/* =========================================================
   PLTRA — Contact page
   index と同じトーン（黒基調・明朝・余白）。style.css の変数を流用。
   ========================================================= */

.contact-page { background: var(--bg); }

.contact-main {
  max-width: 720px;
  margin: 0 auto;
  padding: clamp(8rem, 18vw, 12rem) var(--gutter) var(--section-y);
}

/* ---- 見出し ---- */
.contact-form-head { margin-bottom: clamp(3rem, 7vw, 4.5rem); }
.contact-form-head .section-no {
  display: block;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: var(--fs-small);
  letter-spacing: var(--ls-wide);
  color: var(--ink-faint);
  margin-bottom: 1.25rem;
}
.contact-form-title {
  font-family: var(--mincho-thin);
  font-size: var(--fs-lead-l);
  font-weight: 300;
  letter-spacing: 0.04em;
  line-height: var(--lh-lead);
  margin-bottom: 1.5rem;
}
.contact-form-note {
  font-size: var(--fs-body);
  color: var(--ink-soft);
  line-height: var(--lh-body);
}

/* ---- フォーム ---- */
.contact-form { display: grid; gap: clamp(1.5rem, 3.5vw, 2.25rem); }
.form-row { display: grid; gap: 0.6rem; }
.form-label {
  font-size: var(--fs-small);
  letter-spacing: 0.1em;
  color: var(--ink-soft);
}
.optional { color: var(--ink-faint); font-size: 0.78rem; margin-left: 0.4em; }

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  font-family: var(--mincho);
  font-size: 1rem;
  letter-spacing: 0.04em;
  padding: 0.75rem 0.25rem;
  transition: border-color .4s var(--ease);
  border-radius: 0;
  -webkit-appearance: none;
  appearance: none;
}
.form-textarea { resize: vertical; line-height: 1.9; border: 1px solid var(--line); padding: 1rem; }
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--ink-soft);
}
.form-input::placeholder,
.form-textarea::placeholder { color: var(--ink-faint); }

/* セレクトの矢印 */
.form-select {
  background-image: linear-gradient(45deg, transparent 50%, var(--ink-soft) 50%),
                    linear-gradient(135deg, var(--ink-soft) 50%, transparent 50%);
  background-position: calc(100% - 14px) center, calc(100% - 9px) center;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 2rem;
  cursor: pointer;
}
.form-select option { background: var(--bg-2); color: var(--ink); }

/* ハニーポット（人間には不可視） */
.honeypot {
  position: absolute;
  left: -9999px;
  width: 1px; height: 1px;
  opacity: 0;
}

.form-consent {
  font-size: var(--fs-small);
  color: var(--ink-faint);
  line-height: 1.9;
  margin-top: 0.5rem;
}
.privacy-link { border-bottom: 1px solid var(--ink-faint); }
.privacy-link:hover { border-color: var(--ink-soft); }

/* 送信ボタン */
.form-button {
  justify-self: start;
  margin-top: 1rem;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: var(--fs-small);
  letter-spacing: var(--ls-wide);
  color: var(--ink);
  background: transparent;
  border: 1px solid var(--ink-faint);
  border-radius: 999px;
  padding: 1rem 3.5rem;
  cursor: pointer;
  transition: background .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease);
}
.form-button:hover {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.form-button:disabled { opacity: 0.5; cursor: default; }

/* 送信ステータス */
.form-status {
  font-size: var(--fs-small);
  letter-spacing: 0.06em;
  min-height: 1.4em;
}
.form-status.is-error { color: #d98b7a; }
.form-status.is-success { color: var(--ink); }

@media (max-width: 768px) {
  .contact-main { padding-top: clamp(6rem, 22vw, 9rem); }
}
