/*
 * お知らせ一覧ページ専用CSS
 */

/* ======================================
  News Page H1 Text Clip
====================================== */

#body_wrap.page-id-31 .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-31 .l-mainContent__inner > .c-pageTitle[data-style="b_bottom"] {
  border-bottom: 0;
}

#body_wrap.page-id-31 .l-mainContent__inner > .c-pageTitle::before {
  content: "NEWS";
  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-02.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-31 .l-mainContent__inner > .c-pageTitle::after {
  content: none;
}

#body_wrap.page-id-31 .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-31 .c-pageTitle__inner::before,
#body_wrap.page-id-31 .c-pageTitle__inner::after {
  content: none;
}

/* ======================================
  News Page H1 Responsive
====================================== */

@media (max-width: 960px) {
  #body_wrap.page-id-31 .l-mainContent__inner > .c-pageTitle {
    margin: clamp(4px, 2vw, 18px) calc(50% - 50vw) 54px;
    padding: 14px clamp(18px, 5vw, 42px);
  }

  #body_wrap.page-id-31 .l-mainContent__inner > .c-pageTitle::before {
    font-size: clamp(58px, 15vw, 132px);
    letter-spacing: -0.05em;
  }

  #body_wrap.page-id-31 .c-pageTitle__inner {
    margin-top: 8px;
    font-size: clamp(17px, 2.8vw, 22px);
  }
}

@media (max-width: 600px) {
  #body_wrap.page-id-31 .l-mainContent__inner > .c-pageTitle {
    margin: 4px calc(50% - 50vw) 42px;
    padding: 12px 16px;
  }

  #body_wrap.page-id-31 .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-31 .c-pageTitle__inner {
    margin-top: 10px;
    font-size: clamp(16px, 4.4vw, 19px);
    letter-spacing: 0.1em;
  }
}

@media (min-width: 600px) {
  #body_wrap.page-id-31 .l-content {
    padding-top: 0.5em;
  }
}

/* ======================================
  News Page H1 Bottom Space
  H1下の余白を会社概要ページと同じ思想で詰める
====================================== */

/* PC：H1下の余白を詰める */
#body_wrap.page-id-31 .l-mainContent__inner > .c-pageTitle {
  margin: clamp(6px, 1.8vw, 24px) calc(50% - 50vw) clamp(8px, 1.4vw, 20px);
}

/* 本文エリアの上余白も詰める */
#body_wrap.page-id-31 .post_content {
  margin-top: clamp(8px, 1.4vw, 20px) !important;
}

/* H1直下にフルワイドを置く場合、その上余白を消す */
#body_wrap.page-id-31 .post_content > .swell-block-fullWide:first-child {
  margin-top: 0 !important;
}

/* タブレット */
@media (max-width: 960px) {
  #body_wrap.page-id-31 .l-mainContent__inner > .c-pageTitle {
    margin: clamp(4px, 2vw, 18px) calc(50% - 50vw) 20px;
  }

  #body_wrap.page-id-31 .post_content {
    margin-top: 20px !important;
  }
}

/* スマホ */
@media (max-width: 600px) {
  #body_wrap.page-id-31 .l-mainContent__inner > .c-pageTitle {
    margin: 4px calc(50% - 50vw) 18px;
  }

  #body_wrap.page-id-31 .post_content {
    margin-top: 18px !important;
  }
}

/* ======================================
  POS-COM News Tabs
  お知らせ一覧 タブブロック
====================================== */

/* タブ全体 */
#body_wrap.page-id-31 .post_content .poscom-news-tabs .c-tabList {
  display: flex;
  align-items: center;
  gap: 6px !important;
  margin-bottom: 0.88rem !important;
}

/* タブボタン共通：非アクティブ */
#body_wrap.page-id-31 .post_content .poscom-news-tabs .c-tabList__button {
  background-color: #eaf4f7 !important;
  color: #1a1d20 !important;
  font-weight: 800 !important;
  letter-spacing: 0.09em;
  border: 1px solid rgba(6, 27, 58, 0.3);
  border-radius: 8px 0 8px 0;
  transition:
    background-color 0.28s ease,
    color 0.28s ease,
    border-color 0.28s ease,
    box-shadow 0.28s ease,
    transform 0.28s ease;
}

