/* --------------------------------------------------------------------------

Form

-------------------------------------------------------------------------- */

.form { padding: 0 0 80px; }
.form__container { max-width: 768px; margin: 0 auto; padding: 0 16px; }

@media (max-width: 768px) {
  .form { padding: 0 0 40px; }
}

.form__desc { font-size: 1.6rem; line-height: 1.5; margin-bottom: 16px; }
.form__note { font-size: 1.3rem; text-align: right; margin-bottom: 16px; }
.form__body { display: grid; row-gap: 24px; }
.form__group { display: grid; row-gap: 12px; }
.form__group[hidden] { display: none; }
.form__label { font-size: 1.6rem; font-weight: 700; }
.form__help { font-size: 1.4rem; line-height: 1.5; color: #666; }
.form__field { width: 100%; height: 56px; padding: 0 14px; border: 1px solid #bbb; border-radius: 8px; background: transparent; font-size: 1.6rem; }
.form__field:focus-visible { outline: none; border-color: #ff289f; box-shadow: 0 0 0 3px color-mix(in oklab, #ff289f 30%, transparent); }
textarea.form__field { height: 180px; padding: 12px 14px; }
.form__select { position: relative; height: 56px; }
.form__select select.form__field { appearance: none; -webkit-appearance: none; }
.form__select::before { position: absolute; top: 22px; right: 20px; width: 0; height: 0; content: ""; border-left: 8px solid transparent; border-right: 8px solid transparent; border-top: 12px solid #333; pointer-events: none; }
.form__other { display: none; margin-top: 8px; }
.form__radios { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; }
.form__radio { display: inline-flex; align-items: center; gap: 8px; font-size: 1.5rem; }
.form__radio input[type="radio"] { width: 16px; height: 16px; accent-color: #ff289f; }
.form__choices { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; padding: 4px 0; }
.form__choice { display: inline-flex; align-items: center; gap: 8px; font-size: 1.5rem; line-height: 1.4; }
.form__choice-input { width: 18px; height: 18px; accent-color: #ff289f; }
.form__choice-input:focus-visible { outline: none; box-shadow: 0 0 0 3px color-mix(in oklab, #ff289f 30%, transparent); border-radius: 3px; }
.form__choice-label { display: inline-block; }
.form__group--consent { display: flex; justify-content: center; text-align: center; font-size: 1.4rem; background: #e9e9e9; border-radius: 8px; padding: 14px 12px; }
.form__group--consent .form__choice { justify-content: center; }
a.form__consent-link { text-decoration: underline; }
a.form__consent-link:hover { text-decoration: none; }
.form__actions { display: flex; justify-content: center; }
.form__button { width: 400px; position: relative; display: inline-block; font-size: 2rem; font-weight: 900; letter-spacing: .5px; color: #333; background: transparent; border: 2px solid #333; border-radius: 100vh; text-align: center; padding: 24px 0; margin-top: 16px; transition: .3s; }
.form__button::after { content: ""; position: absolute; top: 42%; right: 24px; width: 12px; height: 12px; border-top: 3px solid #333; border-right: 3px solid #333; transform: rotate(45deg); transition: .3s; }
.form__button:hover { color: #fff; background: #333; }
.form__button:hover::after { right: 20px; border-color: #fff; }
.form__button:focus-visible { outline: 2px solid #ff289f; outline-offset: 2px; }
.form__button:active { transform: translateY(1px); }

@media (max-width: 768px) {
  .form__body { row-gap: 16px; }
  .form__button { width: 90%; font-size: 1.8rem; }
  .form__button::after { top: 42%; right: 20px; width: 8px; height: 8px; border-top: 2px solid #333; border-right: 2px solid #333; }
}

.form__req { color: #ff289f; margin-left: 6px; font-weight: 700; }


input, button, select, textarea { appearance: auto; -webkit-appearance: auto; -moz-appearance: auto; padding: 0; }
