@charset "UTF-8";
/* =========================================================================
   contact.css — お問い合わせフロー（入力/確認/購入）新デザイン 2026-06-22
   フォームの markup / name / action / JS は不変。見た目のみ新デザインへ。
   すべて body.sdp-contact-page にスコープして他ページへ波及させない。
   色トークンは styles.css / service.css の :root を継承（fallback付き）。
   ========================================================================= */

body.sdp-contact-page {
  --c-brand: var(--brand, #a34f4d);
  --c-brand-dark: var(--brand-dark, #803d3c);
  --c-ink: var(--ink, #242122);
  --c-muted: var(--muted, #5d5857);
  --c-line: var(--line, #e3dad6);
  --c-soft: #fbf8f5;
  background: #fff;
  color: var(--c-ink);
}

/* ---- レイアウト容器 ---- */
body.sdp-contact-page .layout_shop,
body.sdp-contact-page .page_shop,
body.sdp-contact-page .container,
body.sdp-contact-page main { display: block; width: auto; margin: 0; padding: 0; background: none; }

body.sdp-contact-page #main_contents {
  width: min(100% - 32px, 880px);
  margin: 0 auto;
  padding: 30px 0 64px;
  box-sizing: border-box;
}

/* ---- 見出し ---- */
body.sdp-contact-page .title_01 {
  margin: 8px 0 28px;
  padding: 0 0 18px;
  border-bottom: 2px solid var(--c-line);
  color: var(--c-ink);
  font-size: clamp(22px, 4.4vw, 31px);
  line-height: 1.5;
  font-weight: 900;
}
body.sdp-contact-page .title_01 .label {
  display: inline-block;
  margin: 0 0 8px;
  padding: 4px 14px;
  border-radius: 999px;
  background: var(--c-brand);
  color: #fff;
  font-size: 14px;
  font-weight: 800;
}

body.sdp-contact-page .heading_02 {
  position: relative;
  margin: 40px 0 12px;
  padding: 0 0 0 16px;
  color: var(--c-ink);
  font-size: clamp(18px, 3.4vw, 23px);
  line-height: 1.5;
  font-weight: 900;
}
body.sdp-contact-page .heading_02::before {
  content: "";
  position: absolute;
  top: 4px; left: 0; bottom: 4px;
  width: 5px;
  border-radius: 3px;
  background: var(--c-brand);
}
body.sdp-contact-page .heading_02 span { color: var(--c-brand-dark); }

body.sdp-contact-page .lead { margin: 0 0 22px; color: var(--c-muted); font-size: 15px; line-height: 1.9; }

/* ---- 電話ボックス ---- */
body.sdp-contact-page .telbox {
  margin: 0 0 12px;
  padding: 24px 22px;
  border: 1px solid var(--c-line);
  border-radius: 12px;
  background: linear-gradient(180deg, #fff 0%, var(--c-soft) 100%);
  text-align: center;
  box-shadow: 0 10px 28px rgba(80, 54, 50, .07);
}
body.sdp-contact-page .telbox_shopname { color: var(--c-muted); font-size: 14px; font-weight: 700; }
body.sdp-contact-page .telbox_telnum { margin: 4px 0 6px; color: var(--c-brand); font-size: clamp(30px, 8vw, 44px); line-height: 1.15; font-weight: 900; letter-spacing: .02em; }
body.sdp-contact-page .telbox_date { color: var(--c-muted); font-size: 13px; line-height: 1.7; }
body.sdp-contact-page .telbox_btn { margin: 14px 0 0; }
body.sdp-contact-page .telbox_btn img,
body.sdp-contact-page .telbox_balloon img,
body.sdp-contact-page .form_step img { max-width: 100%; height: auto; }
body.sdp-contact-page .telbox_balloon { margin: 10px 0 0; }

/* ---- フォーム全体 ---- */
body.sdp-contact-page .form_area { margin: 6px 0 0; }
body.sdp-contact-page .form_step { margin: 0 0 18px; text-align: center; }

body.sdp-contact-page dl.formset { margin: 0; }
body.sdp-contact-page dl.formset > dt {
  margin: 22px 0 8px;
  color: var(--c-ink);
  font-size: 15px;
  font-weight: 800;
}
body.sdp-contact-page dl.formset > dt.inp_must::after {
  content: "必須";
  display: inline-block;
  margin-left: 8px;
  padding: 2px 9px;
  border-radius: 4px;
  background: var(--c-brand);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  vertical-align: 2px;
}
body.sdp-contact-page dl.formset > dt.inp_free::after {
  content: "任意";
  display: inline-block;
  margin-left: 8px;
  padding: 2px 9px;
  border-radius: 4px;
  background: #eee5e1;
  color: var(--c-muted);
  font-size: 11px;
  font-weight: 800;
  vertical-align: 2px;
}
body.sdp-contact-page dl.formset > dd { margin: 0 0 4px; }
body.sdp-contact-page dl.formset > dd > p { margin: 0 0 8px; color: var(--c-muted); font-size: 13px; }

/* ---- 入力フィールド ---- */
body.sdp-contact-page input[type="text"],
body.sdp-contact-page input[type="email"],
body.sdp-contact-page input[type="tel"],
body.sdp-contact-page select,
body.sdp-contact-page textarea {
  width: 100%;
  max-width: 100%;
  padding: 13px 14px;
  border: 1px solid var(--c-line);
  border-radius: 8px;
  background: #fff;
  color: var(--c-ink);
  font-size: 16px; /* iOSの自動ズーム防止 */
  line-height: 1.6;
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color .2s, box-shadow .2s;
}
body.sdp-contact-page select {
  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='%23803d3c' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}
body.sdp-contact-page textarea { min-height: 120px; resize: vertical; }
body.sdp-contact-page input[type="text"]:focus,
body.sdp-contact-page select:focus,
body.sdp-contact-page textarea:focus {
  outline: none;
  border-color: var(--c-brand);
  box-shadow: 0 0 0 3px rgba(163, 79, 77, .14);
}

/* ---- チェックボックス / ラジオ ---- */
body.sdp-contact-page dd ul { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 6px 16px; margin: 0 0 10px; padding: 0; list-style: none; }
body.sdp-contact-page dd ul li { margin: 0; }
body.sdp-contact-page dd label { display: inline-flex; align-items: center; gap: 7px; color: var(--c-ink); font-size: 15px; line-height: 1.7; cursor: pointer; }
body.sdp-contact-page dd input[type="checkbox"],
body.sdp-contact-page dd input[type="radio"] { width: 18px; height: 18px; margin: 0; accent-color: var(--c-brand); flex: 0 0 auto; }
body.sdp-contact-page .form_agree label { font-weight: 700; }

/* ---- アンケート / ポリシー ---- */
body.sdp-contact-page .form_enquete,
body.sdp-contact-page .form_policy { margin: 30px 0 0; padding: 22px; border: 1px solid var(--c-line); border-radius: 12px; background: var(--c-soft); }
body.sdp-contact-page .form_enquete h3,
body.sdp-contact-page .form_policy h3 { margin: 0 0 12px; color: var(--c-brand-dark); font-size: 16px; font-weight: 900; }
body.sdp-contact-page .form_policy_body { max-height: 220px; overflow-y: auto; padding: 16px; border: 1px solid var(--c-line); border-radius: 8px; background: #fff; color: var(--c-muted); font-size: 13px; line-height: 1.85; }

body.sdp-contact-page .form_agree { margin: 22px 0 0; padding: 18px; border: 1px solid var(--c-brand); border-radius: 10px; background: #fff; text-align: center; }
body.sdp-contact-page .form_agree p { margin: 0 0 10px; color: var(--c-ink); font-weight: 700; }

/* ---- 送信ボタン ---- */
body.sdp-contact-page .form_btn { margin: 28px 0 0; text-align: center; }
body.sdp-contact-page .form_btn input[type="submit"],
body.sdp-contact-page .form_btn input[type="button"],
body.sdp-contact-page .form_btn button {
  display: inline-block;
  width: min(100%, 420px);
  padding: 17px 28px;
  border: 0;
  border-radius: 10px;
  background: var(--c-brand);
  color: #fff;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: .04em;
  cursor: pointer;
  box-shadow: 0 12px 26px rgba(163, 79, 77, .28);
  transition: background .2s, transform .08s;
  -webkit-appearance: none;
  appearance: none;
}
body.sdp-contact-page .form_btn input[type="submit"]:hover,
body.sdp-contact-page .form_btn button:hover { background: var(--c-brand-dark); }
body.sdp-contact-page .form_btn input[type="submit"]:active { transform: translateY(1px); }
/* 確認画面などの「戻る」系ボタンは控えめに */
body.sdp-contact-page .form_btn .btn_back input,
body.sdp-contact-page .form_btn input.back,
body.sdp-contact-page .btn_back input { background: #fff; color: var(--c-brand-dark); border: 1.5px solid var(--c-line); box-shadow: none; }

/* ---- 確認/購入画面で入力値を表示する dd ---- */
body.sdp-contact-page .formset.confirm > dd,
body.sdp-contact-page dd.confirm_value { padding: 12px 14px; border: 1px solid var(--c-line); border-radius: 8px; background: var(--c-soft); }

/* ---- 補足リンク ---- */
body.sdp-contact-page #main_contents p a { color: var(--c-brand-dark); font-weight: 700; }

/* ---- レスポンシブ表示切替（旧 rwd.css 相当の最小限） ---- */
body.sdp-contact-page .is_sp { display: none; }
body.sdp-contact-page .is_pc { display: inline; }
@media (max-width: 768px) {
  body.sdp-contact-page .is_sp { display: block; }
  body.sdp-contact-page .is_pc { display: none; }
  body.sdp-contact-page #main_contents { padding: 22px 0 56px; }
  body.sdp-contact-page dd ul { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 460px) {
  body.sdp-contact-page dd ul { grid-template-columns: 1fr; }
}

/* フォーム進行ステップ: 旧コーラル(#e85e6a)画像→ブランド赤のCSSステップ 2026-06-24 */
.form_step img{display:none !important}
.sdp-form-steps{display:flex;gap:8px;margin:18px 0 30px;padding:0;list-style:none}
.sdp-form-steps li{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;min-height:52px;padding:10px 6px;border-radius:8px;background:#efe9e7;color:#8a7f7c;font-weight:800;font-size:14px;line-height:1.3;text-align:center}
.sdp-form-steps li .n{display:inline-flex;width:22px;height:22px;border-radius:50%;background:#cbbdb9;color:#fff;align-items:center;justify-content:center;font-size:12px;flex:0 0 auto}
.sdp-form-steps li.is-active{background:#a34f4d;color:#fff}
.sdp-form-steps li.is-active .n{background:#fff;color:#a34f4d}
.sdp-form-steps li.is-done{background:#d8c5c3;color:#fff}
.sdp-form-steps li.is-done .n{background:#fff;color:#803d3c}
@media (max-width:520px){.sdp-form-steps li{font-size:12px;flex-direction:column;gap:3px;min-height:58px}}