/* 非アクティブ hover / アクティブ */
#body_wrap.page-id-31 .post_content .poscom-news-tabs .c-tabList__button:hover,
#body_wrap.page-id-31 .post_content .poscom-news-tabs .c-tabList__button[aria-selected="true"] {
  background-color: #061b3a !important;
  color: #ffffff !important;
  border-color: #061b3a !important;
  box-shadow: 0 8px 18px rgba(6, 27, 58, 0.3);
}

/* アクティブだけ少し押し出す */
#body_wrap.page-id-31 .post_content .poscom-news-tabs .c-tabList__button[aria-selected="true"] {
  transform: translateY(-2px);
}

/* タブ本文枠 */
#body_wrap.page-id-31 .post_content .poscom-news-tabs .c-tabBody {
  border: 1.4px solid #061b3a;
  border-radius: 8px 0 8px 0;
  background: #ffffff;
}

/* ======================================
  News Tabs Responsive
====================================== */

@media (max-width: 767px) {
  #body_wrap.page-id-31 .post_content .poscom-news-tabs .c-tabList {
    gap: 5px !important;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  #body_wrap.page-id-31 .post_content .poscom-news-tabs .c-tabList__button {
    font-size: 13px;
    letter-spacing: 0.06em;
    white-space: nowrap;
  }
}

/* ======================================
  News Page Side Accordion
  アーカイブ・カテゴリー
====================================== */

/* アコーディオン見出し */
#body_wrap.page-id-31 .post_content .swell-block-accordion__title {
  background-color: #f1f4f5;
  border: none;
  padding: 1.05rem 1.25rem;
}

/* 「アーカイブ」「カテゴリー」の文字 */
#body_wrap.page-id-31 .post_content .swell-block-accordion__label {
  color: #4a5560;
  font-size: 17px;
  font-weight: 600;
  letter-spacing: 0.08em;
}

/* プラス・マイナスアイコン */
#body_wrap.page-id-31 .post_content .swell-block-accordion__icon {
  color: #4a5560;
  font-weight: 700;
}

/* アコーディオン本文 */
#body_wrap.page-id-31 .post_content .swell-block-accordion__body {
  padding: 1.1rem 1.25rem 1.25rem;
  background-color: #ffffff;
}

/* アーカイブ・カテゴリー内のリスト文字 */
#body_wrap.page-id-31 .post_content .swell-block-accordion__body li,
#body_wrap.page-id-31 .post_content .swell-block-accordion__body a {
  color: #4f5b66;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.8;
}

/* ホバー */
#body_wrap.page-id-31 .post_content .swell-block-accordion__body a:hover {
  color: #061b3a;
  text-decoration: none;
}

/* カテゴリーのフォルダアイコンを非表示 */
#body_wrap.page-id-31 .post_content .wp-block-categories li::before,
#body_wrap.page-id-31 .post_content .wp-block-categories-list li::before,
#body_wrap.page-id-31 .post_content .cat-item::before {
  content: none !important;
  display: none !important;
}

/* もしSWELL側やテーマ側でアイコンフォントが入っている場合も消す */
#body_wrap.page-id-31 .post_content .wp-block-categories .icon-folder,
#body_wrap.page-id-31 .post_content .wp-block-categories-list .icon-folder,
#body_wrap.page-id-31 .post_content .cat-item .icon-folder {
  display: none !important;
}

/* カテゴリーリストの左余白を調整 */
#body_wrap.page-id-31 .post_content .wp-block-categories,
#body_wrap.page-id-31 .post_content .wp-block-categories-list {
  padding-left: 0;
  margin-left: 0;
  list-style: none;
}

/* カテゴリー項目 */
#body_wrap.page-id-31 .post_content .wp-block-categories li,
#body_wrap.page-id-31 .post_content .wp-block-categories-list li,
#body_wrap.page-id-31 .post_content .cat-item {
  list-style: none;
  padding-left: 0;
  margin: 0.35rem 0;
}

/* ======================================
  News Page Side Category Icon Remove
  右側アコーディオン内のカテゴリーアイコンだけ非表示
====================================== */

