/*
 * お問い合わせページ専用CSS
 */
/* ======================================
  Contact Page H1 Text Clip
====================================== */

#body_wrap.page-id-25 .l-mainContent__inner > .c-pageTitle {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  width: 100vw;
  max-width: 100vw;
  margin: clamp(6px, 1.8vw, 24px) calc(50% - 50vw) clamp(36px, 5vw, 72px);
  padding: clamp(8px, 2vw, 24px) clamp(24px, 6vw, 96px);
  overflow: hidden;
  color: var(--poscom-deep-navy, #061b3a);
  background: transparent;
  border: 0;
  box-shadow: none;
  text-align: left;
}

#body_wrap.page-id-25 .l-mainContent__inner > .c-pageTitle[data-style="b_bottom"] {
  border-bottom: 0;
}

#body_wrap.page-id-25 .l-mainContent__inner > .c-pageTitle::before {
  content: "CONTACT";
  display: block;
  width: 100%;
  max-width: 100%;
  white-space: nowrap;
  color: transparent;
  background-image:
    linear-gradient(
      90deg,
      rgba(3, 20, 48, 0.08),
      rgba(0, 120, 150, 0.035)
    ),
    url("/wp-content/uploads/2026/05/back-img-07.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: var(--font-en, "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif);
  font-size: clamp(72px, 13.2vw, 230px);
  font-weight: 900;
  line-height: 0.9;
  letter-spacing: -0.045em;
  text-align: left;
  text-transform: uppercase;
  filter: drop-shadow(0 12px 18px rgba(6, 27, 58, 0.08));
}

#body_wrap.page-id-25 .l-mainContent__inner > .c-pageTitle::after {
  content: none;
}

#body_wrap.page-id-25 .c-pageTitle__inner {
  display: inline-block;
  margin-top: clamp(6px, 1.2vw, 16px);
  padding-bottom: 0.18em;
  color: var(--poscom-deep-navy, #061b3a);
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--poscom-deep-navy, #061b3a);
  box-shadow: none;
  font-family: var(--font-sans, "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif);
  font-size: clamp(20px, 1.85vw, 30px);
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.12em;
  text-align: left;
}

#body_wrap.page-id-25 .c-pageTitle__inner::before,
#body_wrap.page-id-25 .c-pageTitle__inner::after {
  content: none;
}

@media (max-width: 960px) {
  #body_wrap.page-id-25 .l-mainContent__inner > .c-pageTitle {
    margin: clamp(4px, 2vw, 18px) calc(50% - 50vw) 54px;
    padding: 14px clamp(18px, 5vw, 42px);
  }

  #body_wrap.page-id-25 .l-mainContent__inner > .c-pageTitle::before {
    font-size: clamp(58px, 15vw, 132px);
    letter-spacing: -0.05em;
  }

  #body_wrap.page-id-25 .c-pageTitle__inner {
    margin-top: 8px;
    font-size: clamp(17px, 2.8vw, 22px);
  }
}

@media (max-width: 600px) {
  #body_wrap.page-id-25 .l-mainContent__inner > .c-pageTitle {
    margin: -16px calc(50% - 50vw) 34px;
    padding: 0 16px 8px;
  }

  #body_wrap.page-id-25 .l-mainContent__inner > .c-pageTitle::before {
    font-size: clamp(42px, 14.2vw, 78px);
    line-height: 0.95;
    letter-spacing: -0.055em;
  }

  #body_wrap.page-id-25 .c-pageTitle__inner {
    margin-top: 4px;
    font-size: clamp(16px, 4.4vw, 19px);
    letter-spacing: 0.1em;
  }

  #body_wrap.page-id-25 .post_content {
    margin-top: 0 !important;
  }

  #body_wrap.page-id-25 .post_content > *:first-child {
    margin-top: 0 !important;
  }
}

/* ======================================
  Contact Page Mobile Content Spacing
  スマホ：CONTACT上の親余白を詰める
====================================== */

@media (max-width: 600px) {
  #body_wrap.page-id-25 #content.l-content {
    padding-top: 0.4em !important;
  }

  #body_wrap.page-id-25 .l-mainContent__inner {
    padding-top: 0.25em !important;
  }
}

@media (min-width: 600px) {
  #body_wrap.page-id-25 .l-content {
    padding-top: 0.25em;
  }
}

/* ======================================
  Contact 3D Frame Object
====================================== */

.contact-3d-object {
  position: relative;
  width: clamp(90px, 9vw, 150px);
  aspect-ratio: 1 / 1;
  pointer-events: none;
  z-index: 1;
}

.contact-3d-object__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter:
    drop-shadow(0 18px 28px rgba(6, 27, 58, 0.16))
    drop-shadow(0 5px 10px rgba(6, 27, 58, 0.10));
  transform-origin: center center;
  will-change: transform, opacity;
}

.contact-3d-object--phone,
.contact-3d-object--mail {
  margin-inline: auto;
}

.contact-page .contact-3d-object,
#body_wrap.page-id-25 .contact-3d-object {
  align-self: center;
}

@media (max-width: 767px) {
  .contact-3d-object {
    width: clamp(84px, 28vw, 130px);
    margin: 0 auto 0.8rem;
  }
}

/* ======================================
  Contact Page H1 Spacing
  H1下の余白を会社概要ページと同じ方向で詰める
====================================== */

/* お問い合わせページのH1下余白 */
#body_wrap.contact-page .l-mainContent__inner > .c-pageTitle {
  margin-bottom: clamp(8px, 1.4vw, 20px) !important;
}

/* 本文エリアの上余白も詰める */
#body_wrap.contact-page .post_content {
  margin-top: clamp(8px, 1.4vw, 20px) !important;
}

/* SWELL側の最初のブロック上マージンを抑える */
#body_wrap.contact-page .post_content > *:first-child {
  margin-top: 0 !important;
}

/* スマホ時 */
@media (max-width: 959px) {
  #body_wrap.contact-page .l-mainContent__inner > .c-pageTitle {
    margin-bottom: 18px !important;
  }

  #body_wrap.contact-page .post_content {
    margin-top: 18px !important;
  }
}

/* ======================================
  Contact Page H1 Spacing
  H1下の余白を詰める
====================================== */

/* contact.css はお問い合わせページだけで読む前提なので、ページID指定なし */
.l-mainContent__inner > .c-pageTitle {
  margin-top: clamp(6px, 1.8vw, 24px) !important;
  margin-right: calc(50% - 50vw) !important;
  margin-bottom: clamp(8px, 1.4vw, 20px) !important;
  margin-left: calc(50% - 50vw) !important;
}

/* 本文側の上余白も詰める */
.post_content {
  margin-top: clamp(8px, 1.4vw, 20px) !important;
}

/* 最初のブロックに余計な上マージンがある場合も消す */
.post_content > *:first-child {
  margin-top: 0 !important;
}

/* SWELLカラムが最初に来る場合の上余白も抑える */
.post_content > .swell-block-columns:first-child,
.post_content > .alignwide:first-child {
  margin-top: 0 !important;
}

/* スマホ */
@media (max-width: 959px) {
  .l-mainContent__inner > .c-pageTitle {
    margin-bottom: 18px !important;
  }

  .post_content {
    margin-top: 18px !important;
  }
}

/* ======================================
  Contact Method Cards
  TEL / Mail 横並びカード
====================================== */

.contact-method-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(20px, 2.2vw, 36px);
  width: min(76vw, 1080px);
  max-width: none;
  margin-top: clamp(32px, 4vw, 56px);
  margin-right: 0;
  margin-left: 50%;
  transform: translateX(-50%);
}

.contact-method-card {
  display: grid;
  grid-template-rows: auto 1fr;
  min-width: 0;
}

.contact-method-card__head {
  display: grid;
  grid-template-columns: clamp(96px, 8.5vw, 150px) minmax(0, 1fr);
  align-items: center;
  gap: clamp(18px, 2.2vw, 34px);
  margin-bottom: clamp(18px, 2vw, 28px);
}

.contact-method-card__title {
  margin: 0 !important;
}

.contact-method-card__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  width: 100%;
  min-height: clamp(150px, 12vw, 190px);
  padding: clamp(24px, 3vw, 38px) clamp(24px, 3vw, 42px);

  background: #061b3a;
  color: #ffffff;
  text-align: center;
}

.contact-method-card__lead {
  margin: 0 0 0.9em !important;
  color: #ffffff;
  font-size: clamp(14px, 1vw, 16px);
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 0.06em;
}

.contact-method-card__main {
  margin: 0 !important;
  color: #ffffff;
  font-family: var(--font-en, "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif);
  font-size: clamp(34px, 3.1vw, 48px);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: 0.08em;
}

.contact-method-card__main--mail {
  font-size: clamp(24px, 2.25vw, 34px);
  letter-spacing: 0.045em;
  white-space: nowrap;
  word-break: normal;
}

.contact-method-card__note {
  margin: 0.75em 0 0 !important;
  color: #ffffff;
  font-size: clamp(13px, 0.95vw, 15px);
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 0.08em;
}

.contact-method-card .contact-3d-object {
  width: clamp(104px, 9.25vw, 160px);
  aspect-ratio: 1 / 1;
  margin-inline: auto;
}


/* ======================================
  Contact Mail Note Spacing
====================================== */

.contact-method-card--mail .contact-method-card__main--mail {
  margin-bottom: clamp(20px, 1.38vw, 28px) !important;
}

.contact-method-card--mail .contact-method-card__note {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  line-height: 1.45;
}

.contact-method-card--mail .contact-method-card__note + .contact-method-card__note {
  margin-top: 0.15em !important;
}


/* ======================================
  Contact Mail Link
  Contact Page / Font Awesome 擬似要素版
====================================== */

.contact-method-card--mail .contact-method-card__mail-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.36em !important;

  color: inherit !important;
  font: inherit !important;
  letter-spacing: inherit !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: inherit !important;

  transition:
    color 0.42s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.52s cubic-bezier(0.16, 1, 0.3, 1);
}

