/* ============================================
   Contact Page Styles (お問い合わせ)
   - Breadcrumb/layout: single.css ルール流用
   - Form parts: 検索モーダルのスタイルをベースに調整
   - MW WP Form のHTML構造に合わせてスタイリング
   ============================================ */

/* ============================================
   Reset — 親テーマ(the-thor)の影響を完全排除
   ============================================ */
body.contact-page .l-wrapper,
body.contact-page .l-main,
body.contact-page .l-sidebar,
body.contact-page .wider,
body.contact-page .container,
body.contact-page .viral,
body.contact-page .prevNext,
body.contact-page .snsFollow,
body.contact-page .postCta,
body.contact-page .social-top,
body.contact-page .social-bottom,
body.contact-page .dividerTop,
body.contact-page .dividerBottom,
body.contact-page .heading,
body.contact-page .heading-primary,
body.contact-page .heading-secondary,
body.contact-page .dateList,
body.contact-page .eyecatch,
body.contact-page .postContents,
body.contact-page .content,
body.contact-page .pageContents {
  all: unset;
  display: none !important;
}

/* 独自コンテンツ領域のリセット */
.contact-container,
.contact-container * {
  all: revert;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body.contact-page {
  margin: 0;
  background: #FBF6EE;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-weight: 700;
  color: #333;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ============================================
   Breadcrumb は common.css の .site-breadcrumb に統一
   ============================================ */

/* ============================================
   Main Container (2-column)
   ============================================ */
.contact-container {
  max-width: 1920px;
  margin: 0 auto;
  padding: clamp(63px, calc(45px + 2.344vw), 90px) clamp(161px, calc(115px + 5.99vw), 230px) clamp(84px, calc(60px + 3.125vw), 120px);
  display: flex;
  gap: clamp(70px, calc(50px + 2.604vw), 100px);
}

.contact-main {
  flex: 1;
  min-width: 0;
}

/* Sidebar layout — archive.css / single.css と同じ幅・配置 */
.contact-container .sidebar {
  flex: 0 0 min(18.75vw, 360px);
  width: min(18.75vw, 360px);
  min-width: 0;
}

.contact-article {
  max-width: 800px;
  margin: 0 auto;
}

/* ============================================
   Header
   - タイトル(__title)は common.css の .page-title* に統一
   ============================================ */
.contact-article__header {
  margin-bottom: clamp(42px, calc(30px + 1.563vw), 60px);
}

.contact-article__lead {
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-weight: 700;
  font-size: clamp(11px, calc(8px + 0.417vw), 16px);
  line-height: clamp(25px, calc(18px + 0.911vw), 35px);
  letter-spacing: 0.8px;
  color: #333;
}

/* ============================================
   MW WP Form — Wrapper
   ============================================ */
.contact-form-wrap .mw_wp_form {
  background: #fff;
  border-radius: 10px;
  padding: clamp(35px, calc(25px + 1.302vw), 50px) clamp(42px, calc(30px + 1.563vw), 60px);
}

.contact-form-wrap .mw_wp_form form {
  display: block;
}

/* ============================================
   MW WP Form — H2 をラベルとして整形
   MW WP Form のコンテンツ内で h2 がフォームラベル代わりに使われている
   ============================================ */
.contact-form-wrap .mw_wp_form h2 {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--color-primary) !important;
  height: auto;
  line-height: 25px;
  border-left: 5px solid var(--color-primary);
  padding-left: 20px;
  margin-top: clamp(28px, calc(20px + 1.042vw), 40px);
  margin-bottom: 16px;
  border-bottom: none;
  background: none;
}

/* 最初のh2の上マージンは不要 */
.contact-form-wrap .mw_wp_form form > h2:first-child,
.contact-form-wrap .mw_wp_form h2:first-of-type {
  margin-top: 0;
}

/* インライン style="color: #ff0000;" の ※必須 表示を上書き */
.contact-form-wrap .mw_wp_form h2 span[style] {
  color: #fff !important;
  background: var(--color-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 22px;
  padding: 0 10px;
  border-radius: 22px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
}

/* ============================================
   MW WP Form — Input / Email / Text
   ============================================ */
.contact-form-wrap .mw_wp_form input[type="text"],
.contact-form-wrap .mw_wp_form input[type="email"] {
  width: 100%;
  height: clamp(52px, calc(38px + 1.823vw), 75px);
  padding: 0 clamp(20px, calc(14px + 0.781vw), 40px);
  border: none;
  border-radius: 10px;
  box-shadow: inset 0px 1px 8px 1px rgba(0, 0, 0, 0.1);
  font-family: var(--font-sans);
  font-size: clamp(14px, calc(12px + 0.26vw), 18px);
  font-weight: 700;
  color: var(--color-text);
  background: #FBF6EE;
  transition: box-shadow 0.2s;
  margin-bottom: 4px;
}

.contact-form-wrap .mw_wp_form input[type="text"]::placeholder,
.contact-form-wrap .mw_wp_form input[type="email"]::placeholder {
  color: #b4b4b4;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.contact-form-wrap .mw_wp_form input[type="text"]:focus,
.contact-form-wrap .mw_wp_form input[type="email"]:focus {
  outline: none;
  box-shadow: inset 0px 1px 8px 1px rgba(0, 0, 0, 0.15);
}

/* ============================================
   MW WP Form — Tel（3分割フィールド）
   ============================================ */
.contact-form-wrap .mw_wp_form .mwform-tel-field {
  display: flex;
  align-items: center;
  gap: 8px;
}

.contact-form-wrap .mw_wp_form .mwform-tel-field input[type="text"] {
  flex: 1;
  min-width: 0;
}

/* ============================================
   MW WP Form — Textarea
   ============================================ */
.contact-form-wrap .mw_wp_form textarea {
  width: 100%;
  padding: clamp(14px, calc(10px + 0.521vw), 20px) clamp(20px, calc(14px + 0.781vw), 40px);
  border: none;
  border-radius: 10px;
  box-shadow: inset 0px 1px 8px 1px rgba(0, 0, 0, 0.1);
  font-family: var(--font-sans);
  font-size: clamp(14px, calc(12px + 0.26vw), 18px);
  font-weight: 700;
  color: var(--color-text);
  background: #FBF6EE;
  min-height: 200px;
  resize: vertical;
  line-height: 1.8;
  transition: box-shadow 0.2s;
}

.contact-form-wrap .mw_wp_form textarea::placeholder {
  color: #b4b4b4;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.contact-form-wrap .mw_wp_form textarea:focus {
  outline: none;
  box-shadow: inset 0px 1px 8px 1px rgba(0, 0, 0, 0.15);
}

/* ============================================
   MW WP Form — Radio
   ============================================ */
.contact-form-wrap .mw_wp_form .mwform-radio-field {
  display: inline-flex;
  align-items: center;
  margin-right: 24px;
  margin-bottom: 8px;
}

.contact-form-wrap .mw_wp_form .mwform-radio-field.vertical-item {
  display: flex;
  margin-right: 0;
  margin-bottom: 12px;
}

.contact-form-wrap .mw_wp_form .mwform-radio-field label {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-weight: 700;
}

.contact-form-wrap .mw_wp_form .mwform-radio-field input[type="radio"] {
  width: 20px;
  height: 20px;
  accent-color: var(--color-primary);
  margin: 0;
  cursor: pointer;
}

.contact-form-wrap .mw_wp_form .mwform-radio-field-text {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text);
}

/* ============================================
   MW WP Form — Checkbox
   ============================================ */
.contact-form-wrap .mw_wp_form .mwform-checkbox-field {
  display: inline-flex;
  align-items: center;
  margin-right: 24px;
  margin-bottom: 8px;
  margin-top: 30px;
}

.contact-form-wrap .mw_wp_form .mwform-checkbox-field.vertical-item {
  display: flex;
  margin-right: 0;
}

.contact-form-wrap .mw_wp_form .mwform-checkbox-field label {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-weight: 700;
}

.contact-form-wrap .mw_wp_form .mwform-checkbox-field input[type="checkbox"] {
  width: 20px;
  height: 20px;
  accent-color: var(--color-primary);
  margin: 0;
  cursor: pointer;
}

.contact-form-wrap .mw_wp_form .mwform-checkbox-field-text {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text);
}

/* ============================================
   MW WP Form — プライバシーポリシー・個人情報エリア
   .agreement_contents 内のテキストを読みやすく整形
   ============================================ */
.contact-form-wrap .mw_wp_form .agreement_contents {
  margin-top: clamp(28px, calc(20px + 1.042vw), 40px);
  border: 1px solid var(--color-border, #ddd);
  border-radius: 8px;
  overflow: hidden;
}

.contact-form-wrap .mw_wp_form .agreement_title {
  /* インラインスタイルを上書き */
  display: flex !important;
  align-items: center;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--color-primary) !important;
  background: #f9f5f0;
  padding: 16px 20px !important;
  margin: 0 !important;
  border-bottom: 1px solid var(--color-border, #ddd) !important;
  cursor: default;
}

.contact-form-wrap .mw_wp_form .agreement-box {
  max-height: 300px;
  overflow-y: auto;
  padding: 20px;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.9;
  color: #555;
}

/* agreement-box 内の h2 をコンテンツ見出しとして整形（ラベルとは別） */
.contact-form-wrap .mw_wp_form .agreement-box h2 {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #333 !important;
  border-left: none;
  padding-left: 0;
  margin-top: 20px;
  margin-bottom: 8px;
  height: auto;
  line-height: 1.6;
  gap: 0;
}

.contact-form-wrap .mw_wp_form .agreement-box p,
.contact-form-wrap .mw_wp_form .agreement-box .maincontent-leadcopy {
  margin-bottom: 12px;
  font-size: 13px;
  line-height: 1.9;
}

/* agreement-box 内のテーブル */
.contact-form-wrap .mw_wp_form .agreement-box table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
  font-size: 12px;
}

.contact-form-wrap .mw_wp_form .agreement-box table caption {
  text-align: left;
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 8px;
  color: #333;
}

.contact-form-wrap .mw_wp_form .agreement-box table th,
.contact-form-wrap .mw_wp_form .agreement-box table td {
  border: 1px solid #ddd;
  padding: 8px 12px;
  text-align: left;
  vertical-align: top;
}

.contact-form-wrap .mw_wp_form .agreement-box table th {
  background: var(--color-primary);
  color: #fff;
  font-weight: 700;
}

.contact-form-wrap .mw_wp_form .agreement-box strong {
  font-weight: 900;
}

/* ============================================
   MW WP Form — Submit Button
   .btn__link-primary クラスが付与される送信ボタン
   デザインは .btn-membership に合わせる
   ============================================ */
.contact-form-wrap .mw_wp_form p[style] {
  text-align: center !important;
  margin-top: clamp(28px, calc(20px + 1.042vw), 40px);
}

.contact-form-wrap .mw_wp_form input[type="submit"],
.contact-form-wrap .mw_wp_form .btn__link-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(266px, calc(190px + 9.896vw), 380px);
  height: clamp(74px, calc(53px + 2.734vw), 105px);
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: clamp(15px, calc(11px + 0.573vw), 22px);
  line-height: 1;
  letter-spacing: 0;
  border: none;
  border-radius: clamp(49px, calc(35px + 1.823vw), 70px);
  cursor: pointer;
  transition: opacity 0.3s;
  text-decoration: none;
}

