/* ===========================================
   atelier hanaroman  |  Reservation form
   =========================================== */

.hr-form {
  max-width: 640px;
  margin: 0 auto;
  background: var(--color-cream-deep);
  border-radius: 8px;
  padding: clamp(24px, 5vw, 48px);
}

.hr-form__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.hr-form__row { margin-bottom: 22px; }
.hr-form__grid { display: grid; grid-template-columns: 1fr; gap: 0 22px; }
@media (min-width: 600px){ .hr-form__grid { grid-template-columns: 1fr 1fr; } }

.hr-form__label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: .08em;
  color: var(--color-heading);
  margin-bottom: 8px;
}
.hr-form__req {
  font-size: 10px;
  letter-spacing: .05em;
  color: #fff;
  background: var(--color-accent);
  padding: 2px 8px;
  border-radius: 3px;
}

.hr-form__input,
.hr-form__textarea {
  width: 100%;
  padding: 13px 16px;
  border: 1px solid var(--color-line);
  border-radius: 4px;
  font: inherit;
  letter-spacing: .04em;
  background: #fff;
  color: var(--color-text);
  transition: border-color .25s ease, box-shadow .25s ease;
}
.hr-form__input:focus,
.hr-form__textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(217,138,130,.18);
}
.hr-form__textarea { resize: vertical; min-height: 140px; }

select.hr-form__input {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23d98a82' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 40px;
}

/* Fieldsets (radio / checkbox groups) */
.hr-form__fieldset { border: 0; margin: 0 0 22px; padding: 0; }
.hr-form__fieldset legend { padding: 0; }
.hr-form__choices {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 22px;
  margin-top: 4px;
}
.hr-form__choice {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  letter-spacing: .04em;
  cursor: pointer;
}
.hr-form__choice input {
  width: 18px; height: 18px;
  accent-color: var(--color-accent);
  cursor: pointer;
}

.hr-form__note { font-size: 12px; color: var(--color-text); text-align: center; margin: 6px 0 26px; }
.hr-form__submit { text-align: center; }

/* Alerts */
.hr-form__alert { border-radius: 6px; padding: 18px 22px; margin-bottom: 26px; line-height: 1.9; }
.hr-form__alert--success { background: #eaf4ec; border: 1px solid #bcdcc2; color: #3d6b46; }
.hr-form__alert--error   { background: #fbeceb; border: 1px solid #e9c2bd; color: var(--color-accent-deep); }
.hr-form__alert ul { margin: 8px 0 0; padding-left: 1.2em; }
.hr-form__alert li { list-style: disc; }