.contact-method-card--mail .contact-method-card__mail-text {
  display: inline-block !important;
  line-height: 1 !important;
}

.contact-method-card--mail .contact-method-card__mail-link::after {
  content: "\f35d" !important;

  display: inline-block !important;
  flex: 0 0 auto !important;

  font-family:
    "Font Awesome 6 Free",
    "Font Awesome 5 Free",
    "FontAwesome" !important;
  font-weight: 900 !important;

  font-size: 0.66em !important;
  line-height: 1 !important;

  color: currentColor !important;
  opacity: 0.95 !important;

  transform: translateY(0em) !important;

  transition:
    opacity 0.42s cubic-bezier(0.16, 1, 0.3, 1);
}

.contact-method-card--mail .contact-method-card__mail-link:hover {
  color: #16c6d3 !important;
  transform: translate(0.16em, -0.1em) !important;
}

.contact-method-card--mail .contact-method-card__mail-link:hover::after {
  opacity: 1 !important;
}


/* ======================================
  Contact Tel Icon
  Contact Page / 指定SVG画像版
====================================== */

.contact-method-card--tel .contact-method-card__main--tel {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.34em !important;

  color: #ffffff !important;
  line-height: 1 !important;
}

.contact-method-card--tel .contact-method-card__tel-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  width: 0.92em !important;
  height: 0.92em !important;
  flex: 0 0 0.92em !important;

  transform: translateY(0.07em) !important;
}

.contact-method-card--tel .contact-method-card__tel-icon img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.contact-method-card--tel .contact-method-card__tel-text {
  display: inline-block !important;
  line-height: 1 !important;
}

/* ======================================
  Contact Tel Link
  電話番号リンクの青文字化を完全に抑止
====================================== */

#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__main--tel {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.34em !important;
  color: #ffffff !important;
  line-height: 1 !important;
}

#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-link,
#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-link:link,
#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-link:visited,
#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-link:hover,
#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-link:focus,
#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-link:active {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.25em !important;

  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  text-decoration: none !important;

  font: inherit !important;
  letter-spacing: inherit !important;
  line-height: 1 !important;
}

#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-link *,
#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-icon,
#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-text {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  text-decoration: none !important;
}

#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  width: 0.92em !important;
  height: 0.92em !important;
  flex: 0 0 0.92em !important;

  transform: translateY(0.07em) !important;
}

#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-icon img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

#body_wrap.page-id-25 .contact-method-card--tel .contact-method-card__tel-text {
  display: inline-block !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

/* ======================================
  SP
====================================== */

@media (max-width: 959px) {
  .contact-method-grid {
    grid-template-columns: 1fr;
    gap: 36px;
    width: min(100%, 760px);
    max-width: calc(100vw - 48px);
    margin-bottom: 56px;
    margin-left: auto;
    margin-right: auto;
    transform: none;
  }

  .contact-method-card {
    width: 100%;
    max-width: 100%;
  }

  .contact-method-card--mail {
    margin-bottom: 0;
  }

  .contact-method-grid + .poscom-contact-fullwide {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  .contact-method-grid + .poscom-contact-fullwide > .swell-block-fullWide__inner {
    padding-top: 0 !important;
  }

  .contact-method-card__head {
    grid-template-columns: clamp(92px, 16vw, 124px) minmax(0, 1fr);
    gap: clamp(16px, 3vw, 24px);
    min-width: 0;
  }

  .contact-method-card__body {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-height: 150px;
    padding: clamp(22px, 3.8vw, 34px) clamp(22px, 4vw, 38px);
  }

  .contact-method-card__main {
    font-size: clamp(28px, 6.4vw, 40px);
    letter-spacing: 0.055em;
  }

  .contact-method-card--tel .contact-method-card__main--tel,
  .contact-method-card--tel .contact-method-card__tel-text {
    white-space: nowrap;
  }

  .contact-method-card__main--mail {
    font-size: clamp(19px, 4.1vw, 29px);
    letter-spacing: 0.03em;
    white-space: nowrap;
    word-break: normal;
    overflow-wrap: normal;
  }

  .contact-method-card--mail .contact-method-card__mail-text {
    white-space: nowrap;
  }

  .contact-method-card__note {
    line-height: 1.6;
    letter-spacing: 0.05em;
    text-align: center;
  }

  .contact-method-card .contact-3d-object {
    width: clamp(92px, 16vw, 132px);
  }

  .contact-method-card--mail .contact-method-card__mail-link {
    gap: 0.28em !important;
  }

  .contact-method-card--mail .contact-method-card__mail-link::after {
    font-size: 0.58em !important;
    transform: translateY(-0.03em) !important;
  }

  .contact-method-card--mail .contact-method-card__mail-link:hover {
    transform: translate(0.1em, -0.06em) !important;
  }

  .contact-method-card--tel .contact-method-card__main--tel {
    gap: 0.28em !important;
  }

  .contact-method-card--tel .contact-method-card__tel-icon {
    width: 0.84em !important;
    height: 0.84em !important;
    flex-basis: 0.84em !important;
    transform: translateY(0.06em) !important;
  }
}

@media (max-width: 600px) {
  #body_wrap.page-id-25 .post_content > .wp-block-group.alignfull.sp_only:has(+ .contact-method-grid) {
    margin-bottom: 8px !important;
  }

  .contact-method-grid {
    gap: 30px;
    width: min(100%, calc(100vw - 28px));
    max-width: calc(100vw - 28px);
    margin-top: 10px;
    margin-bottom: 40px;
  }

  .contact-method-card__head {
    grid-template-columns: clamp(68px, 21vw, 92px) minmax(0, 1fr);
    gap: clamp(12px, 3.8vw, 16px);
    margin-bottom: 16px;
  }

  .contact-method-card__body {
    min-height: 132px;
    padding: 22px 16px;
  }

  .contact-method-card__lead {
    margin-bottom: 0.75em !important;
    font-size: clamp(12px, 3.4vw, 14px);
    line-height: 1.6;
    letter-spacing: 0.04em;
  }

  .contact-method-card__main {
    font-size: clamp(24px, 6.6vw, 32px);
    letter-spacing: 0.04em;
  }

  .contact-method-card__main--mail {
    font-size: clamp(16px, 4.2vw, 22px);
    letter-spacing: 0.015em;
  }

  .contact-method-card__note {
    font-size: clamp(12px, 3.3vw, 14px);
    line-height: 1.55;
    letter-spacing: 0.03em;
  }

  .contact-method-card .contact-3d-object {
    width: clamp(72px, 21vw, 96px);
  }

  .contact-method-card--tel .contact-method-card__main--tel {
    gap: 0.22em !important;
  }

  .contact-method-card--tel .contact-method-card__tel-icon {
    width: 0.78em !important;
    height: 0.78em !important;
    flex-basis: 0.78em !important;
  }
}

@media (max-width: 374px) {
  .contact-method-grid {
    width: min(100%, calc(100vw - 24px));
    max-width: calc(100vw - 24px);
  }

  .contact-method-card__head {
    grid-template-columns: clamp(62px, 20vw, 76px) minmax(0, 1fr);
    gap: 11px;
    margin-bottom: 14px;
  }

  .contact-method-card__body {
    padding: 20px 12px;
  }

  .contact-method-card__lead {
    font-size: 12px;
    letter-spacing: 0.025em;
  }

  .contact-method-card__main {
    letter-spacing: 0.025em;
  }

  .contact-method-card__main--tel {
    font-size: clamp(21px, 6.7vw, 25px);
  }

  .contact-method-card__main--mail {
    font-size: clamp(14.5px, 4.5vw, 16px);
    letter-spacing: 0;
  }

  .contact-method-card__note {
    font-size: 11.5px;
    letter-spacing: 0.015em;
  }

  .contact-method-card .contact-3d-object {
    width: clamp(64px, 20vw, 76px);
  }

  .contact-method-card--mail .contact-method-card__mail-link {
    gap: 0.18em !important;
  }

  .contact-method-card--mail .contact-method-card__mail-link::after {
    font-size: 0.5em !important;
  }
}


/* ======================================
  POS-COM Contact Form Layout
  FullWide + Rich Column 70/30
  ※ここから下は整理済み。上書き用の重複CSSは入れない。
====================================== */

#body_wrap.page-id-25 {
  --pc-navy: #061b3a;
  --pc-blue: #005A9C;
  --pc-blue-dark: #00416F;
  --pc-teal: #00A7A0;
  --pc-red: #c9151b;
  --pc-line: rgba(6, 27, 58, 0.40);
  --pc-line-light: rgba(6, 27, 58, 0.14);
  --pc-bg-blue: rgba(146, 175, 205, 0.77);
}

