/* Contactページ専用。テンプレの .page-contact / .ct-* と CF7 に合わせた版 */
.page-contact{
  --max: 1040px;
  --pad: 24px;
  --accent: var(--color-accent-blue);
  --ink: var(--primary-black);
  --muted: #6b7b84;
  --panel: #e3f4f4;
  --panel-inner: #ffffff;
}

/* 共通コンテナ */
.page-contact .ct-hero,
.page-contact .ct-lead__inner,
.page-contact .ct-form,
.page-contact .ct-back{
  max-width: var(--max);
  margin: 0 auto;
  padding-left: var(--pad);
  padding-right: var(--pad);
}

/* ヒーロー */
.page-contact .ct-hero{ padding-top: 80px; }
.page-contact .ct-title{ text-align:center; margin:0 0 18px; }
.page-contact .ct-eyebrow{
  display:block; font-weight:700; font-size: var(--font-h2); letter-spacing:.06em; color: var(--ink);
}
.page-contact .ct-sub{
  display:inline-flex; gap:8px; align-items:center; font-size:12px;
  color: var(--muted); letter-spacing:.12em;
}
.page-contact .ct-sub::before{
  content:""; width:0;height:0; border-left:7px solid #F3C24B;
  border-top:4px solid transparent; border-bottom:4px solid transparent;
}

/* リードボックス（本文はエディタから） */
.page-contact .ct-lead__inner{
  background: var(--panel);
  border-radius: 24px;
  padding: clamp(16px,3vw,24px);
  margin: 18px auto 28px;
  box-shadow: 0 4px 12px rgba(0,0,0,.03) inset;
  text-align: center;
}
.page-contact .ct-lead__inner p{ margin: 0 0 1em; }
.page-contact .ct-lead__inner .ct-bullets{
  background: var(--panel-inner); border-radius: 12px; padding: 14px 16px;
  max-width: 520px; margin: 12px auto 0; box-shadow: 0 1px 0 rgba(0,0,0,.05);
}
.page-contact .ct-bullets__title{
  display:inline-block; font-size:12px; color:var(--muted); letter-spacing:.12em; margin-bottom:6px;
}
.page-contact .ct-bullets ul{ margin:0; padding-left:1.2em; text-align:left; display:inline-block; }
.page-contact .ct-bullets li{ position:relative; margin:.25em 0; }
.page-contact .ct-bullets li::before{
  content:""; position:absolute; left:-1.1em; top:.6em;
  width:0;height:0; border-left:6px solid #F3C24B;
  border-top:4px solid transparent; border-bottom:4px solid transparent;
}