.contact-form-wrap .mw_wp_form input[type="submit"]:hover,
.contact-form-wrap .mw_wp_form .btn__link-primary:hover {
  opacity: 0.7;
}

/* MW WP Form の確認画面用ボタン（戻るボタン等） */
.contact-form-wrap .mw_wp_form input[type="submit"][name*="back"] {
  background: #999;
}

/* ============================================
   MW WP Form — Error message
   ============================================ */
.contact-form-wrap .mw_wp_form .error {
  font-size: 13px;
  color: #B70000;
  display: block;
  margin-top: 6px;
}

/* ============================================
   MW WP Form — 確認画面
   ============================================ */
.contact-form-wrap .mw_wp_form_confirm h2 {
  margin-top: clamp(28px, calc(20px + 1.042vw), 40px);
}

.contact-form-wrap .mw_wp_form_confirm h2:first-of-type {
  margin-top: 0;
}

/* ============================================
   Responsive — Tablet (≤ 1199px)
   ============================================ */
@media (max-width: 1199px) {
  .contact-container {
    flex-direction: column;
    padding: 50px 40px clamp(84px, calc(60px + 3.125vw), 120px);
    gap: 50px;
  }

  .contact-container .sidebar {
    flex: none;
    width: 100%;
    max-width: 700px;
    margin: 0 auto;
    overflow: visible;
  }

  .contact-form-wrap .mw_wp_form {
    padding: 35px 30px;
  }

  /* Submit — btn-membership Tablet に合わせる */
  .contact-form-wrap .mw_wp_form input[type="submit"],
  .contact-form-wrap .mw_wp_form .btn__link-primary {
    width: 320px;
    height: 85px;
    font-size: 20px;
  }
}