/* ======================================
  FullWide / Rich Column
====================================== */

#body_wrap.page-id-25 .poscom-contact-fullwide {
  position: relative;
  overflow: hidden;
  background-color: var(--pc-bg-blue) !important;
}

#body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-fullWide__inner {
  width: min(92vw, 1320px) !important;
  max-width: 1320px !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;
  box-sizing: border-box;
}

#body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-columns {
  margin-top: clamp(26px, 3.2vw, 48px) !important;
}

#body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-columns__inner {
  align-items: flex-start !important;
  gap: clamp(24px, 2.6vw, 38px) !important;
}

#body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-column:first-child {
  display: flex;
  flex-direction: column;
  align-items: center;
}

#body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-column:nth-child(2) {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

/* PC：フォーム右カラムの入力フローを固定追従させる */
@media (min-width: 960px) {
  #body_wrap.page-id-25 {
    --pc-contact-sticky-top: 124px;
    --pc-contact-flow-gap: 12px;
  }

  #body_wrap.page-id-25 .poscom-contact-fullwide,
  #body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-fullWide__inner,
  #body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-columns,
  #body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-columns__inner {
    overflow: visible;
  }

  #body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-column:has(.poscom-form-flow) {
    align-self: stretch;
  }

  #body_wrap.page-id-25 .swell-block-column:has(.poscom-form-flow) > .wp-block-group.pc_only {
    position: sticky;
    top: var(--pc-contact-sticky-top);
    align-self: flex-start;
    width: 100%;
    box-sizing: border-box;
    padding-top: var(--pc-contact-flow-gap);
  }

  #body_wrap.page-id-25 .poscom-form-flow {
    margin-top: 0;
  }
}

#body_wrap.page-id-25 .poscom-contact-fullwide .is-style-section_ttl {
  width: 100%;
  max-width: 760px;
  margin: 0 auto clamp(18px, 2vw, 28px) !important;
  color: var(--pc-navy);
  text-align: center;
  line-height: 1.8;
  letter-spacing: 0.045em;
}

#body_wrap.page-id-25 .poscom-contact-fullwide .is-style-section_ttl strong {
  font-weight: 850;
}

/* ======================================
  Contact Form Main
====================================== */

#body_wrap.page-id-25 .poscom-contact-form {
  width: 100%;
  max-width: none;
  margin: 0 auto;
  color: var(--pc-navy);
  font-family: var(--font-sans, "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif);
}

#body_wrap.page-id-25 .poscom-contact-form * {
  box-sizing: border-box;
}

/* CF7が自動で入れるbrは基本消す。補足文のbrだけ後で復活 */
#body_wrap.page-id-25 .poscom-contact-form .poscom-field br {
  display: none !important;
}

#body_wrap.page-id-25 .poscom-contact-form .poscom-field__note br {
  display: block !important;
  content: "" !important;
}

#body_wrap.page-id-25 .poscom-contact-form .wpcf7-form-control-wrap {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ======================================
  Form Section
====================================== */

#body_wrap.page-id-25 .poscom-form-section {
  position: relative;
  margin-top: clamp(16px, 1.8vw, 24px);
  margin-bottom: 30px;
  padding: clamp(18px, 2.1vw, 26px);
  background: #ffffff;
  border: 1px solid var(--pc-line);
  box-shadow: none;
}

#body_wrap.page-id-25 .poscom-form-section--first {
  margin-top: 0;
}

#body_wrap.page-id-25 .poscom-form-section__head {
  margin-bottom: clamp(16px, 1.8vw, 22px);
  padding-bottom: clamp(14px, 1.5vw, 18px);
  border-bottom: 1px solid var(--pc-line-light);
}

#body_wrap.page-id-25 .poscom-form-section__titleline {
  display: flex;
  align-items: center;
  gap: clamp(14px, 1.5vw, 20px);
  margin-bottom: 10px;
}

#body_wrap.page-id-25 .poscom-form-section__step {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 62px;
  height: 38px;
  color: #ffffff;
  background: var(--pc-blue);
  border: 1px solid var(--pc-blue-dark);
  font-family: var(--font-en, "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.14em;
}

#body_wrap.page-id-25 .poscom-form-section__head h3 {
  margin: 0 !important;
  color: var(--pc-navy);
  font-size: clamp(21px, 1.55vw, 27px);
  font-weight: 900;
  line-height: 1.35;
  letter-spacing: 0.035em;
}

#body_wrap.page-id-25 .poscom-form-section__head p {
  margin: 0 !important;
  color: rgba(6, 27, 58, 0.72);
  font-size: clamp(13px, 0.9vw, 15px);
  font-weight: 600;
  line-height: 1.75;
  letter-spacing: 0.035em;
}

/* セクション間の下向き矢印 */
#body_wrap.page-id-25 .poscom-contact-form .poscom-form-section:not(.poscom-form-section--privacy)::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -22px;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 15px solid transparent;
  border-right: 15px solid transparent;
  border-top: 19px solid var(--pc-blue);
  filter: drop-shadow(0 3px 0 rgba(6, 27, 58, 0.08));
  z-index: 2;
}

#body_wrap.page-id-25 .poscom-contact-form .poscom-form-section:not(.poscom-form-section--privacy)::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -25px;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 18px solid transparent;
  border-right: 18px solid transparent;
  border-top: 23px solid rgba(0, 167, 160, 0.22);
  z-index: 1;
}

/* ======================================
  Choice Cards
====================================== */

#body_wrap.page-id-25 .poscom-choice-list .wpcf7-form-control {
  display: grid;
  gap: 10px;
}

@media (min-width: 960px) {
  #body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-form-control {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  #body_wrap.page-id-25 .poscom-choice-list--service .wpcf7-form-control {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

#body_wrap.page-id-25 .poscom-choice-list .wpcf7-list-item {
  display: block;
  margin: 0 !important;
}

#body_wrap.page-id-25 .poscom-choice-list .wpcf7-list-item label {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 52px;
  padding: 10px 12px 10px 42px;
  background: #ffffff;
  border: 1px solid rgba(6, 27, 58, 0.18);
  color: var(--pc-navy);
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    background 0.2s ease,
    color 0.2s ease,
    box-shadow 0.2s ease;
}

#body_wrap.page-id-25 .poscom-choice-list .wpcf7-list-item label:hover {
  border-color: rgba(0, 90, 156, 0.55);
  box-shadow: 0 0 0 2px rgba(0, 90, 156, 0.08);
}

#body_wrap.page-id-25 .poscom-choice-list input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

#body_wrap.page-id-25 .poscom-choice-list .wpcf7-list-item label::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 50%;
  width: 17px;
  height: 17px;
  transform: translateY(-50%);
  background: #ffffff;
  border: 2px solid rgba(6, 27, 58, 0.30);
}

#body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item label::before {
  border-radius: 999px;
}

#body_wrap.page-id-25 .poscom-choice-list--service .wpcf7-list-item label::before {
  border-radius: 3px;
}

#body_wrap.page-id-25 .poscom-choice-list .wpcf7-list-item label:has(input:checked) {
  color: #ffffff;
  background: var(--pc-navy);
  border-color: var(--pc-teal);
  box-shadow: 0 0 0 2px rgba(0, 167, 160, 0.25);
}

#body_wrap.page-id-25 .poscom-choice-list .wpcf7-list-item label:has(input:checked)::before {
  background: #ffffff;
  border-color: var(--pc-teal);
  box-shadow: 0 0 0 3px rgba(0, 167, 160, 0.18);
}

#body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item label:has(input:checked)::after {
  content: "";
  position: absolute;
  left: 22.5px;
  top: 50%;
  width: 7px;
  height: 7px;
  transform: translate(-50%, -50%);
  background: var(--pc-teal);
  border-radius: 999px;
}

#body_wrap.page-id-25 .poscom-choice-list--service .wpcf7-list-item label:has(input:checked)::after {
  content: "✓";
  position: absolute;
  left: 22.5px;
  top: 50%;
  transform: translate(-50%, -55%);
  color: var(--pc-navy);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

#body_wrap.page-id-25 .poscom-choice-list .wpcf7-list-item-label {
  display: block;
  color: currentColor;
  font-size: clamp(14px, 0.92vw, 16px);
  font-weight: 850;
  line-height: 1.45;
  letter-spacing: 0.02em;
}

/* STEP01だけ、長い文言をきれいに改行 */
#body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item-label {
  font-size: 0 !important;
  line-height: 1 !important;
}

#body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item-label::before {
  display: block;
  color: currentColor;
  font-size: clamp(14px, 0.92vw, 16px);
  font-weight: 850;
  line-height: 1.45;
  letter-spacing: 0.02em;
  white-space: pre-line;
}

#body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item:nth-child(1) .wpcf7-list-item-label::before {
  content: "まずは気軽に\Aざっくり相談したい";
}

#body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item:nth-child(2) .wpcf7-list-item-label::before {
  content: "だいたいの\A金額を知りたい";
}

#body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item:nth-child(3) .wpcf7-list-item-label::before {
  content: "詳しく見積りを\A依頼したい";
}

@media (min-width: 960px) {
  #body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item label {
    min-height: 60px;
  }
}