/* フォーム枠 */
.page-contact .ct-form{
  background: var(--panel);
  border-radius: 24px;
  padding: clamp(16px,5vw,24px);
  margin-bottom: 32px;
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
}
.page-contact .ct-form__inner{ background:#e5f7f7; border-radius:12px; padding: clamp(12px,3.6vw,22px); }
.page-contact .ct-note{ text-align:center; color:var(--muted); margin-top:10px; }

/* CF7 スキン */
.page-contact .wpcf7 form p{ margin-bottom:24px; }
.page-contact .wpcf7 label{     display: flex
;
    font-weight: 600;
    margin-bottom: 6px;
    flex-direction: column;
    gap: 0.5em; }
.page-contact .wpcf7 input[type="text"],
.page-contact .wpcf7 input[type="email"],
.page-contact .wpcf7 select,
.page-contact .wpcf7 textarea{
  width:100%; background:#fff; border:1px solid #dfe6e9; border-radius:10px;
  padding:14px 16px; font-size:var(--font-p);
}
.page-contact .wpcf7 textarea{ min-height:180px; resize:vertical; }
.page-contact .wpcf7 .wpcf7-submit{
  appearance:none; cursor:pointer;
  background: var(--accent); border:1px solid var(--accent); color:#fff;
  padding: 14px 26px; border-radius:10px;
}
.page-contact .wpcf7 .wpcf7-submit:hover{
  background: color-mix(in srgb, var(--accent) 85%, #000 15%); border-color: color-mix(in srgb, var(--accent) 85%, #000 15%);
}

.submit{
  text-align: center;
}
.page-contact .wpcf7 form p.submit .wpcf7-spinner { display: none; }

/* 戻るボタン */
.page-contact .ct-back{ text-align:center; padding-bottom:40px; }


.fl-cta__box-inner.no-bg {
  background: none !important;
  box-shadow: none !important;
}

.no-ma{
  margin: 0 0 0.2em;
}

/***** CONTACT：見出し下の「画像＋テキスト」行 *****/

/* WPの自動中央寄せ・幅制限をこのセクションだけ無効化 */
.contact-row .is-layout-constrained >
:where(:not(.alignleft):not(.alignright):not(.alignfull)) {
  max-width: none !important;
  margin-inline: 0 !important;
}

/* 行本体：2カラム（中央寄せ） */
.contact-row .contact-content {
    margin-top: 1em;
    display: inline-flex;
    width: auto;
    margin-inline: auto;
    gap: clamp(24px, 2vw, 56px);
}

/* デフォルトのColumns余白を無効化 */
.contact-row .contact-content > .wp-block-column {
  margin: 0 !important;
  padding: 0 !important;
}

/* 画像コンテナ（figure）の幅を“可変”で決める → 画像は中で100% */
.contact-row .wp-block-image.contact-image {
  margin: 0 !important;
  width: clamp(200px, 18vw, 420px); /* 最小～可変～最大：ここで画像の大きさを決める */
}

/* 画像は常にコンテナ幅にフィット（比率保持） */
.contact-row .wp-block-image.contact-image img {
  display: block;
  width: 100% !important;           /* ← ここが肝。コンテナ幅に追従して拡大縮小 */
  height: auto !important;          /* 高さ固定を解除 */
  max-width: 100% !important;
  aspect-ratio: auto !important;    /* 比率固定を解除（過去の指定を無効化） */
  object-fit: initial !important;   /* contain/cover を無効化（レターボックス防止） */
}

/* テキスト側 */
.contact-row .contact-text {
  text-align: left;
  max-width: 520px;                 /* 読みやすい幅に制限（任意） */
}
.co-gap{
  gap:0.3em;
}

.has-sm-font-size {
  background-color: #19A3A3;
  padding: 0.1em 0.8em 0.2em;
  border-radius: 4px;
}

/* 768～900px以下で縦並び */
@media (max-width: 900px) {
  .contact-row .contact-content {
    flex-direction: column;
    max-width: min(92vw, 560px);
    display: block;
  }
  .contact-row .wp-block-image.contact-image,
  .contact-row .contact-text {
    width: 100%;
  }
  .contact-row .wp-block-image.contact-image {
    /* 画像の上限を少し下げるなら調整 */
    width: clamp(220px, 55vw, 420px);
    margin-inline: auto !important;
  }
}

@media (max-width: 768px){
  .fl-cta__box-inner.no-bg {
    margin: 16px 24px 56px;
    padding: 0;
}
.has-sm-font-size{
  padding: 0.1em 0.8em 0.12em;
}

.contact_sp_h2{
  display: flex;
  flex-direction:column ;
}

.contact_sp_h2 .label{
  padding-right: 1.4em;
}

.page-contact .contact_txt_p {
    text-align: left !important;
    width: 98%;
    padding-left: 0.8em;
  }

}


/* レスポンシブ */
@media (min-width:1024px){ .page-contact .ct-hero{ padding-top:96px; } }


/* 追加CSS中央寄せ */
.fl-cta__box-inner-text p{
  white-space: nowrap; 
}

.fl-cta__box-inner-text{
  display: inline-flex;   
  width: auto;
  padding-top: 3em !important;
}

.contact-row{
    display: flex;
    justify-content: center;
}

@media (max-width: 900px) {
  .contact-row .wp-block-image.contact-image img{
    width: 80% !important;
    margin-right: 4rem;
  }

  .contact_catch{      
    display: flex;
    justify-content: center;
  }
}


@media (max-width: 789px) {
    .contact-row .wp-block-image.contact-image img {
        width: 80% !important;
        margin: 0;
    }

    .fl-cta__box-inner-text {
    padding-top: 1em !important;
    padding-left: 1em !important;
  }
}
/* 画像サイズのみ細分化 */
@media (max-width: 550px) {
    .contact-row .wp-block-image.contact-image img {
        width: 100% !important;
        margin-right: 0;
    }
}