@charset "utf-8";
/* ===============================
Contact
=============================== */
.contact-form {
  background: var(--pink-dark);
  color: var(--ink);
  padding: 80px 20px;
}

.contact-form__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 40px 20px;
}

.form-title {
  font-family: "Sansation", sans-serif;
  font-size: 6rem;
  font-weight: 700;
  margin-bottom: 50px;
  text-align: center;
}
/* pc 768px */

/* ==========================
   SP contact（〜768px）
=========================== */
@media (max-width: 768px){
  .contact-form {
    padding-top: 60px;
  }

  .contact-form__inner {
    padding: 100px 25px 0;
  }

  .form-title {
    font-size: 2rem;
  }
}

/* ===========================
  お問い合わせフォーム
=========================== */
.cform__lead {
  max-width: 760px;
  margin: 0 auto 32px;
  text-align: center;
  font-size: 1.6rem;
  line-height: 1.9;
  color: #fff;
}

.cform__simnote {
  max-width: 760px;
  margin: 0 auto 24px;
  padding: 16px 22px;
  border-radius: 8px;
  background: #fff;
  border-left: 6px solid var(--ink);
  font-size: 1.4rem;
  line-height: 1.7;
  color: var(--ink);
  box-shadow: 0 6px 18px rgba(29, 35, 49, 0.15);
}

.cform {
  max-width: 760px;
  margin: 0 auto;
  padding: 48px 48px 56px;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(29, 35, 49, 0.2);
}

.cform__row {
  margin-bottom: 28px;
}

.cform__label {
  display: block;
  margin-bottom: 10px;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ink);
}

.cform__req {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 8px;
  border-radius: 4px;
  background: var(--pink-dark);
  color: #fff;
  font-size: 1.1rem;
  font-weight: 700;
  vertical-align: middle;
}

.cform__input {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid #ccc;
  border-radius: 6px;
  background: #fff;
  font-size: 1.5rem;
  line-height: 1.6;
  color: var(--ink);
  font-family: inherit;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.cform__input::placeholder { color: #aaa; }

.cform__input:focus {
  outline: none;
  border-color: var(--pink-dark);
  box-shadow: 0 0 0 3px rgba(248, 14, 147, 0.15);
}

.cform__input:invalid:not(:placeholder-shown) {
  border-color: var(--pink-dark);
}

.cform__textarea {
  min-height: 220px;
  resize: vertical;
}

/* セレクト（プルダウン） */
.cform__select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 44px;
  cursor: pointer;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'><path d='M1 1l6 6 6-6' fill='none' stroke='%231D2331' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 16px center;
}

.cform__select:invalid {
  color: #aaa;
}

/* 自動入力（読み取り専用）のシミュレーション結果 */
.cform__textarea--readonly {
  min-height: 260px;
  background: #FAFAFB;
  color: #555;
  white-space: pre-wrap;
  cursor: default;
}

.cform__textarea--readonly:focus {
  border-color: #ccc;
  box-shadow: none;
}

/* ラベル横の「自動入力」バッジ */
.cform__note-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 8px;
  border-radius: 4px;
  background: var(--ink);
  color: #fff;
  font-size: 1.1rem;
  font-weight: 700;
  vertical-align: middle;
}

/* ハニーポット（人間には非表示） */
.cform__hp {
  position: absolute !important;
  left: -9999px !important;
  width: 1px;
  height: 1px;
  opacity: 0;
}

.cform__error {
  margin-bottom: 20px;
  padding: 12px 16px;
  border-radius: 6px;
  background: #FFF0F5;
  color: var(--pink-dark);
  font-size: 1.4rem;
  font-weight: 700;
}

.cform__submit-wrap {
  text-align: center;
  margin-top: 8px;
}

.cform__submit {
  min-width: 240px;
  padding: 18px 56px;
  border: none;
  cursor: pointer;
  border-radius: 999px;
  background: var(--pink-dark);
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 6px 18px rgba(248, 14, 147, 0.28);
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.cform__submit:hover { opacity: .9; transform: translateY(-1px); }
.cform__submit:disabled { opacity: .6; cursor: default; transform: none; }

.cform__done {
  max-width: 760px;
  margin: 0 auto;
  padding: 56px 48px;
  background: #fff;
  border-radius: 12px;
  text-align: center;
  box-shadow: 0 12px 32px rgba(29, 35, 49, 0.2);
}
.cform__done-title {
  font-size: 2rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 16px;
}
.cform__done-text {
  font-size: 1.5rem;
  line-height: 1.9;
  color: var(--ink);
}

@media (max-width: 768px) {
  .cform__lead { font-size: 1.4rem; }
  .cform { padding: 32px 22px 40px; }
  .cform__input { font-size: 1.6rem; } /* iOSズーム防止 */
  .cform__submit { width: 100%; min-width: 0; }
  .cform__done { padding: 40px 22px; }
}