/* ======================================
  Fields
====================================== */

#body_wrap.page-id-25 .poscom-field {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
}

#body_wrap.page-id-25 .poscom-field:last-child {
  margin-bottom: 0 !important;
}

#body_wrap.page-id-25 .poscom-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 18px !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
}

#body_wrap.page-id-25 .poscom-field-grid:last-child {
  margin-bottom: 0 !important;
}

#body_wrap.page-id-25 .poscom-field-grid .poscom-field {
  margin-bottom: 0 !important;
}

/* 04 お客様情報：業種とお名前の間を広げる
   ※業種フィールドと、直後のお名前/フリガナ grid の両方で余白を確保する */
#body_wrap.page-id-25 .poscom-form-section:has(select[name="industry"]) label.poscom-field:has(select[name="industry"]) {
  margin-bottom: clamp(24px, 2.2vw, 36px) !important;
}

#body_wrap.page-id-25 .poscom-form-section:has(select[name="industry"]) label.poscom-field:has(select[name="industry"]) + .poscom-field-grid {
  margin-top: clamp(8px, 1vw, 14px) !important;
}

/* 念のためCF7のwrap側で余白が潰れないようにする */
#body_wrap.page-id-25 .poscom-form-section:has(select[name="industry"]) label.poscom-field:has(select[name="industry"]) .wpcf7-form-control-wrap {
  margin-bottom: 0 !important;
}

/* スマホでは業種とお名前をさらに明確に離す */
@media (max-width: 600px) {
  #body_wrap.page-id-25 .poscom-form-section:has(select[name="industry"]) label.poscom-field:has(select[name="industry"]) {
    margin-bottom: 34px !important;
  }

  #body_wrap.page-id-25 .poscom-form-section:has(select[name="industry"]) label.poscom-field:has(select[name="industry"]) + .poscom-field-grid {
    margin-top: 0 !important;
  }
}

/* 04 お客様情報：住所とその他・補足事項の間を広げる */
#body_wrap.page-id-25 .poscom-form-section:has(#addr) .poscom-field:has(#addr) {
  margin-bottom: clamp(24px, 2.2vw, 36px) !important;
}

/* 住所直後のその他・補足事項ラベルも少し独立して見せる */
#body_wrap.page-id-25 .poscom-form-section:has(#addr) .poscom-field:has(#addr) + .poscom-field {
  margin-top: clamp(8px, 1vw, 14px) !important;
}

/* スマホではさらに余白を明確にする */
@media (max-width: 600px) {
  #body_wrap.page-id-25 .poscom-form-section:has(#addr) .poscom-field:has(#addr) {
    margin-bottom: 34px !important;
  }

  #body_wrap.page-id-25 .poscom-form-section:has(#addr) .poscom-field:has(#addr) + .poscom-field {
    margin-top: 0 !important;
  }
}

#body_wrap.page-id-25 .poscom-field__label {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0.28em 0.66em !important;
  color: var(--pc-navy) !important;
  background: rgba(0, 90, 156, 0.075) !important;
  border-left: 4px solid var(--pc-blue) !important;
  font-size: clamp(14px, 0.92vw, 16px) !important;
  font-weight: 900 !important;
  line-height: 1.35 !important;
  letter-spacing: 0.04em;
}

#body_wrap.page-id-25 .poscom-field__label em {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 0.6em !important;
  padding: 0.22em 0.62em !important;
  color: #ffffff;
  background: var(--pc-red) !important;
  border-left: none !important;
  border-radius: 0;
  font-size: 11px !important;
  font-style: normal;
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: 0.08em;
}

#body_wrap.page-id-25 .poscom-input,
#body_wrap.page-id-25 .poscom-contact-form input[type="text"],
#body_wrap.page-id-25 .poscom-contact-form input[type="email"],
#body_wrap.page-id-25 .poscom-contact-form input[type="tel"],
#body_wrap.page-id-25 .poscom-contact-form input[type="url"],
#body_wrap.page-id-25 .poscom-contact-form input[type="number"],
#body_wrap.page-id-25 .poscom-contact-form select,
#body_wrap.page-id-25 .poscom-contact-form textarea {
  width: 100%;
  min-height: 40px;
  margin-top: 0 !important;
  padding: 8px 12px;
  color: var(--pc-navy);
  background: #ffffff !important;
  border: 1px solid rgba(6, 27, 58, 0.18) !important;
  border-left: 4px solid rgba(0, 90, 156, 0.58) !important;
  border-radius: 0;
  box-shadow: none;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.02em;
}

#body_wrap.page-id-25 .poscom-contact-form textarea {
  min-height: 108px;
  resize: vertical;
}

#body_wrap.page-id-25 .poscom-contact-form input::placeholder,
#body_wrap.page-id-25 .poscom-contact-form textarea::placeholder {
  color: rgba(6, 27, 58, 0.42);
  font-size: 13px;
}

#body_wrap.page-id-25 .poscom-contact-form input:focus,
#body_wrap.page-id-25 .poscom-contact-form select:focus,
#body_wrap.page-id-25 .poscom-contact-form textarea:focus {
  outline: none;
  border-color: var(--pc-blue) !important;
  border-left-color: var(--pc-teal) !important;
  box-shadow: 0 0 0 2px rgba(0, 167, 160, 0.16) !important;
}

#body_wrap.page-id-25 .poscom-field__note {
  display: block;
  margin-top: 0;
  color: rgba(6, 27, 58, 0.64);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.6;
}

/* ======================================
  Detail Boxes
====================================== */

#body_wrap.page-id-25 .poscom-detail-box {
  margin-top: 18px;
  padding: clamp(16px, 1.8vw, 22px);
  background:
    linear-gradient(180deg, rgba(0, 90, 156, 0.035) 0%, #ffffff 78%);
  border: 1px solid rgba(6, 27, 58, 0.16);
  border-top: 3px solid var(--pc-blue);
}

#body_wrap.page-id-25 .poscom-detail-box h4 {
  position: relative;
  margin: 0 0 16px !important;
  padding-left: 1.15em;
  padding-bottom: 0.42em !important;
  color: var(--pc-navy);
  border-bottom: 1px solid rgba(6, 27, 58, 0.10);
  font-size: clamp(18px, 1.25vw, 22px);
  font-weight: 900;
  line-height: 1.4;
  letter-spacing: 0.03em;
}

#body_wrap.page-id-25 .poscom-detail-box h4::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.36em;
  width: 11px;
  height: 11px;
  background: var(--pc-blue);
  clip-path: polygon(0 50%, 100% 0, 100% 100%);
}

#body_wrap.page-id-25 .poscom-detail-box > .poscom-field > .poscom-field__label {
  margin-bottom: 6px !important;
}

/* STEP03：CF7チェックボックス・ラジオ全体
   ※wpcf7-form-control と wpcf7-checkbox/radio は同じ要素に付くため、ここの指定に統一する */
#body_wrap.page-id-25 .poscom-detail-box .wpcf7-form-control.wpcf7-checkbox,
#body_wrap.page-id-25 .poscom-detail-box .wpcf7-form-control.wpcf7-radio {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
  gap: 10px 12px !important;
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-list-item {
  display: inline-flex !important;
  margin: 0 !important;
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-list-item input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-list-item label {
  position: relative;
  display: inline-flex !important;
  align-items: center;
  min-height: 34px;
  padding: 0.5em 0.78em 0.5em 2.35em;
  color: var(--pc-navy, #061b3a);
  background: #ffffff;
  border: 1px solid rgba(6, 27, 58, 0.22);
  box-shadow: 0 1px 0 rgba(6, 27, 58, 0.04);
  cursor: pointer;
}

/* hover時だけ少し分かる程度 */
#body_wrap.page-id-25 .poscom-detail-box .wpcf7-list-item label:hover {
  border-color: rgba(0, 90, 156, 0.42);
  background: rgba(0, 90, 156, 0.025);
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-list-item label::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 50%;
  width: 15px;
  height: 15px;
  transform: translateY(-50%);
  background: #ffffff;
  border: 1.6px solid rgba(6, 27, 58, 0.45);
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-radio .wpcf7-list-item label::before {
  border-radius: 999px;
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-list-item label:has(input:checked) {
  color: #ffffff;
  background: var(--pc-blue, #005A9C);
  border-color: var(--pc-blue, #005A9C);
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-list-item label:has(input:checked)::before {
  background: #ffffff;
  border-color: #ffffff;
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-checkbox .wpcf7-list-item label:has(input:checked)::after,
#body_wrap.page-id-25 .poscom-detail-box .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item label:has(input:checked)::after {
  content: "✓";
  position: absolute;
  left: 19.5px;
  top: 50%;
  transform: translate(-50%, -56%);
  color: var(--pc-blue);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-radio .wpcf7-list-item label:has(input:checked)::after,
#body_wrap.page-id-25 .poscom-detail-box .wpcf7-form-control.wpcf7-radio .wpcf7-list-item label:has(input:checked)::after {
  content: "";
  position: absolute;
  left: 19.5px;
  top: 50%;
  width: 7px;
  height: 7px;
  transform: translate(-50%, -50%);
  background: var(--pc-blue);
  border-radius: 999px;
}

#body_wrap.page-id-25 .poscom-detail-box .wpcf7-list-item-label {
  font-size: 13px;
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: 0.03em;
}

/* ======================================
  Privacy / Acceptance
====================================== */

#body_wrap.page-id-25 .poscom-form-section--privacy {
  border: 2px solid #b9e4d3;
}

#body_wrap.page-id-25 .poscom-form-section--privacy a {
  color: var(--pc-blue);
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 0.22em;
}

/* 05 個人情報同意：付箋ラベルを使わず、必須ピルだけ表示 */
#body_wrap.page-id-25 .poscom-privacy-required {
  display: flex;
  align-items: center;
  gap: 0.65em;
  margin: 0 0 0.6em !important;
  padding: 0 !important;
  color: var(--pc-navy, #061b3a);
  background: transparent !important;
  border: 0 !important;
  font-size: clamp(14px, 0.92vw, 16px);
  font-weight: 900;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

#body_wrap.page-id-25 .poscom-privacy-required em {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.22em 0.62em !important;
  color: #ffffff;
  background: var(--pc-red, #c9151b) !important;
  border: 0 !important;
  border-radius: 0;
  font-size: 11px !important;
  font-style: normal;
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: 0.08em;
}

#body_wrap.page-id-25 .poscom-field--acceptance {
  margin-bottom: 0.7em !important;
}

#body_wrap.page-id-25 .poscom-field--acceptance .wpcf7-list-item {
  margin: 0 !important;
}

#body_wrap.page-id-25 .poscom-field--acceptance label {
  display: inline-flex;
  align-items: center;
  gap: 0.55em;
  color: var(--pc-navy);
  font-size: clamp(13px, 0.9vw, 15px);
  font-weight: 800;
  line-height: 1.7;
  cursor: pointer;
}

#body_wrap.page-id-25 .poscom-field--acceptance input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--pc-blue);
}