/* ============================================
   Responsive — SP (≤ 767px)
   ============================================ */
@media (max-width: 767px) {
  .contact-container {
    padding: 30px 20px 84px;
    gap: 40px;
  }

  .contact-container .sidebar {
    max-width: 100%;
  }

  .contact-article__lead {
    font-size: 14px;
    line-height: 26px;
  }

  .br-pc {
    display: none;
  }

  /* Form wrapper */
  .contact-form-wrap .mw_wp_form {
    padding: 25px 20px;
    border-radius: 8px;
  }

  /* H2 labels */
  .contact-form-wrap .mw_wp_form h2 {
    font-size: 14px;
    padding-left: 15px;
    border-left-width: 4px;
    margin-bottom: 12px;
    flex-wrap: wrap;
    gap: 8px;
  }

  .contact-form-wrap .mw_wp_form h2 span[style] {
    height: 20px;
    padding: 0 8px;
    font-size: 10px;
  }

  /* Inputs */
  .contact-form-wrap .mw_wp_form input[type="text"],
  .contact-form-wrap .mw_wp_form input[type="email"] {
    height: 48px;
    font-size: 16px;
    padding: 0 14px;
    border-radius: 6px;
  }

  .contact-form-wrap .mw_wp_form input[type="text"]::placeholder,
  .contact-form-wrap .mw_wp_form input[type="email"]::placeholder {
    font-size: 14px;
  }

  .contact-form-wrap .mw_wp_form textarea {
    font-size: 16px;
    padding: 14px;
    border-radius: 6px;
    min-height: 160px;
  }

  .contact-form-wrap .mw_wp_form textarea::placeholder {
    font-size: 14px;
  }

  /* Radio / Checkbox */
  .contact-form-wrap .mw_wp_form .mwform-radio-field-text,
  .contact-form-wrap .mw_wp_form .mwform-checkbox-field-text {
    font-size: 14px;
  }

  .contact-form-wrap .mw_wp_form .mwform-radio-field input[type="radio"],
  .contact-form-wrap .mw_wp_form .mwform-checkbox-field input[type="checkbox"] {
    width: 18px;
    height: 18px;
  }

  /* Agreement box */
  .contact-form-wrap .mw_wp_form .agreement_title {
    font-size: 13px !important;
    padding: 12px 16px !important;
  }

  .contact-form-wrap .mw_wp_form .agreement-box {
    max-height: 200px;
    padding: 16px;
    font-size: 12px;
  }

  .contact-form-wrap .mw_wp_form .agreement-box h2 {
    font-size: 13px;
  }

  .contact-form-wrap .mw_wp_form .agreement-box table {
    font-size: 11px;
  }

  .contact-form-wrap .mw_wp_form .agreement-box table th,
  .contact-form-wrap .mw_wp_form .agreement-box table td {
    padding: 6px 8px;
  }

  /* Submit — btn-membership SP に合わせる */
  .contact-form-wrap .mw_wp_form input[type="submit"],
  .contact-form-wrap .mw_wp_form .btn__link-primary {
    width: 80%;
    max-width: 260px;
    height: 65px;
    font-size: 15px;
    border-radius: 65px;
  }
}
