@charset "UTF-8";
.mt0 {
  margin-top: 0 !important;
}

.mt8 {
  margin-top: 8px !important;
}

.mt16 {
  margin-top: 16px !important;
}

.mt24 {
  margin-top: 24px !important;
}

.mt32 {
  margin-top: 32px !important;
}

.mt64 {
  margin-top: 64px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mb8 {
  margin-bottom: 8px !important;
}

.mb16 {
  margin-bottom: 16px !important;
}

.mb24 {
  margin-bottom: 24px !important;
}

.mb32 {
  margin-bottom: 32px !important;
}

.mb64 {
  margin-bottom: 64px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.pt0 {
  padding-top: 0 !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.pl32 {
  padding-left: 32px !important;
}

.is_pc {
  display: none;
}
@media print, screen and (min-width: 1024px) {
  .is_pc {
    display: block;
  }
}

.is_sp {
  display: block;
}
@media print, screen and (min-width: 1024px) {
  .is_sp {
    display: none;
  }
}

.bg_white {
  background: #fff !important;
}

.table_rows tbody th {
  background-color: #E1E1E1 !important;
  color: #333 !important;
  width: 30%;
}
@media print, screen and (min-width: 1200px) {
  .table_rows tbody th {
    width: 300px;
  }
}
.table_rows tbody td {
  vertical-align: top;
}
.table_rows tbody td:first-child {
  font-weight: 700;
  background-color: #E1E1E1;
  color: #333 !important;
}
@media print, screen and (min-width: 1200px) {
  .table_rows tbody td:first-child {
    width: 300px;
  }
}
@media print, screen and (max-width: 780px) {
  .table_rows {
    display: block;
  }
  .table_rows tbody {
    display: block;
    width: 100%;
  }
  .table_rows tr {
    display: block;
    width: 100%;
  }
  .table_rows tr:first-child th, .table_rows tr:first-child td {
    border-bottom: 0;
  }
  .table_rows th, .table_rows td {
    display: block;
    width: 100%;
  }
}

.p-contactform {
  max-width: 100%;
}
@media print, screen and (max-width: 780px) {
  .p-contactform {
    padding-left: 0;
  }
}
.p-contactform input[type=text].full, .p-contactform input[type=tel], .p-contactform input[type=email] {
  width: 100%;
  max-width: 100%;
}
.p-contactform input[type=text], .p-contactform input[type=tel], .p-contactform input[type=email] {
  padding: 3px 5px;
  border: 1px solid #CCC;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}
.p-contactform input[type=text]:focus, .p-contactform input[type=tel]:focus, .p-contactform input[type=email]:focus {
  background-color: #EEE;
}
.p-contactform input[type=text].wpcf7-not-valid, .p-contactform input[type=tel].wpcf7-not-valid, .p-contactform input[type=email].wpcf7-not-valid {
  border: 1px solid #E00;
}
.p-contactform textarea {
  width: 100%;
  padding: 3px 5px;
  border: 1px solid #CCC;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}
.p-contactform textarea:focus {
  background-color: #EEE;
}
.p-contactform textarea.wpcf7-not-valid {
  border: 1px solid #E00;
}
.p-contactform select {
  padding: 8px;
  border-color: #CCC;
}
.p-contactform .wpcf7-list-item {
  margin: 0 1em 0 0;
  margin-bottom: 8px !important;
}
@media print, screen and (max-width: 780px) {
  .p-contactform .wpcf7-list-item {
    margin-bottom: 0.8rem;
    display: block !important;
  }
}
.p-contactform span.wpcf7-not-valid-tip {
  margin-top: 2px;
  color: #E00;
}
.p-contactform p {
  margin-bottom: 0;
}
.p-contactform .u-ai_center {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-contactform .u-flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.p-contactform .wpcf7-form-control-wrap input {
  width: 100%;
}
@media print, screen and (max-width: 780px) {
  .p-contactform th {
    width: 100% !important;
  }
}

input::-webkit-input-placeholder {
  color: #999;
}

input::-moz-placeholder {
  color: #999;
}

input:-ms-input-placeholder {
  color: #999;
}

input::-ms-input-placeholder {
  color: #999;
}

input::placeholder {
  color: #999;
}

.p-required_mark::after {
  display: inline-block;
  margin-left: 0.3rem;
  color: #ED1C24;
  content: "*";
}

.wpcf7-submit {
  font-weight: bold;
  margin-left: 72px;
}

.bl_cv_btn .bl_cv_btn_contact {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #E84345;
  color: #ffffff;
  display: block;
  font-size: 20px;
  font-weight: bold;
  margin-top: 4px;
  padding: 10px 50px;
  text-decoration: none;
}
.bl_cv_btn .bl_cv_btn_contact:hover {
  opacity: 0.8; /* 透過率20% */
  -webkit-transition: 0.2s;
  transition: 0.2s; /* 0.2秒アニメーション */
}

.p-contactform .wpcf7-form-control-wrap input {
  width: 100%;
}

@media print, screen and (max-width: 780px) {
  .p-contactform th {
    width: 100% !important;
  }
}

/* h1 - メインタイトル */
body:not(.home) h1.c-entry__title {
  color: var(--accent-color);
  font-weight: 600;
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--accent-color);
}

body:not(.home) .l-container .c-page-header {
  padding-top: 0;
  padding-bottom: 0;
}

body:not(.home) .l-contents__inner {
  margin-top: 1.8em;
}

/* h2 - セクション見出し */
body:not(.home):not(.single-job) h2:not(.p-related-posts__title.c-entry-aside__title):not(.smb-section__title):not(.c-entry-summary__title) {
  color: var(--accent-color);
  font-weight: 600;
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  padding-left: 1rem;
  border-left: 4px solid var(--accent-color);
}

/* h3 - サブセクション見出し */
body:not(.home) h3:not(.c-entry-summary__title) {
  color: #1e275b;
  font-weight: bold;
  margin-bottom: 0.8rem;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid var(--sub-accent-color);
}
@media print, screen and (max-width: 780px) {
  body:not(.home) h3:not(.c-entry-summary__title) {
    font-size: 1rem;
  }
}

/* h4 - 小見出し */
body:not(.home) h4 {
  color: var(--accent-color);
  font-weight: 500;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

/* h5 - 詳細見出し */
body:not(.home) h5 {
  color: var(--sub-accent-color);
  font-weight: 500;
  margin-top: 1.2rem;
  margin-bottom: 0.5rem;
}

/* h6 - 最小見出し */
body:not(.home) h6 {
  color: #666;
  font-weight: 500;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}

.button_arrow .smb-btn {
  /* ボタンの基本的な形状と背景 */
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  /* 角丸を大きく設定 */
  border-radius: 50px;
  /* 横長のサイズを確保するため、最小の幅を設定 */
  min-width: 270px;
  height: 50px;
  /* 画像のグラデーションに似せて設定 */
  background: -webkit-gradient(linear, left top, right top, from(#12449B), to(#2976C1));
  background: -webkit-linear-gradient(left, #12449B, #2976C1);
  background: linear-gradient(to right, #12449B, #2976C1);
  /* テキストスタイル（「採用情報」） */
  color: white;
  font-size: 1rem;
  font-weight: bold;
  text-decoration: none;
  /* 右側のアイコンスペースを確保 */
  /* 影の追加（立体感を出すため） */
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  /* トランジションでホバー時の変化を滑らかに */
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  /* 相対位置指定で、内部のアイコンを絶対配置できるようにする */
  position: relative;
}

.button_arrow-orange .smb-btn {
  background: -webkit-gradient(linear, left top, right top, from(#FF6B35), to(#ff9a35));
  background: -webkit-linear-gradient(left, #FF6B35, #ff9a35);
  background: linear-gradient(to right, #FF6B35, #ff9a35);
}

/* ホバーエフェクト（任意） */
.button_arrow .smb-btn:hover {
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
  -webkit-filter: brightness(1.2);
          filter: brightness(1.2);
}

/* アイコンコンテナ（白い丸）のスタイル */
.button_arrow .smb-btn::after {
  content: ""; /* 疑似要素にはcontentが必要 */
  position: absolute; /* 親要素 .smb-btn 内で絶対配置 */
  right: 10px; /* 右端からの位置調整 */
  width: 30px; /* 白丸の直径 */
  height: 30px; /* 白丸の直径 */
  border-radius: 50%; /* 完全な円形 */
  background-color: white; /* 背景色を白に */
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex; /* 内部の矢印を配置するためにflexを使用 */
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  /* 矢印の影（任意） */
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

/* 矢印（→）のスタイル */
.button_arrow .smb-btn::before {
  content: "";
  background-image: url(../img/icon_arrow_right.svg);
  position: absolute;
  right: 20px;
  top: 20px;
  font-size: 24px;
  font-weight: bold;
  z-index: 2;
  background-size: contain;
  width: 10px;
  height: 10px;
}

.button_white .button_arrow .smb-btn {
  /* ボタンの基本的な形状と背景 */
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  /* 角丸を大きく設定 */
  border-radius: 50px;
  /* 横長のサイズを確保するため、最小の幅を設定 */
  min-width: 270px;
  height: 50px;
  /* 画像のグラデーションに似せて設定 */
  background: #ffffff;
  /* テキストスタイル（「採用情報」） */
  color: #164EA2;
  font-size: 1rem;
  font-weight: bold;
  text-decoration: none;
  /* 右側のアイコンスペースを確保 */
  /* 影の追加（立体感を出すため） */
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  /* トランジションでホバー時の変化を滑らかに */
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  /* 相対位置指定で、内部のアイコンを絶対配置できるようにする */
  position: relative;
}
.button_white {
  /* ホバーエフェクト（任意） */
}
.button_white .button_arrow .smb-btn:hover {
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
  -webkit-filter: brightness(1.2);
          filter: brightness(1.2);
}
.button_white {
  /* アイコンコンテナ（白い丸）のスタイル */
}
.button_white .button_arrow .smb-btn::after {
  content: ""; /* 疑似要素にはcontentが必要 */
  position: absolute; /* 親要素 .smb-btn 内で絶対配置 */
  right: 10px; /* 右端からの位置調整 */
  width: 30px; /* 白丸の直径 */
  height: 30px; /* 白丸の直径 */
  border-radius: 50%; /* 完全な円形 */
  background-color: #164EA2; /* 背景色を白に */
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex; /* 内部の矢印を配置するためにflexを使用 */
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  /* 矢印の影（任意） */
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}
.button_white {
  /* 矢印（→）のスタイル */
}
.button_white .button_arrow .smb-btn::before {
  content: "";
  background-image: url(../img/icon_arrow_right.svg);
  position: absolute;
  right: 20px;
  top: 20px;
  font-size: 24px;
  font-weight: bold;
  z-index: 2;
  background-size: contain;
  width: 10px;
  height: 10px;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}

.button_white-orange .button_arrow .smb-btn .smb-btn__label {
  color: #FF6B35;
}
.button_white-orange .button_arrow .smb-btn::after {
  background-color: #FF6B35; /* 背景色を白に */
}

#page-top {
  bottom: 2rem;
  right: 2rem;
}

.c-page-top {
  background-color: rgba(0, 123, 255, 0.431372549) !important;
  width: 100px;
  height: 100px;
  border-radius: 50px;
}

.svg-inline--fa.fa-chevron-up {
  display: none;
}

.p-page-top {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

p.p-page-top__text {
  font-size: 1rem;
}

.c-meta__item--author, .c-meta__item--modified {
  display: none !important;
}

.u-text_center {
  text-align: center;
}

.wp-block-snow-monkey-blocks-step.smb-step {
  margin-top: 2rem;
}

.smb-media-text > .c-row {
  -webkit-flex-wrap: nowrap;
      -ms-flex-wrap: nowrap;
          flex-wrap: nowrap;
}

@media (min-width: 1024px) {
  .c-entries {
    --entries--item-width: 25%;
  }
}
/* 横いっぱいに広げる */
.l-2row-header .p-global-nav,
.p-header-sub-nav {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
}

/* 中身をコンテナー幅に収める */
.l-2row-header .p-global-nav > *,
.p-header-sub-nav > * {
  margin: 0 auto;
  max-width: 1200px;
  padding-right: 1.8rem;
  padding-left: 1.8rem;
}

.faq .c-entry__title::before {
  content: "Q.";
  font-size: 3rem;
  font-weight: bold;
  font-family: "Arial Black";
  margin-right: 1.6rem;
  color: #349CF7;
}

.faq .c-entry__body::before {
  content: "A.";
  font-size: 3rem;
  font-weight: bold;
  font-family: "Arial Black";
  margin-right: 1.6rem;
  color: #cf2e2e;
}

.c-entry-summary--type-faq .c-entry-summary__title::before {
  content: "Q.";
  font-weight: bold;
  font-size: 2.5rem;
  font-family: "Arial Black";
  margin-right: 1.5rem;
  color: #349CF7;
}

.c-entry-summary__body .c-entry-summary__header .c-entry-summary__title {
  line-height: 2rem;
}

/* ====================================
   施工実績詳細ページスタイル
==================================== */
.p-cases-detail {
  max-width: 1080px;
  margin: 0 auto;
  padding: 40px 20px;
}

/* タイトル */
.p-cases-detail__title {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 30px;
  line-height: 1.4;
  color: #333;
}

/* 画像 */
.p-cases-detail__image {
  margin-bottom: 30px;
  border-radius: 8px;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.p-cases-detail__image img {
  height: auto;
  display: block;
  max-height: 800px;
}

/* カテゴリーラベル */
.p-cases-detail__categories {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 30px;
}

.p-cases-detail__category-label {
  display: inline-block;
  padding: 6px 16px;
  background-color: #007bff;
  color: #fff;
  font-size: 0.875rem;
  border-radius: 8px;
  font-weight: bold;
  text-decoration: none;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}

.p-cases-detail__category-label:hover {
  background-color: #0056b3;
}

/* 詳細情報 */
.p-cases-detail__info {
  background-color: #f8f9fa;
  border-radius: 8px;
  padding: 30px;
  margin-bottom: 30px;
}

.p-cases-detail__info-item {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 20px;
  padding: 15px 0;
  border-bottom: 1px solid #dee2e6;
}

.p-cases-detail__info-item:last-child {
  border-bottom: none;
}

.p-cases-detail__info-label {
  font-weight: bold;
  color: #495057;
  font-size: 0.9375rem;
}

.p-cases-detail__info-value {
  color: #333;
  font-size: 0.9375rem;
}

/* コメント */
h2.p-cases-detail__comment-title {
  margin-top: 0 !important;
}

.p-cases-detail__comment {
  background-color: #fff;
  padding: 30px;
  border-radius: 4px;
  -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
          box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
}

.p-cases-detail__comment-title {
  font-size: 1.25rem;
  font-weight: bold;
  margin-bottom: 15px;
  color: #333;
}

.p-cases-detail__comment-text {
  line-height: 1.8;
  color: #555;
  font-size: 0.9375rem;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .p-cases-detail {
    padding: 20px 15px;
  }
  .p-cases-detail__title {
    font-size: 1.5rem;
    margin-bottom: 20px;
  }
  .p-cases-detail__info {
    padding: 20px;
  }
  .p-cases-detail__info-item {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 12px 0;
  }
  .p-cases-detail__info-label {
    font-size: 0.875rem;
  }
  .p-cases-detail__info-value {
    font-size: 0.875rem;
    padding-left: 10px;
  }
  .p-cases-detail__comment {
    padding: 20px;
  }
  .p-cases-detail__comment-title {
    font-size: 1.125rem;
  }
}
@media (max-width: 480px) {
  .p-cases-detail__title {
    font-size: 1.25rem;
  }
  .p-cases-detail__category-label {
    font-size: 0.8125rem;
    padding: 5px 12px;
  }
}
/* ====================================
   応募フォーム スタイル
==================================== */
.entry form {
  border: 1px solid #ced4da;
  border-radius: 4px;
}

.recruit-form {
  max-width: 800px;
  margin: 0 auto;
  padding: 40px 20px;
}

.recruit-form__field {
  margin-bottom: 30px;
}

.recruit-form__label,
.form__label {
  display: block;
  font-weight: bold;
  font-size: 0.9375rem;
  color: #333;
  margin-bottom: 8px;
}

.form__label .required,
.recruit-form__label .required {
  color: #dc3545;
  margin-left: 4px;
  font-size: 0.875rem;
}

.recruit-form__input,
.recruit-form__select,
.form__select,
.recruit-form__textarea {
  width: 100%;
  padding: 12px 16px;
  font-size: 1rem;
  border: 1px solid #ced4da;
  border-radius: 4px;
  background-color: #fff;
  -webkit-transition: border-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: border-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  transition: border-color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}

.recruit-form__input:focus,
.recruit-form__select:focus,
.form__select:focus,
.recruit-form__textarea:focus {
  outline: none;
  border-color: #007bff;
  -webkit-box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
          box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
}

.recruit-form__select,
.form__select {
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 40px;
}

.recruit-form__textarea {
  min-height: 150px;
  resize: vertical;
  font-family: inherit;
}

.recruit-form__submit {
  text-align: center;
  margin-top: 40px;
}

.recruit-form__button {
  display: inline-block;
  padding: 16px 48px;
  font-size: 1.125rem;
  font-weight: bold;
  color: #fff;
  background-color: #007bff;
  border: none;
  border-radius: 50px;
  cursor: pointer;
  -webkit-transition: background-color 0.3s ease, -webkit-transform 0.2s ease;
  transition: background-color 0.3s ease, -webkit-transform 0.2s ease;
  transition: background-color 0.3s ease, transform 0.2s ease;
  transition: background-color 0.3s ease, transform 0.2s ease, -webkit-transform 0.2s ease;
  -webkit-box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3);
          box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3);
}

.recruit-form__button:hover {
  background-color: #0056b3;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 6px 16px rgba(0, 123, 255, 0.4);
          box-shadow: 0 6px 16px rgba(0, 123, 255, 0.4);
}

.recruit-form__button:active {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/* Contact Form 7 バリデーションエラー */
.wpcf7-not-valid-tip {
  color: #dc3545;
  font-size: 0.875rem;
  margin-top: 4px;
}

span.wpcf7-not-valid {
  border-color: #dc3545 !important;
}

.wpcf7-response-output {
  margin: 20px 0;
  padding: 16px;
  border-radius: 4px;
  font-size: 0.9375rem;
}

.wpcf7-validation-errors {
  background-color: #f8d7da;
  border: 1px solid #f5c6cb;
  color: #721c24;
}

.wpcf7-mail-sent-ok {
  background-color: #d4edda;
  border: 1px solid #c3e6cb;
  color: #155724;
}

/* ====================================
   応募ボタン スタイル（募集職種シングルページ用）
==================================== */
.p-recruit-apply {
  margin-top: 60px;
  padding: 40px 20px;
  text-align: center;
  background: -webkit-linear-gradient(315deg, #f8f9fa 0%, #e9ecef 100%);
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  border-radius: 12px;
}

.p-recruit-apply__button {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
  padding: 18px 40px;
  font-size: 1.125rem;
  font-weight: bold;
  color: #fff;
  background: -webkit-linear-gradient(315deg, #007bff 0%, #0056b3 100%);
  background: linear-gradient(135deg, #007bff 0%, #0056b3 100%);
  text-decoration: none;
  border-radius: 50px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-shadow: 0 4px 15px rgba(0, 123, 255, 0.3);
          box-shadow: 0 4px 15px rgba(0, 123, 255, 0.3);
}

.p-recruit-apply__button:hover {
  -webkit-transform: translateY(-3px);
          transform: translateY(-3px);
  -webkit-box-shadow: 0 6px 20px rgba(0, 123, 255, 0.4);
          box-shadow: 0 6px 20px rgba(0, 123, 255, 0.4);
  background: -webkit-linear-gradient(315deg, #0056b3 0%, #004085 100%);
  background: linear-gradient(135deg, #0056b3 0%, #004085 100%);
  color: #fff;
}

.p-recruit-apply__button:active {
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
}

.p-recruit-apply__button-icon {
  font-size: 1.5rem;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

.p-recruit-apply__button:hover .p-recruit-apply__button-icon {
  -webkit-transform: translateX(4px);
          transform: translateX(4px);
}

/* ====================================
   レスポンシブ対応
==================================== */
@media (max-width: 768px) {
  .recruit-form {
    padding: 30px 15px;
  }
  .recruit-form__field {
    margin-bottom: 24px;
  }
  .recruit-form__button {
    width: 100%;
    padding: 14px 32px;
    font-size: 1rem;
  }
  .p-recruit-apply {
    margin-top: 40px;
    padding: 30px 15px;
  }
  .p-recruit-apply__button {
    width: 100%;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 16px 32px;
    font-size: 1rem;
  }
}
@media (max-width: 480px) {
  .recruit-form__label,
  .form__label {
    font-size: 0.875rem;
  }
  .recruit-form__input,
  .recruit-form__select,
  .form__select,
  .recruit-form__textarea {
    font-size: 0.9375rem;
    padding: 10px 14px;
  }
  .recruit-form__button {
    font-size: 0.9375rem;
  }
  .p-recruit-apply__button {
    font-size: 0.9375rem;
  }
}
/* ====================================
   お問い合わせフォーム スタイル
==================================== */
.otoiawase form {
  border: 1px solid #ced4da;
  border-radius: 4px;
}

.contact-form-wrapper {
  max-width: 800px;
  margin: 0 auto;
  padding: 40px 20px;
}

.form-row {
  margin-bottom: 30px;
}

.form__label {
  display: block;
  font-weight: bold;
  font-size: 0.9375rem;
  color: #333;
  margin-bottom: 8px;
}

.required-badge {
  color: #dc3545;
  margin-left: 4px;
  font-size: 0.875rem;
}

.form-note {
  font-size: 0.875rem;
  color: #666;
  margin-top: 4px;
  margin-bottom: 8px;
}

.form__input,
.form__select,
.form__textarea {
  width: 100%;
  padding: 12px 16px;
  font-size: 1rem;
  border: 1px solid #ced4da;
  border-radius: 4px;
  background-color: #fff;
  -webkit-transition: border-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: border-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  transition: border-color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}

.form__input:focus,
.form__select:focus,
.form__textarea:focus {
  outline: none;
  border-color: #007bff;
  -webkit-box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
          box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
}

.form__select {
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 40px;
}

.form__textarea {
  min-height: 150px;
  resize: vertical;
  font-family: inherit;
}

.privacy-check {
  margin-bottom: 20px;
}

.privacy-check a {
  color: #007bff;
  text-decoration: underline;
}

.privacy-check a:hover {
  color: #0056b3;
}

.submit-btn {
  text-align: center;
  margin-top: 40px;
}

.form__button {
  display: inline-block;
  padding: 16px 48px;
  font-size: 1.125rem;
  font-weight: bold;
  color: #fff;
  background-color: #007bff;
  border: none;
  border-radius: 50px;
  cursor: pointer;
  -webkit-transition: background-color 0.3s ease, -webkit-transform 0.2s ease;
  transition: background-color 0.3s ease, -webkit-transform 0.2s ease;
  transition: background-color 0.3s ease, transform 0.2s ease;
  transition: background-color 0.3s ease, transform 0.2s ease, -webkit-transform 0.2s ease;
  -webkit-box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3);
          box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3);
}

.form__button:hover {
  background-color: #0056b3;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 6px 16px rgba(0, 123, 255, 0.4);
          box-shadow: 0 6px 16px rgba(0, 123, 255, 0.4);
}

.form__button:active {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/* Contact Form 7 バリデーションエラー */
.wpcf7-not-valid-tip {
  color: #dc3545;
  font-size: 0.875rem;
  margin-top: 4px;
}

span.wpcf7-not-valid {
  border-color: #dc3545 !important;
}

.wpcf7-response-output {
  margin: 20px 0;
  padding: 16px;
  border-radius: 4px;
  font-size: 0.9375rem;
}

.wpcf7-validation-errors {
  background-color: #f8d7da;
  border: 1px solid #f5c6cb;
  color: #721c24;
}

.wpcf7-mail-sent-ok {
  background-color: #d4edda;
  border: 1px solid #c3e6cb;
  color: #155724;
}

/* 条件分岐用スタイル */
.wpcf7-form [data-class*=construction-fields] {
  display: none;
}

.wpcf7-form.show-construction-fields [data-class*=construction-fields] {
  display: block;
}

.l-1row-header {
  margin: 0 1rem;
  margin-top: 2rem;
}
@media print, screen and (max-width: 1023px) {
  .l-1row-header {
    margin: 0;
  }
}
.l-1row-header .c-container {
  background-color: #fff;
  border-radius: 50px;
}

.c-section.p-section-front-page-content {
  padding-top: 0;
}

.c-header-content .button_arrow .smb-btn {
  min-width: 160px;
  font-size: 14px;
  padding-right: 2rem;
}

.c-navbar__item .button_arrow .smb-btn {
  min-width: 160px;
  font-size: 14px;
  padding-right: 2rem;
}

.p-global-nav .c-navbar__item > a {
  padding: 10px;
}

@media screen and (max-width: 1110px) {
  .p-global-nav .c-navbar__item > a {
    font-size: 0.8em;
  }
}
p.p_with-shadow {
  text-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5294117647);
}

@media print, screen and (max-width: 1023px) {
  p.p_top_copy {
    font-size: 1.6rem !important;
  }
}
@media print, screen and (max-width: 780px) {
  p.p_top_copy {
    font-size: 1.4rem !important;
  }
}

.section_top_banner .wp-block-image > a {
  display: block;
}

@media screen and (max-width: 781px) {
  .column_top_copy {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  figure.wp-block-image.size-full.img_top_copy {
    max-width: 50%;
    position: absolute;
    bottom: -33%;
    right: 0;
    z-index: -1;
  }
}
.top_section_service .has-border-color:where(:not(img)) {
  padding: 0;
}
.top_section_service .p_with-shadow {
  font-size: clamp(1.2rem, 2vw, 1.5rem) !important;
}

@media print, screen and (max-width: 1023px) {
  .grid_top_service {
    max-width: 100%;
  }
}
.grid_top_service .smb-box__body {
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (max-width: 1023px) {
  .grid_top_service {
    grid-template-columns: repeat(1, 1fr);
  }
}

@media screen and (max-width: 1045px) {
  .columns_top_service-color {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .wp-block-snow-monkey-blocks-box.smb-box.smb-box--has-link {
    max-width: 600px;
    text-align: center;
    margin: auto !important;
    width: 100%;
  }
}
.section_top_news .c-entry-summary__term {
  color: var(--wp--preset--color--sm-accent);
  background-color: var(--wp--preset--color--white);
  border: solid 1px var(--wp--preset--color--sm-accent);
  width: 108px;
  text-align: center;
  padding: 0;
  margin-left: 30px;
}
.section_top_news .c-entries--simple .c-entries__item, .section_top_news .c-entries--text .c-entries__item, .section_top_news .c-entries--text2 .c-entries__item {
  border-bottom: 0;
}
.section_top_news .c-entries--text2 {
  border-top: 0;
}
.section_top_news .wp-block-column:first-child {
  border-right: 1px solid #D3D3D3;
}
@media print, screen and (max-width: 1023px) {
  .section_top_news .wp-block-column:first-child {
    border-right: 0;
  }
}
.section_top_news .c-entry-summary__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 30px;
}
@media print, screen and (max-width: 1023px) {
  .section_top_news .c-entry-summary__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    gap: 0;
  }
}
.section_top_news .c-entries--text2 .c-entry-summary__meta {
  margin-top: 0;
}
.section_top_news time {
  min-width: 74px;
}

.home .c-section {
  padding-bottom: 0;
}

@media print, screen and (max-width: 1023px) {
  .top_section_service .wp-block-snow-monkey-blocks-box {
    width: 100%;
  }
}

.l-footer {
  border-top: 0;
  background-color: var(--wp--preset--color--sm-accent);
}
@media print, screen and (max-width: 780px) {
  .l-footer {
    text-align: center;
  }
}
.l-footer a {
  text-decoration: none;
}
.l-footer p.icon-phone {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4px;
}
.l-footer p.icon-phone::before {
  font-size: 2rem;
}
@media print, screen and (max-width: 780px) {
  .l-footer p.icon-phone {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.l-footer .widget_nav_menu ul {
  color: var(--wp--preset--color--white);
}
.l-footer .footer_menu_heading {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 1rem;
}
.l-footer .c-copyright--inverse {
  background-color: var(--wp--preset--color--sm-accent);
}
.l-footer .l-footer-widget-area__item:has(.footer_text_group) {
  margin-bottom: 15px !important;
}
.l-footer .footer_column_menu {
  gap: 8px;
}
@media print, screen and (max-width: 780px) {
  .l-footer .widget.widget_nav_menu {
    margin-bottom: 1rem;
  }
}

.cases_top h3.c-entry-summary__title {
  color: #ffffff;
}

@media print, screen and (max-width: 780px) {
  .column_footer_info p {
    text-align: center;
  }
}

.recruit .c-entry__header {
  margin-bottom: var(--_margin1);
  display: none;
}
.recruit .p-breadcrumbs-wrapper {
  display: none;
}
.recruit .smb-section__subtitle {
  color: #FF6B35;
}
.recruit .smb-section__title:after {
  background-color: #FF6B35;
  margin-top: 0;
}
.recruit h2.smb-section__title {
  margin-top: 0;
}
@media (min-width: 1024px) {
  .recruit .c-entries {
    --entries--item-width: 25%;
  }
}
.recruit .section_recruit_job h3.c-entry-summary__title {
  color: #ffffff;
}
.recruit .section_recruit_job h2.smb-section__title {
  color: #ffffff;
}
.recruit .section_recruit_job .smb-section__subtitle {
  color: #ffffff;
}
.recruit .section_recruit_job .smb-section__title:after {
  background-color: #ffffff;
}

body.recruit .l-contents__inner {
  margin-top: 0;
}

.section_recruit_interview .wp-block-column {
  position: relative;
}
.section_recruit_interview .smb-box {
  max-width: 200px;
  margin-right: 0 !important;
  margin-top: -40px;
}

/* 施工実績リストのページネーション */
.case_pagination {
  margin-top: 20px;
  text-align: center;
}

.case_pagination ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  gap: 10px;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.case_pagination li a,
.case_pagination li span {
  display: block;
  padding: 8px 12px;
  border: 1px solid #ddd;
  text-decoration: none;
  color: #333;
  border-radius: 4px;
  background-color: #fff;
}

/* 現在のページのスタイル */
.case_pagination li span.current {
  background-color: #001f5b; /* テーブルのヘッダー色に合わせると綺麗です */
  color: #fff;
  border-color: #001f5b;
}

/* ホバー時 */
.case_pagination li a:hover {
  background-color: #f0f0f0;
}

/* ----------------------------------------------------
   施工実績テーブルスタイル (パターンA: コーポレート)
---------------------------------------------------- */
.table_cases_list {
  margin-bottom: 30px;
  -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.05);
          box-shadow: 0 0 10px rgba(0, 0, 0, 0.05); /* うっすら影をつけて浮き上がらせる */
  border-radius: 4px;
  overflow: hidden;
}

.table_cases_list table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px; /* データが多いので少し文字を小さくして一覧性を高める */
  background-color: #fff;
  border-style: hidden; /* デフォルトの二重線を消す */
}

/* ヘッダーデザイン */
.table_cases_list thead th {
  background-color: #001f5b; /* ベースカラー（紺） */
  color: #fff;
  padding: 15px;
  text-align: center;
  font-weight: 600;
  white-space: nowrap; /* 見出しの折り返し禁止 */
  border-bottom: 2px solid #001f5b;
}

/* セルデザイン */
.table_cases_list tbody td {
  padding: 15px;
  border-bottom: 1px solid #e0e0e0; /* 薄いグレーの線 */
  color: #333;
  vertical-align: middle;
}

/* 偶数行の色を変えてストライプにする（読みやすさ向上） */
.table_cases_list tbody tr:nth-child(even) {
  background-color: #f9f9f9;
}

/* マウスホバー時の強調 */
.table_cases_list tbody tr:hover {
  background-color: #eef2f7; /* 薄い青色でハイライト */
  -webkit-transition: background-color 0.2s;
  transition: background-color 0.2s;
}

/* 特定の列の調整（必要に応じて） */
/* 工期と階数、戸数は中央寄せ */
.table_cases_list td:nth-child(1),
.table_cases_list td:nth-child(5),
.table_cases_list td:nth-child(6) {
  text-align: center;
  white-space: nowrap;
}

/* 現場名は少し太字で強調 */
.table_cases_list td:nth-child(2) {
  font-weight: bold;
  color: #001f5b;
}

/* ----------------------------------------------------
   ページネーションのスタイル調整（テーブルに合わせる）
---------------------------------------------------- */
.case_pagination {
  margin-top: 30px;
  text-align: center;
}

.case_pagination ul {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
}

.case_pagination li a,
.case_pagination li span {
  border: 1px solid #ddd;
  padding: 8px 14px;
  border-radius: 2px;
  color: #001f5b;
  font-weight: 500;
}

.case_pagination li span.current {
  background-color: #001f5b;
  color: #fff;
  border-color: #001f5b;
}

.case_pagination li a:hover {
  background-color: #f0f0f0;
}

/* スマホ表示時の横スクロール対応 */
@media screen and (max-width: 768px) {
  .table_scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    display: block;
    width: 100%;
  }
  .table_cases_list table {
    min-width: 600px; /* これ以上縮めない幅を指定 */
  }
  /* スマホでは文字を少し小さく */
  .table_cases_list table th,
  .table_cases_list table td {
    padding: 10px 8px;
    font-size: 13px;
  }
}
.block_data_logo {
  background-color: #ffffff;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}/*# sourceMappingURL=style.css.map */