/* ======================================
  Submit
====================================== */

#body_wrap.page-id-25 .poscom-submit-area {
  margin-top: clamp(22px, 2.2vw, 32px);
  text-align: center;
}

#body_wrap.page-id-25 .poscom-submit,
#body_wrap.page-id-25 .wpcf7-submit.poscom-submit {
  min-width: min(100%, 260px);
  min-height: 50px;
  padding: 0.85em 2em;
  color: #ffffff;
  background: var(--pc-blue);
  border: 1px solid var(--pc-blue-dark);
  border-radius: 0;
  box-shadow: none;
  font-size: clamp(15px, 0.95vw, 17px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.12em;
  cursor: pointer;
  transition:
    background 0.2s ease,
    transform 0.2s ease;
}

#body_wrap.page-id-25 .poscom-submit:hover,
#body_wrap.page-id-25 .wpcf7-submit.poscom-submit:hover {
  background: var(--pc-blue-dark);
  transform: translateY(-1px);
}

#body_wrap.page-id-25 .wpcf7-spinner {
  display: block;
  margin: 12px auto 0;
}

/* ======================================
  Flow Chart Right Column
====================================== */

#body_wrap.page-id-25 .poscom-form-flow {
  width: 100%;
  max-width: 320px;
  margin-left: auto;
  margin-right: auto;
  padding: clamp(20px, 2vw, 26px);
  color: var(--pc-navy);
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(6, 27, 58, 0.16);
}

#body_wrap.page-id-25 .poscom-form-flow,
#body_wrap.page-id-25 .poscom-form-flow * {
  word-break: normal !important;
  overflow-wrap: normal !important;
  line-break: strict !important;
}

#body_wrap.page-id-25 .poscom-form-flow__label {
  margin: 0 0 0.65em !important;
  color: var(--pc-blue);
  font-family: var(--font-en, "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.18em;
}

#body_wrap.page-id-25 .poscom-form-flow__title {
  margin: 0 0 1.15em !important;
  color: var(--pc-navy);
  font-size: clamp(20px, 1.35vw, 24px);
  font-weight: 900;
  line-height: 1.4;
}

#body_wrap.page-id-25 .poscom-form-flow__list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

#body_wrap.page-id-25 .poscom-form-flow__list li {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 46px minmax(0, 1fr) !important;
  grid-template-areas: "num title" !important;
  column-gap: 14px !important;
  align-items: center !important;
  min-height: 48px !important;
  padding: 0 0 18px !important;
}

#body_wrap.page-id-25 .poscom-form-flow__list li:last-child {
  padding-bottom: 0 !important;
}

#body_wrap.page-id-25 .poscom-form-flow__list li:not(:last-child)::after {
  content: "" !important;
  position: absolute !important;
  left: 23px !important;
  top: 46px !important;
  bottom: 0 !important;
  width: 1px !important;
  background: rgba(6, 27, 58, 0.18) !important;
}

#body_wrap.page-id-25 .poscom-form-flow__list span {
  grid-area: num !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 46px !important;
  height: 46px !important;
  margin: 0 !important;
  color: #ffffff !important;
  background: var(--pc-blue) !important;
  font-family: var(--font-en, "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif);
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: 0.08em !important;
}

#body_wrap.page-id-25 .poscom-form-flow__list strong {
  grid-area: title !important;
  display: flex !important;
  align-items: center !important;
  min-height: 46px !important;
  margin: 0 !important;
  color: var(--pc-navy) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  line-height: 1.45 !important;
  letter-spacing: 0.04em !important;
  white-space: normal !important;
}

#body_wrap.page-id-25 .poscom-form-flow__list em {
  display: none !important;
}

#body_wrap.page-id-25 .poscom-form-flow__note {
  margin: 24px 0 0 !important;
  padding-top: 16px;
  border-top: 1px solid rgba(6, 27, 58, 0.14);
  color: rgba(6, 27, 58, 0.72);
  font-size: 12.5px;
  font-weight: 700;
  line-height: 1.75;
}

/* ======================================
  Flow Chart Right Column / Low Height PC
  低いPCだけ、右側の入力フローを固定のまま縦に収める
====================================== */

@media (min-width: 960px) and (max-height: 780px) {
  #body_wrap.page-id-25 {
    --pc-contact-sticky-top: 124px;
    --pc-contact-flow-gap: 10px;
  }

  #body_wrap.page-id-25 .swell-block-column:has(.poscom-form-flow) > .wp-block-group.pc_only {
    top: var(--pc-contact-sticky-top);
    padding-top: var(--pc-contact-flow-gap);
  }

  #body_wrap.page-id-25 .poscom-form-flow {
    max-width: 300px;
    max-height: calc(100vh - var(--pc-contact-sticky-top) - var(--pc-contact-flow-gap) - 14px);
    overflow: hidden;
    padding: 16px 18px;
  }

  #body_wrap.page-id-25 .poscom-form-flow__label {
    margin-bottom: 0.45em !important;
    font-size: 10px;
    letter-spacing: 0.16em;
  }

  #body_wrap.page-id-25 .poscom-form-flow__title {
    margin-bottom: 0.82em !important;
    font-size: 19px;
    line-height: 1.3;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list li {
    grid-template-columns: 40px minmax(0, 1fr) !important;
    column-gap: 11px !important;
    min-height: 40px !important;
    padding-bottom: 11px !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list li:not(:last-child)::after {
    left: 20px !important;
    top: 40px !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list span {
    width: 40px !important;
    height: 40px !important;
    font-size: 12px !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list strong {
    min-height: 40px !important;
    font-size: 13px !important;
    line-height: 1.38 !important;
    letter-spacing: 0.03em !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__note {
    margin-top: 16px !important;
    padding-top: 12px;
    font-size: 11.5px;
    line-height: 1.62;
  }
}

/* さらに低いPCでは、固定は維持したままもう一段だけ圧縮 */
@media (min-width: 960px) and (max-height: 680px) {
  #body_wrap.page-id-25 {
    --pc-contact-sticky-top: 124px;
    --pc-contact-flow-gap: 8px;
  }

  #body_wrap.page-id-25 .swell-block-column:has(.poscom-form-flow) > .wp-block-group.pc_only {
    top: var(--pc-contact-sticky-top);
    padding-top: var(--pc-contact-flow-gap);
  }

  #body_wrap.page-id-25 .poscom-form-flow {
    max-width: 286px;
    max-height: calc(100vh - var(--pc-contact-sticky-top) - var(--pc-contact-flow-gap) - 12px);
    padding: 14px 16px;
  }

  #body_wrap.page-id-25 .poscom-form-flow__title {
    font-size: 18px;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list li {
    grid-template-columns: 36px minmax(0, 1fr) !important;
    column-gap: 10px !important;
    min-height: 36px !important;
    padding-bottom: 9px !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list li:not(:last-child)::after {
    left: 18px !important;
    top: 36px !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list span {
    width: 36px !important;
    height: 36px !important;
    font-size: 11px !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list strong {
    min-height: 36px !important;
    font-size: 12.5px !important;
    line-height: 1.34 !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__note {
    margin-top: 13px !important;
    padding-top: 10px;
    font-size: 11px;
    line-height: 1.55;
  }
}


/* ======================================
  Validation
====================================== */

#body_wrap.page-id-25 .wpcf7-not-valid-tip {
  margin-top: 0.45em;
  color: var(--pc-red);
  font-size: 12px;
  font-weight: 700;
}

#body_wrap.page-id-25 .wpcf7-response-output {
  margin: 18px 0 0 !important;
  padding: 0.9em 1.05em !important;
  border-radius: 0;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.7;
}

/* ======================================
  Responsive
====================================== */

@media (max-width: 959px) {
  #body_wrap.page-id-25 .poscom-contact-fullwide .swell-block-columns__inner {
    gap: 28px !important;
  }

  #body_wrap.page-id-25 .poscom-contact-form {
    max-width: 760px;
  }

  #body_wrap.page-id-25 .poscom-form-section {
    padding: 22px 16px;
    margin-bottom: 28px;
  }

  #body_wrap.page-id-25 .poscom-form-section__titleline {
    display: block;
  }

  #body_wrap.page-id-25 .poscom-form-section__step {
    width: 68px;
    height: 38px;
    margin-bottom: 14px;
    font-size: 14px;
  }

  #body_wrap.page-id-25 .poscom-form-section__head h3 {
    font-size: clamp(22px, 5.8vw, 30px);
  }

  #body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-form-control,
  #body_wrap.page-id-25 .poscom-choice-list--service .wpcf7-form-control {
    grid-template-columns: 1fr;
  }

  #body_wrap.page-id-25 .poscom-choice-list .wpcf7-list-item label {
    min-height: 58px;
  }

  #body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item-label::before {
    font-size: 16px;
    white-space: normal;
  }

  #body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item:nth-child(2) .wpcf7-list-item-label::before {
    content: "だいたいの金額を知りたい";
  }

  #body_wrap.page-id-25 .poscom-choice-list--type .wpcf7-list-item:nth-child(3) .wpcf7-list-item-label::before {
    content: "詳しく見積りを依頼したい";
  }

  #body_wrap.page-id-25 .poscom-field-grid {
    grid-template-columns: 1fr;
    gap: 16px !important;
  }

  #body_wrap.page-id-25 .poscom-field {
    margin-bottom: 16px !important;
  }

  #body_wrap.page-id-25 .poscom-field__label {
    width: 100% !important;
    padding: 0.42em 0.72em !important;
  }

  #body_wrap.page-id-25 .poscom-contact-form .poscom-form-section:not(.poscom-form-section--privacy)::after {
    bottom: -20px;
    border-left-width: 14px;
    border-right-width: 14px;
    border-top-width: 18px;
  }

  #body_wrap.page-id-25 .poscom-contact-form .poscom-form-section:not(.poscom-form-section--privacy)::before {
    bottom: -23px;
    border-left-width: 17px;
    border-right-width: 17px;
    border-top-width: 21px;
  }

  #body_wrap.page-id-25 .poscom-form-flow {
    position: static;
    max-width: none;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list li {
    grid-template-columns: 48px minmax(0, 1fr) !important;
    column-gap: 16px !important;
    min-height: 56px !important;
    padding-bottom: 22px !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list span {
    width: 48px !important;
    height: 48px !important;
    font-size: 14px !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list strong {
    min-height: 48px !important;
    font-size: 16px !important;
  }

  #body_wrap.page-id-25 .poscom-form-flow__list li:not(:last-child)::after {
    left: 24px !important;
    top: 48px !important;
  }
}

