/* ===== フォームページ専用スタイル ===== */

.form-page { background: #f5f7fa; min-height: 100vh; }

.form-hero {
  background: linear-gradient(135deg, var(--primary, #2e86ab), var(--primary-dark, #1f6080));
  color: #fff; padding: 48px 24px; text-align: center;
}
.form-category { font-size: .85rem; letter-spacing: .1em; opacity: .8; margin-bottom: 8px; }
.form-hero h1 { font-size: clamp(1.4rem, 4vw, 2rem); font-weight: 900; margin-bottom: 12px; }
.form-hero p { opacity: .85; font-size: .95rem; }

.form-wrap {
  max-width: 720px; margin: 0 auto;
  padding: 40px 0 80px;
}

/* 仕様ボックス */
.info-box {
  background: #fff; border-radius: 12px; padding: 24px;
  margin-bottom: 32px;
  border-left: 4px solid var(--primary, #2e86ab);
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.info-box h3 { font-size: 1rem; margin-bottom: 12px; }
.spec-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.spec-table th, .spec-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid #eee; }
.spec-table th { width: 120px; color: #555; font-weight: 600; white-space: nowrap; }
.info-note { font-size: .8rem; color: #888; margin-top: 12px; }

/* フォーム本体 */
form {
  background: #fff; border-radius: 16px; padding: 40px;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
}

.form-section-title {
  font-size: 1.1rem; font-weight: 700;
  color: var(--primary, #2e86ab);
  border-bottom: 2px solid var(--primary, #2e86ab);
  padding-bottom: 8px; margin: 32px 0 20px;
}
.form-section-title:first-child { margin-top: 0; }

.form-row { margin-bottom: 20px; }
.form-row label { display: block; font-size: .9rem; font-weight: 600; margin-bottom: 6px; color: #444; }
.required { background: #e74c3c; color: #fff; font-size: .72rem; padding: 2px 6px; border-radius: 4px; margin-left: 6px; }

.form-row input[type="text"],
.form-row input[type="email"],
.form-row input[type="tel"],
.form-row input[type="date"],
.form-row select,
.form-row textarea {
  width: 100%; padding: 12px 16px;
  border: 1.5px solid #ddd; border-radius: 8px;
  font-size: 1rem; font-family: inherit; color: #333;
  transition: border-color .2s, box-shadow .2s;
  background: #fafafa;
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus {
  outline: none;
  border-color: var(--primary, #2e86ab);
  box-shadow: 0 0 0 3px rgba(46,134,171,.15);
  background: #fff;
}

.radio-group { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 4px; }
.radio-label {
  display: flex; align-items: center; gap: 6px;
  cursor: pointer; font-size: .95rem; font-weight: 400;
  background: #f0f4f8; border-radius: 8px; padding: 8px 16px;
  border: 1.5px solid transparent; transition: all .2s;
}
.radio-label input { accent-color: var(--primary, #2e86ab); }
.radio-label:has(input:checked) {
  background: rgba(46,134,171,.1);
  border-color: var(--primary, #2e86ab);
  color: var(--primary, #2e86ab);
  font-weight: 600;
}

.form-submit { text-align: center; margin-top: 32px; }
.btn-submit {
  background: var(--primary, #2e86ab); color: #fff;
  border: none; cursor: pointer;
  padding: 16px 72px; border-radius: 40px;
  font-size: 1.1rem; font-weight: 700;
  transition: opacity .2s, transform .1s;
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
}
.btn-submit:hover { opacity: .88; transform: translateY(-1px); }
.btn-submit:active { transform: translateY(0); }

.form-note { text-align: center; font-size: .82rem; color: #888; margin-top: 12px; }

@media (max-width: 768px) {
  form { padding: 24px 16px; }
  .form-wrap { padding: 20px 16px 60px; }
}