#body_wrap.page-id-31 .post_content .swell-block-accordion .wp-block-categories-list > li > a::before,
#body_wrap.page-id-31 .post_content .swell-block-accordion .widget_categories > ul > .cat-item > a::before {
  content: "" !important;
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

/* アイコン分の左余白を詰める */
#body_wrap.page-id-31 .post_content .swell-block-accordion .wp-block-categories-list > li > a,
#body_wrap.page-id-31 .post_content .swell-block-accordion .widget_categories > ul > .cat-item > a {
  padding-left: 0 !important;
}

/* SWELL側のリストメニュー指定が絡む場合もここだけで消す */
#body_wrap.page-id-31 .post_content .swell-block-accordion .c-listMenu a::before {
  content: "" !important;
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

#body_wrap.page-id-31 .post_content .swell-block-accordion .c-listMenu a {
  padding-left: 0 !important;
}


/* ======================================
  Single Post Body Typography
  投稿本文：スマホ時の読みやすさ調整
====================================== */

@media (max-width: 600px) {
  #body_wrap:not(.page-id-31) .l-mainContent .post_content {
    margin-top: 16px !important;
    padding-top: 0 !important;
  }

  #body_wrap:not(.page-id-31) .l-mainContent .post_content > p:first-child {
    margin-top: 0 !important;
  }

  #body_wrap:not(.page-id-31) .l-mainContent p {
    font-size: 14px !important;
    line-height: 1.62 !important;
    letter-spacing: 0.02em;
  }

  #body_wrap:not(.page-id-31) .l-mainContent ul,
  #body_wrap:not(.page-id-31) .l-mainContent ol {
    font-size: 14px !important;
    line-height: 1.58 !important;
    letter-spacing: 0.018em;
  }

  #body_wrap:not(.page-id-31) .l-mainContent li {
    font-size: 14px !important;
    line-height: 1.55 !important;
  }

  #body_wrap:not(.page-id-31) .l-mainContent p + p {
    margin-top: 1em !important;
  }

  #body_wrap:not(.page-id-31) .l-mainContent .swl-fz.u-fz-l {
    font-size: 1em !important;
  }

  #body_wrap:not(.page-id-31) .l-mainContent .swl-fz.u-fz-xl {
    font-size: 1.04em !important;
  }
}


/* ====================================== News Page Link Button Responsive タブ内「一覧」ボタンのスマホ調整 ====================================== */ /* PC〜タブレット共通：タブ内ボタンの基本整形 */ #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn { display: flex; justify-content: center; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link { display: inline-flex; align-items: center; justify-content: center; gap: 0.55em; min-width: 0; text-decoration: none !important; line-height: 1.25; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link img { flex: 0 0 auto; width: 16px !important; height: 16px !important; object-fit: contain; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link .swl-inline-icon { flex: 0 0 auto; margin-left: 0.08em !important; transform: translateY(0.5px); } /* タブレット：少しだけ締める */ @media (max-width: 960px) { #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-buttons { justify-content: center !important; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link { width: min(280px, 72vw); padding: 11px 20px !important; font-size: 14.5px !important; gap: 0.48em; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link img { width: 14px !important; height: 14px !important; } } /* スマホ：トップページのボタンと同じ思想で小さく */ @media (max-width: 600px) { #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-buttons { justify-content: center !important; margin-left: 0 !important; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn { width: 100%; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link { width: min(260px, 72vw) !important; min-width: 0 !important; padding: 10px 18px !important; gap: 0.45em !important; font-size: 14px !important; line-height: 1.2 !important; white-space: nowrap; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link img { width: 14px !important; height: 14px !important; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link .swl-inline-icon { margin-left: 0.08em !important; transform: translateY(0.5px) !important; } } /* 320px安全弁 */ @media (max-width: 374px) { #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link { width: min(238px, 76vw) !important; padding: 9px 15px !important; font-size: 13.2px !important; gap: 0.36em !important; } #body_wrap.page-id-31 .post_content .poscom-news-tabs .wp-block-button.poscom-news-link-btn .wp-block-button__link img { width: 13px !important; height: 13px !important; } }