/* ======================================
  Contact Lead Card
  フォーム上の導入文カード
  POS-COMページ調和版
====================================== */

#body_wrap.page-id-25 .poscom-contact-lead-card {
  width: 100%;
  max-width: 860px;
  margin: 0 auto clamp(22px, 2.2vw, 34px) !important;
  padding: clamp(18px, 1.6vw, 24px) 0.6em !important;

  color: var(--pc-navy, #061b3a) !important;
  background:
    -webkit-repeating-linear-gradient(
      -45deg,
      #f7f9fb,
      #f7f9fb 0,
      #f7f9fb 6px,
      #eef2f5 6px,
      #eef2f5 12px
    ) !important;
  background:
    repeating-linear-gradient(
      -45deg,
      #f7f9fb,
      #f7f9fb 0,
      #f7f9fb 6px,
      #eef2f5 6px,
      #eef2f5 12px
    ) !important;

  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  text-align: center !important;
  line-height: 1.9 !important;
  letter-spacing: 0.12em !important;
}

/* SWELL側の枠・背景・角丸を無効化 */
#body_wrap.page-id-25 .poscom-contact-lead-card.has-border,
#body_wrap.page-id-25 .poscom-contact-lead-card.-border01,
#body_wrap.page-id-25 .poscom-contact-lead-card.has-background {
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* 余計な装飾は出さない */
#body_wrap.page-id-25 .poscom-contact-lead-card::before,
#body_wrap.page-id-25 .poscom-contact-lead-card::after {
  content: none !important;
}

#body_wrap.page-id-25 .poscom-contact-lead-card strong {
  font-weight: 900 !important;
}

#body_wrap.page-id-25 .poscom-contact-lead-card .swl-fz {
  font-size: clamp(18px, 1.25vw, 23px) !important;
}

@media (max-width: 959px) {
  #body_wrap.page-id-25 .poscom-contact-lead-card {
    padding: 16px 0.5em !important;
    line-height: 1.75 !important;
  }

  #body_wrap.page-id-25 .poscom-contact-lead-card .swl-fz {
    font-size: 16px !important;
  }
}

#body_wrap.page-id-25 .poscom-contact-lead-card {
  text-shadow:
    0 1px 0 rgba(255, 255, 255, 1),
    0 2px 8px rgba(255, 255, 255, 0.85),
    0 0 1px rgba(6, 27, 58, 0.18) !important;
}

#body_wrap.page-id-25 .poscom-contact-lead-card .swl-fz {
  font-weight: 900 !important;
}

/* 導入文：強調下線 */
#body_wrap.page-id-25 .poscom-lead-underline {
  display: inline;
  background: linear-gradient(
    transparent 62%,
    rgba(0, 167, 160, 0.28) 62%
  );
  padding: 0 0.08em;
}

/* 詳細見積りSTEP03：サービス別項目の下にある資料添付だけ余白を付ける */
#body_wrap.page-id-25 .poscom-field--detail-file {
  margin-top: clamp(18px, 1.8vw, 26px) !important;
}

/* 詳細見積りSTEP03：資料添付をサービス詳細ボックスと左位置をそろえる */
#body_wrap.page-id-25 .poscom-field--detail-file {
  margin-top: clamp(22px, 2vw, 30px) !important;
  padding-left: clamp(16px, 1.8vw, 22px) !important;
  padding-right: clamp(16px, 1.8vw, 22px) !important;
}

@media (max-width: 959px) {
  #body_wrap.page-id-25 .poscom-field--detail-file {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}


/* ======================================
  Contact Form Detail Helpers
  STEP03のみ：2カラム詳細見積り / 数値＋単位 / 工程分離
====================================== */

/* STEP03：入力補足メッセージ */
#body_wrap.page-id-25 .poscom-detail-assist {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin-top: 0.75em !important;
  padding: 0.5em 0.95em !important;

  color: #005A9C !important;
  background: rgba(0, 167, 160, 0.08) !important;
  border: 1px solid rgba(0, 167, 160, 0.22) !important;
  border-left: 5px solid #00A7A0 !important;

  font-size: 14px !important;
  font-weight: 900 !important;
  line-height: 1.55 !important;
  letter-spacing: 0.04em !important;
}

/* STEP03：左＝項目セル、右＝入力エリア
   左列と右列の違いを一目で分かるようにする */
#body_wrap.page-id-25 .poscom-detail-row {
  display: grid;
  grid-template-columns: clamp(205px, 15.5vw, 250px) minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
  padding: 0;
  border-bottom: 1px solid rgba(6, 27, 58, 0.16);
}

#body_wrap.page-id-25 .poscom-detail-row:first-of-type {
  border-top: 1px solid rgba(6, 27, 58, 0.10);
  padding-top: 0;
}

#body_wrap.page-id-25 .poscom-detail-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

/* STEP03：左列セル */
#body_wrap.page-id-25 .poscom-detail-row__label {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 58px;
  margin: 0 !important;
  padding: 0.72em 0.9em 0.72em 1em !important;
  color: var(--pc-navy, #061b3a) !important;
  background: #eaf5ef !important;
  border-left: 5px solid #2f8f75 !important;
  border-right: 1px solid rgba(47, 143, 117, 0.24) !important;
  font-size: clamp(15px, 1vw, 17px) !important;
  font-weight: 950 !important;
  line-height: 1.45 !important;
  letter-spacing: 0.045em;
  white-space: nowrap !important;
}

/* STEP03：左列ラベルを任意で2行表示にする */
#body_wrap.page-id-25 .poscom-detail-row__label.poscom-detail-row__label--stack {
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
  gap: 0.18em !important;
  white-space: normal !important;
}

#body_wrap.page-id-25 .poscom-detail-row__label.poscom-detail-row__label--stack span {
  display: block;
  line-height: 1.35;
  white-space: nowrap;
}

/* STEP03：右列入力エリア */
#body_wrap.page-id-25 .poscom-detail-row__body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  min-height: 58px;
  padding: 0.78em 0 0.78em clamp(18px, 2vw, 28px);
}

/* STEP03：CF7自動brによる余白を消す
   ※青文字補足文の上に空白が出る原因になるため、二度と戻さない */
#body_wrap.page-id-25 .poscom-detail-box br,
#body_wrap.page-id-25 .poscom-detail-row br,
#body_wrap.page-id-25 .poscom-detail-row__body > br {
  display: none !important;
}

/* STEP03：補足文つき行は、青文字の上余白を詰める
   ※二度と広い上余白へ戻さない */
#body_wrap.page-id-25 .poscom-detail-row:has(.poscom-detail-note--above) {
  align-items: stretch !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* STEP03：入力欄上の補足文 */
#body_wrap.page-id-25 .poscom-detail-note {
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0;
  color: rgba(0, 90, 156, 0.86);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.55;
  letter-spacing: 0.03em;
}

#body_wrap.page-id-25 .poscom-detail-note--above {
  margin-top: 0.08em !important;
  margin-bottom: 3px !important;
  padding: 0 !important;
  background: transparent !important;
  border-left: 0 !important;
}

/* STEP03：補足文つき行の右側入力エリア
   青文字が行の上に浮かないよう、上paddingを最小化する */
#body_wrap.page-id-25 .poscom-detail-row:has(.poscom-detail-note--above) .poscom-detail-row__body {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  padding-top: 0.72em !important;
  padding-bottom: 0.72em !important;
  gap: 0 !important;
}

/* 入力欄・チェック群の左端を右列内で揃える */
#body_wrap.page-id-25 .poscom-detail-row__body > .wpcf7-form-control-wrap,
#body_wrap.page-id-25 .poscom-detail-row__body > .poscom-unit-row,
#body_wrap.page-id-25 .poscom-detail-row__body > .poscom-check-block,
#body_wrap.page-id-25 .poscom-detail-row__body > .poscom-other-line {
  width: 100%;
}

/* 補足文直後の入力欄・数値行との距離を詰める */
#body_wrap.page-id-25 .poscom-detail-note--above + .poscom-unit-row,
#body_wrap.page-id-25 .poscom-detail-note--above + .wpcf7-form-control-wrap,
#body_wrap.page-id-25 .poscom-detail-note--above + textarea {
  margin-top: 0 !important;
}

/* 念のため、p自体の上下余白も殺す */
#body_wrap.page-id-25 .poscom-detail-row__body > .poscom-detail-note {
  margin-block-start: 0 !important;
}

/* STEP03：数値＋単位
   CF7のwpcf7-form-control-wrapがblock化して数値行を崩すため、
   unit-row内だけinline-flexに戻す */
#body_wrap.page-id-25 .poscom-unit-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5em 0.7em;
  min-height: 42px;
  margin: 0 !important;
  color: var(--pc-navy, #061b3a);
  font-weight: 700;
  line-height: 1.2;
}

#body_wrap.page-id-25 .poscom-unit-cluster {
  display: inline-flex;
  align-items: center;
  gap: 0.42em;
  min-height: 42px;
  white-space: nowrap;
}

#body_wrap.page-id-25 .poscom-unit-row .wpcf7-form-control-wrap {
  display: inline-flex !important;
  align-items: center !important;
  width: auto !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  flex: 0 0 auto !important;
}

#body_wrap.page-id-25 .poscom-unit-prefix,
#body_wrap.page-id-25 .poscom-unit-suffix,
#body_wrap.page-id-25 .poscom-unit-separator {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  line-height: 1;
  white-space: nowrap;
  font-weight: 700;
}

#body_wrap.page-id-25 .poscom-input--unit {
  width: 7.2em !important;
  max-width: 100%;
  text-align: right;
}

/* 保管面積：横にはみ出さないよう3行構成にする */
#body_wrap.page-id-25 .poscom-unit-row--storage {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.42em;
  width: 100%;
  min-width: 0;
}

#body_wrap.page-id-25 .poscom-unit-row--storage .poscom-unit-cluster {
  display: inline-flex;
  align-items: center;
  gap: 0.42em;
  min-height: 40px;
  white-space: nowrap;
  flex: 0 0 auto;
}

#body_wrap.page-id-25 .poscom-unit-row--storage .poscom-unit-separator {
  display: block;
  min-height: 0;
  margin: -0.1em 0 -0.1em 0.15em;
  color: var(--pc-navy, #061b3a);
  font-weight: 800;
  line-height: 1.3;
  white-space: nowrap;
}

#body_wrap.page-id-25 .poscom-unit-row--storage .poscom-input--unit {
  width: 7.2em !important;
  max-width: 100%;
  text-align: right;
}

/* STEP03だけテキストエリアを低めに */
#body_wrap.page-id-25 .poscom-textarea--compact {
  min-height: 68px !important;
  height: 68px !important;
}

/* 工程：全部と個別を明確に分ける */
#body_wrap.page-id-25 .poscom-check-block {
  display: grid !important;
  gap: 0.95rem !important;
}

#body_wrap.page-id-25 .poscom-check-block__all {
  padding-bottom: 0.95rem !important;
  border-bottom: 1px solid rgba(6, 27, 58, 0.16) !important;
}

#body_wrap.page-id-25 .poscom-check-block__all .wpcf7-list-item label {
  background: rgba(0, 90, 156, 0.06);
  border-color: rgba(0, 90, 156, 0.35);
}

#body_wrap.page-id-25 .poscom-check-block__items {
  display: block !important;
}

#body_wrap.page-id-25 .poscom-check-block__items .wpcf7-form-control.wpcf7-checkbox,
#body_wrap.page-id-25 .poscom-check-block__items .wpcf7-form-control.wpcf7-radio {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
  gap: 10px 12px !important;
}

/* その他：前フォーム風に1行 */
#body_wrap.page-id-25 .poscom-other-line {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 0.75em;
  margin-top: 0.85rem;
}

#body_wrap.page-id-25 .poscom-other-line__label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 0.28em 0.66em;
  color: var(--pc-navy, #061b3a);
  background: rgba(0, 90, 156, 0.075);
  border-left: 4px solid var(--pc-blue, #005A9C);
  font-size: 14px;
  font-weight: 900;
  line-height: 1.35;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

#body_wrap.page-id-25 .poscom-other-line .wpcf7-form-control-wrap {
  width: 100%;
}

/* STEP03：その他入力欄を2行分にする */
#body_wrap.page-id-25 .poscom-other-line--textarea {
  align-items: start;
}

#body_wrap.page-id-25 .poscom-other-line--textarea .wpcf7-form-control-wrap {
  width: 100%;
}

#body_wrap.page-id-25 .poscom-other-textarea {
  min-height: 58px !important;
  height: 58px !important;
  resize: vertical;
  line-height: 1.55 !important;
}

/* 2行textareaのプレースホルダーも読みやすく */
#body_wrap.page-id-25 .poscom-other-textarea::placeholder {
  line-height: 1.55;
}

/* STEP03内の資料添付だけ少し離す */
#body_wrap.page-id-25 .poscom-field--detail-file {
  margin-top: clamp(22px, 2vw, 30px) !important;
}

/* SPでも同じ3行構成を維持 */
@media (max-width: 700px) {
  #body_wrap.page-id-25 .poscom-unit-row--storage {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.38em;
  }

  #body_wrap.page-id-25 .poscom-unit-row--storage .poscom-input--unit {
    width: 6.5em !important;
  }
}

@media (max-width: 959px) {
  #body_wrap.page-id-25 .poscom-detail-row {
    grid-template-columns: 1fr;
    gap: 0;
  }

  #body_wrap.page-id-25 .poscom-detail-row__label {
    min-height: 0;
    padding: 0.5em 0.72em !important;
    white-space: normal !important;
    border-right: 0 !important;
  }

  #body_wrap.page-id-25 .poscom-detail-row__body {
    min-height: 0;
    padding: 0.75em 0 1em 0;
  }

  #body_wrap.page-id-25 .poscom-detail-row:has(.poscom-detail-note--above) .poscom-detail-row__body {
    padding-top: 0.56em !important;
    padding-bottom: 1em !important;
  }

  #body_wrap.page-id-25 .poscom-detail-note--above {
    width: fit-content;
    max-width: 100%;
  }
}

@media (max-width: 600px) {
  #body_wrap.page-id-25 .poscom-detail-assist {
    width: 100%;
    font-size: 13px !important;
  }

  #body_wrap.page-id-25 .poscom-input--unit {
    width: 6.5em !important;
  }

  #body_wrap.page-id-25 .poscom-unit-row {
    gap: 0.45em 0.6em;
  }

  #body_wrap.page-id-25 .poscom-other-line {
    grid-template-columns: 1fr;
    gap: 0.45em;
  }

  #body_wrap.page-id-25 .poscom-other-line--textarea {
    grid-template-columns: 1fr;
    gap: 0.45em;
  }

  #body_wrap.page-id-25 .poscom-other-textarea {
    min-height: 64px !important;
    height: 64px !important;
  }
}



/* ======================================
  Contact Form Flow SP
  スマホ専用：フォーム直前の横スクロール入力フロー
====================================== */

.poscom-form-flow-sp {
  display: none;
}

@media (max-width: 959px) {
  #body_wrap.page-id-25 .poscom-form-flow-sp {
    display: block;
    width: 100%;
    margin: 18px 0 18px;
    padding: 14px 0 12px;
    overflow: hidden;
    border-top: 1px solid rgba(6, 27, 58, 0.1);
    border-bottom: 1px solid rgba(6, 27, 58, 0.1);
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__head {
    display: flex;
    align-items: baseline;
    gap: 0.65em;
    margin: 0 0 10px;
    padding: 0 2px;
    color: #061b3a;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__label {
    color: #0a8fa3;
    font-family: var(--font-en, "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif);
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0.16em;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__title {
    color: #061b3a;
    font-family: var(--font-sans, "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif);
    font-size: 14px;
    font-weight: 800;
    line-height: 1.35;
    letter-spacing: 0.08em;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__list {
    display: flex;
    align-items: stretch;
    gap: 10px;
    margin: 0;
    padding: 0 2px 4px;
    overflow-x: auto;
    overflow-y: hidden;
    list-style: none;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__list::-webkit-scrollbar {
    height: 4px;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__list::-webkit-scrollbar-thumb {
    background: rgba(6, 27, 58, 0.22);
    border-radius: 999px;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__item {
    position: relative;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-width: max-content;
    padding: 9px 13px;
    color: #061b3a;
    background: #f4f9ff;
    border: 1px solid rgba(6, 27, 58, 0.12);
    border-radius: 999px;
    scroll-snap-align: start;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__item:not(:last-child)::after {
    content: "→";
    position: absolute;
    top: 50%;
    right: -12px;
    color: rgba(6, 27, 58, 0.45);
    font-family: var(--font-en, "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif);
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    transform: translateY(-50%);
    pointer-events: none;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__num {
    color: #0a8fa3;
    font-family: var(--font-en, "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif);
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0.08em;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__text {
    color: #061b3a;
    font-family: var(--font-sans, "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif);
    font-size: 13px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0.04em;
    white-space: nowrap;
  }
}

@media (max-width: 374px) {
  #body_wrap.page-id-25 .poscom-form-flow-sp {
    margin-top: 14px;
    margin-bottom: 16px;
    padding-top: 12px;
    padding-bottom: 10px;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__item {
    padding: 8px 11px;
  }

  #body_wrap.page-id-25 .poscom-form-flow-sp__text {
    font-size: 12px;
  }
}


/* ======================================
  POS-COM CTA Badges
  ご提案 / 無料お見積り バッジ共通
====================================== */

#body_wrap .poscom-cta-copy {
  text-align: center !important;
}

#body_wrap .poscom-cta-badge {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;

  height: 1.98em;
  padding: 0 0.38em;

  color: #ffffff !important;
  background: #0b2c5e !important;

  line-height: 1 !important;
  white-space: nowrap !important;
  vertical-align: 0.02em;

  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#body_wrap .poscom-cta-badge__text {
  display: block;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;

  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: 0.035em;
  text-align: center;

  font-feature-settings: "palt" 1;
  transform: translateY(0.055em);
}

/* ご提案：ごの左が広く見えるので左を詰める */
#body_wrap .poscom-cta-badge--proposal {
  padding-left: 0.28em;
  padding-right: 0.44em;
}

/* 無料お見積り：りの右が広く見えるので右を詰める */
#body_wrap .poscom-cta-badge--estimate {
  padding-left: 0.42em;
  padding-right: 0.26em;
}

/* スマホ用：企画 / ご提案 は少しだけ通常寄り */
#body_wrap .poscom-cta-badge--proposal-wide {
  padding-left: 0.42em;
  padding-right: 0.42em;
}

/* PCの / の間隔 */
#body_wrap .poscom-cta-separator {
  display: inline-block;
  margin-inline: 0.28em;
  color: #1f2730;
  line-height: 1;
}

/* PCだけ：「無料お見積り」と「から」の間を少しだけ空ける */
@media (min-width: 601px) {
  #body_wrap .poscom-cta-badge--estimate {
    margin-right: 0.134em !important;
  }
}

/* スマホ */
@media (max-width: 600px) {
  #body_wrap .poscom-cta-badge {
    height: 1.94em;
    padding-right: 0.35em;
    padding-left: 0.35em;
  }

/* スマホ：2つのバッジ間隔を調整 */
#body_wrap .poscom-cta-copy--sp > strong {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 1em !important;
}

/* HTML内の全角スペースを無効化 */
#body_wrap .poscom-cta-copy--sp > strong > .swl-fz.u-fz-l {
  display: none !important;
}

  #body_wrap .poscom-cta-badge__text {
    letter-spacing: 0.025em;
    transform: translateY(0.05em);
  }

  #body_wrap .poscom-cta-badge--estimate {
    padding-left: 0.38em;
    padding-right: 0.24em;
  }

  #body_wrap .poscom-cta-badge--proposal-wide {
    padding-left: 0.36em;
    padding-right: 0.36em;
  }
}


/* ======================================
  Contact Spam Note
  スパムメール注意文
====================================== */

#body_wrap .poscom-spam-note {
  box-sizing: border-box;
  width: min(100%, 960px);
  margin-inline: auto !important;
  margin-bottom: clamp(44px, 5vw, 72px) !important;
  padding: clamp(22px, 3vw, 34px) clamp(20px, 4vw, 48px);

  color: #061b3a;
  background:
    repeating-linear-gradient(
      -45deg,
      rgba(22, 198, 211, 0.045) 0,
      rgba(22, 198, 211, 0.045) 8px,
      rgba(255, 255, 255, 0.82) 8px,
      rgba(255, 255, 255, 0.82) 16px
    );

  font-size: clamp(15px, 1.35vw, 22px);
  font-weight: 600;
  line-height: 1.95;
  letter-spacing: 0.08em;
  text-align: center;
}

#body_wrap .poscom-spam-note strong {
  font-weight: 900;
}

/* スマホ：文字を小さく、行間を詰め、下余白を広げる */
@media (max-width: 600px) {
  #body_wrap .poscom-spam-note {
    width: min(100%, calc(100vw - 52px));
    margin-top: 0px !important;
    margin-bottom: 40px !important;
    padding: 22px 20px 24px !important;

    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.62 !important;
    letter-spacing: 0.035em !important;
    text-align: left !important;
  }

  #body_wrap .poscom-spam-note strong {
    font-size: 1em !important;
    font-weight: 900 !important;
    line-height: inherit !important;
  }
}


/* ======================================
  Contact Form Bottom Spacing / SP
  #contact-form直指定：送信ボタン下の余白調整
====================================== */

@media (max-width: 959px) {
  /* フォームブロック全体の下余白を詰める */
  #body_wrap.page-id-25 #contact-form.swell-block-fullWide {
    padding-bottom: 0 !important;
  }

  #body_wrap.page-id-25 #contact-form > .swell-block-fullWide__inner {
    padding-bottom: 0 !important;
  }

  /* SWELLカラムの行間を詰める */
  #body_wrap.page-id-25 #contact-form .swell-block-columns {
    margin-bottom: 0 !important;
  }

  #body_wrap.page-id-25 #contact-form .swell-block-columns__inner {
    row-gap: 12px !important;
    gap: 12px !important;
  }

  /* PC用の右カラムはスマホでは完全に消す。0%幅だけでは隙間が残る可能性がある */
  #body_wrap.page-id-25 #contact-form .swell-block-column:nth-child(2) {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* フォームが入っている1列目の下余白を消す */
  #body_wrap.page-id-25 #contact-form .swell-block-column:nth-child(1) {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  #body_wrap.page-id-25 #contact-form .wp-block-contact-form-7-contact-form-selector,
  #body_wrap.page-id-25 #contact-form .wpcf7,
  #body_wrap.page-id-25 #contact-form .wpcf7-form,
  #body_wrap.page-id-25 #contact-form .poscom-contact-form,
  #body_wrap.page-id-25 #contact-form .poscom-submit-area {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  /* 送信ボタン直下のスピナー余白も最小化 */
  #body_wrap.page-id-25 #contact-form .wpcf7-spinner {
    margin-top: 6px !important;
    margin-bottom: 0 !important;
  }

  /* スパム注意文が入っている3列目を上に寄せる */
  #body_wrap.page-id-25 #contact-form .swell-block-column:nth-child(3) {
    margin-top: 8px !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
  }

  #body_wrap.page-id-25 #contact-form .swell-block-column:nth-child(3) > .wp-block-group {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  #body_wrap.page-id-25 #contact-form .poscom-spam-note {
    margin-top: 0 !important;
  }
}

/* ======================================
  Contact File Upload SP Fix
  スマホ：資料添付のファイル選択欄だけ外枠内に収める
====================================== */

@media (max-width: 600px) {
  #body_wrap.page-id-25 .poscom-contact-form input[type="file"],
  #body_wrap.page-id-25 .poscom-contact-form .wpcf7-file {
    display: block !important;
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    padding: 8px 10px !important;
    font-size: 13px !important;
    line-height: 1.4 !important;
    white-space: nowrap !important;
  }

  #body_wrap.page-id-25 .poscom-contact-form .wpcf7-form-control-wrap:has(input[type="file"]) {
    display: block !important;
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  #body_wrap.page-id-25 .poscom-contact-form .poscom-field:has(input[type="file"]) {
    min-width: 0 !important;
    overflow: hidden !important;
  }

  #body_wrap.page-id-25 .poscom-contact-form input[type="file"]::file-selector-button {
    max-width: 46%;
    margin-right: 8px;
    padding: 0.42em 0.72em;
    font-size: 13px;
    line-height: 1.3;
    white-space: nowrap;
  }
}
