@charset "utf-8";
/* =========================================================================
   Custom Styles
   =========================================================================

   【構成】
   1. 共通・PC版スタイル
   2. SP版スタイル（@media max-width: 768px）

   ========================================================================= */


/* *************************************************************************

   ██████╗  ██████╗    ██╗     ██████╗ ██████╗ ███╗   ███╗███╗   ███╗ ██████╗ ███╗   ██╗
   ██╔══██╗██╔════╝   ██╔╝    ██╔════╝██╔═══██╗████╗ ████║████╗ ████║██╔═══██╗████╗  ██║
   ██████╔╝██║       ██╔╝     ██║     ██║   ██║██╔████╔██║██╔████╔██║██║   ██║██╔██╗ ██║
   ██╔═══╝ ██║      ██╔╝      ██║     ██║   ██║██║╚██╔╝██║██║╚██╔╝██║██║   ██║██║╚██╗██║
   ██║     ╚██████╗██╔╝       ╚██████╗╚██████╔╝██║ ╚═╝ ██║██║ ╚═╝ ██║╚██████╔╝██║ ╚████║
   ╚═╝      ╚═════╝╚═╝         ╚═════╝ ╚═════╝ ╚═╝     ╚═╝╚═╝     ╚═╝ ╚═════╝ ╚═╝  ╚═══╝

   PC版 / 共通スタイル

   ************************************************************************* */


/* ===============================================
   Header
   =============================================== */

#headContents {
  width: 97%;
}

/* Header Menu Underline Fixes */
@media screen and (min-width: 769px) {
  /* Divisions: アンダーラインを:beforeで実装（:afterは▼に使用しているため） */
  #globalNavi ul#naviList li#divisions > a:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0%;
    height: 2px;
    background: #fff;
    opacity: 0;
    transition: 0.2s all;
  }

  #globalNavi ul#naviList li#divisions > a:hover:before {
    width: calc(100% - 0px);
    opacity: 1;
  }

  /* Divisions: 元の:afterアンダーラインを無効化 */
  #globalNavi ul#naviList li#divisions > a:after {
    left: auto;
    bottom: auto;
    width: auto;
    height: auto;
    background: none;
    opacity: 1;
  }

  /* General Store: アンダーライン完全無効化 */
  #globalNavi ul#naviList li#store a:before,
  #globalNavi ul#naviList li#store a:after {
    content: none !important;
    display: none !important;
  }

  /* Dropdown内のli: アンダーライン無効化 */
  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li a:before,
  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li a:after {
    content: none !important;
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    background: none !important;
  }
}

/* ===============================================
   Dropdown Menu Styles (PC)
   =============================================== */

@media screen and (min-width: 769px) {
  #globalNavi ul#naviList li.has-dropdown {
    position: relative;
  }

  #globalNavi ul#naviList li.has-dropdown > a:after {
    content: "▼";
    font-size: 8px;
    margin-left: 6px;
    vertical-align: middle;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    min-width: 220px;
    background: rgba(0, 0, 0, 0.95);
    padding: 15px 0;
    margin-top: 10px;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    z-index: 999;
    list-style: none;
  }

  #globalNavi ul#naviList li.has-dropdown:hover .dropdown-menu {
    opacity: 1;
    visibility: visible;
    margin-top: 5px;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li {
    margin: 0;
    padding: 0;
    width: 100%;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li a {
    display: block;
    padding: 12px 20px;
    color: #fff;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.2s ease;
    white-space: nowrap;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li a:after {
    content: none;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li a:hover {
    background: rgba(255, 255, 255, 0.1);
    padding-left: 25px;
  }
}


/* ===============================================
   PC/SP表示切り替え
   =============================================== */

.sp {
  display: none;
}

.pc {
  display: inline;
}


/* ===============================================
   2 Column Thumb List (Top Page Menu)
   =============================================== */

ul.thumb_list_2col {
  list-style-type: none;
  width: 100%;
  height: auto;
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
}

ul.thumb_list_2col li {
  width: 48.5%;
  height: auto;
  margin: 0 3% 4% 0;
}

ul.thumb_list_2col li:nth-of-type(2n) {
  margin-right: 0;
}


/* ===============================================
   Top Page - First View Swiper
   =============================================== */

#firstview .swiper-slide {
  height: 40vw !important;
}

#firstview .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ===============================================
   Division Pages - Swiper
   =============================================== */

.machine-slide {
  position: relative !important;
  overflow: hidden !important;
}

dl.division_container {
  max-width: none !important;
}

.machine-slide .swiper-slide img {
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  display: block !important;
}

.machine-slide .swiper-pagination {
  bottom: 30px !important;
}

ul#storeList li {
  width: 40% !important;
}

/* Division Pages - Overview List（ぶら下げインデント） */
.overview_list li {
  padding-left: 1em;
  text-indent: -1em;
}


/* ===============================================
   システム開発セクション
   =============================================== */

.biz_system_section {
  width: 90%;
  max-width: 980px;
  margin: 0 auto 90px;
  display: block;
}

.biz_system_content {
  margin-bottom: 3rem;
}

.biz_system_content .div_catname {
  margin-bottom: 2%;
  border-bottom: 1px solid #afafaf;
  padding-bottom: 10px;
}

.biz_system_content .div_catname p {
  border-top: none;
}

.biz_system_content > p {
  margin-bottom: 1.5rem;
  font-size: clamp(13px, 0.729vw, 14px);
}

.biz_system_content .block_biz_txt {
  line-height: 200%;
  color: #121212;
  margin-bottom: 2rem;
  list-style: none;
  padding: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 0 30px;
  background-color: #f9f9f9;
}

.biz_system_content .block_biz_txt li {
  position: relative;
  padding-left: 15px;
  font-size: clamp(13px, 0.729vw, 14px);
}

.biz_system_content .block_biz_txt li::before {
  content: "・";
  position: absolute;
  left: 0;
}

.biz_system_content .biz_workstext {
  line-height: 180%;
  color: #121212;
}

.biz_system_content .biz_workstext a {
  color: #121212;
  text-decoration: underline;
}

.biz_system_content .biz_workstext a:hover {
  color: rgb(239, 49, 87);
  text-decoration: none;
}

.biz_system_images {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  width: 100%;
  max-width: 980px;
}

.biz_system_images li {
  width: 100%;
}

.biz_system_images li img {
  width: 100%;
  height: auto;
  display: block;
}


/* ===============================================
   Privacy / Legal Notice Pages
   =============================================== */

#pageTitle.fades {
  font-size: clamp(24px, 2.5vw, 32px);
  text-align: center;
  margin-bottom: 50px;
  font-weight: bold;
  color: #121212;
}

.privacy_content.clearfix {
  width: 90%;
  max-width: 980px;
  margin: 0 auto;
  padding: 40px 20px;
}

.privacy_content p {
  font-size: clamp(13px, 0.833vw, 16px);
  line-height: 2.2;
  color: #121212;
  margin-bottom: 40px;
  letter-spacing: 0.05em;
}

.privacy_content p strong {
  font-weight: bold;
  font-size: clamp(15px, 0.938vw, 18px);
  margin-bottom: 8px;
  margin-top: 30px;
  color: #000;
  letter-spacing: 0.05em;
}

.raw_content.clearfix {
  width: 90%;
  max-width: 980px;
  margin: 0 auto;
  padding: 40px 20px;
}

.raw_content table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #ddd;
  margin-bottom: 50px;
  background-color: #fff;
}

.raw_content table tbody tr {
  border-bottom: 1px solid #ddd;
}

.raw_content table tbody tr:last-child {
  border-bottom: none;
}

.raw_content table td {
  padding: 20px;
  vertical-align: top;
  font-size: clamp(13px, 0.833vw, 16px);
  line-height: 180%;
  color: #121212;
}

.raw_content table td:first-child {
  width: 30%;
  font-weight: bold;
  background-color: #f9f9f9;
  border-right: 1px solid #ddd;
}

.raw_content table td:last-child {
  width: 70%;
}

.raw_content table td a {
  color: #121212;
  text-decoration: underline;
}

.raw_content table td a:hover {
  color: #000;
  text-decoration: none;
}


/* ===============================================
   News Page
   =============================================== */

.block_newslist {
  width: 90%;
  max-width: 980px;
  margin: 0 auto;
  padding: 0 20px;
}

.block_newslist .newslist_item {
  display: flex;
  gap: 40px;
  padding: 40px 0;
  border-bottom: 1px solid #ddd;
}

.block_newslist .newslist_item:first-child {
  padding-top: 0;
}

.block_newslist .newslist_item:last-child {
  border-bottom: none;
}

.block_newslist .newslist_image {
  width: 200px;
  flex-shrink: 0;
}

.block_newslist .newslist_image img {
  width: 100%;
  height: auto;
  display: block;
  background-color: #f0f0f0;
}

.block_newslist .newslist_content {
  width: 70%;
  display: flex;
  flex-direction: column;
}

.block_newslist .newslist_title {
  font-size: clamp(16px, 1.25vw, 24px);
  font-weight: bold;
  color: #121212;
  margin: 0 0 10px 0;
  line-height: 1.4;
}

.block_newslist .newslist_date {
  font-size: clamp(11px, 0.729vw, 14px);
  color: #888;
  display: block;
  margin-bottom: 20px;
  letter-spacing: 0.05em;
}

.block_newslist .newslist_text {
  font-size: clamp(13px, 0.729vw, 14px);
  line-height: 1.8;
  color: #121212;
  margin-bottom: 15px;
}

.block_newslist .newslist_text:last-of-type {
  margin-bottom: 20px;
}

.block_newslist .newslist_link {
  font-size: clamp(13px, 0.833vw, 16px);
  color: #121212;
  text-decoration: underline;
  display: inline-block;
  margin-top: auto;
}

.block_newslist .newslist_link:hover {
  color: #000;
  text-decoration: none;
}


/* ===============================================
   Pagination
   =============================================== */

.pagination {
  width: 90%;
  max-width: 980px;
  margin: 60px auto 0;
  padding: 0 20px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
}

.pagination .page-numbers {
  display: inline-block;
  padding: 4px 10px;
  font-size: 11px !important;
  color: #121212;
  text-decoration: none;
  background-color: transparent;
  transition: all 0.3s ease;
}

.pagination .page-numbers:hover {
  color: #000;
}

.pagination .page-numbers.current {
  color: #000;
  background-color: rgba(0, 0, 0, 0.1);
  cursor: default;
}

.pagination .page-numbers.prev,
.pagination .page-numbers.next {
  font-size: 11px !important;
}

.pagination .page-numbers.prev:not([href]),
.pagination .page-numbers.next:not([href]) {
  opacity: 0.3;
  cursor: not-allowed;
  pointer-events: none;
}


/* ===============================================
   Footer
   =============================================== */

#footer_companyAdd img {
  max-width: 150px;
  width: 100%;
  height: auto;
  display: block;
}

ul#foot_linkList li:after {
  right: -2% !important;
}


/* ===============================================
   Intro Section (Top Page)
   =============================================== */

.intro_section {
  background: #fff;
  padding: 0px 20px 50px;
  text-align: center;
}

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

.intro_title {
  font-size: clamp(18px, 2vw, 28px);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 20px;
  color: #000;
  letter-spacing: 0.05em;
}

.intro_text {
  font-size: clamp(11px, 1vw, 13px);
  line-height: 1.9;
  color: #000;
  margin-bottom: 25px;
  letter-spacing: 0.08em;
}

.intro_btn {
  margin-top: 25px;
}

.intro_btn a {
  display: inline-block;
  background: #B3B3B3;
  color: #fff;
  padding: 2px 60px;
  border-radius: 50px;
  text-decoration: none;
  font-size: clamp(11px, 0.9vw, 13px);
  font-weight: 500;
  letter-spacing: 0.15em;
  transition: all 0.3s ease;
  text-transform: uppercase;
}

.intro_btn a:hover {
  background: #9a9a9a;
  opacity: 0.9;
}


/* ===============================================
   Tablet (max-width: 1000px)
   =============================================== */

@media screen and (max-width: 1000px) {
  dl.division_container {
    display: block !important;
  }

  dl.division_container dt {
    width: 100% !important;
    margin: 0 0 9% !important;
  }

  dl.division_container dd {
    width: 100% !important;
  }
}

@media screen and (max-width: 725px) {
  .machine-slide {
    height: auto !important;
  }

  .machine-slide .swiper-wrapper {
    height: auto !important;
  }

  .machine-slide .swiper-slide {
    height: auto !important;
  }

  dl.division_container dt {
    width: 100% !important;
    margin: 0 auto 6% !important;
  }
}


/* *************************************************************************

   ███████╗██████╗     ██╗███████╗███╗   ███╗ █████╗ ██████╗ ████████╗██████╗ ██╗  ██╗ ██████╗ ███╗   ██╗███████╗██╗
   ██╔════╝██╔══██╗   ██╔╝██╔════╝████╗ ████║██╔══██╗██╔══██╗╚══██╔══╝██╔══██╗██║  ██║██╔═══██╗████╗  ██║██╔════╝╚██╗
   ███████╗██████╔╝  ██╔╝ ███████╗██╔████╔██║███████║██████╔╝   ██║   ██████╔╝███████║██║   ██║██╔██╗ ██║█████╗   ╚██╗
   ╚════██║██╔═══╝  ██╔╝  ╚════██║██║╚██╔╝██║██╔══██║██╔══██╗   ██║   ██╔═══╝ ██╔══██║██║   ██║██║╚██╗██║██╔══╝   ██╔╝
   ███████║██║     ██╔╝   ███████║██║ ╚═╝ ██║██║  ██║██║  ██║   ██║   ██║     ██║  ██║╚██████╔╝██║ ╚████║███████╗██╔╝
   ╚══════╝╚═╝     ╚═╝    ╚══════╝╚═╝     ╚═╝╚═╝  ╚═╝╚═╝  ╚═╝   ╚═╝   ╚═╝     ╚═╝  ╚═╝ ╚═════╝ ╚═╝  ╚═══╝╚══════╝╚═╝

   SP版スタイル (max-width: 768px)

   ************************************************************************* */

@media screen and (max-width: 768px) {

/* ===============================================
   SP版 ファーストビュー フルスクリーン化設定
   ※トップページ（.is-home）のみ適用
   =============================================== */

  /* 1. コンテナの高さを画像に合わせる - トップページ */
  #firstview.is-home,
  #firstview.is-home .swiper-container,
  #firstview.is-home .swiper-wrapper,
  #firstview.is-home .swiper-slide {
    height: auto !important;
    min-height: auto !important;
  }

  /* 2. 画像の表示設定を変更 - トップページのみ */
  #firstview.is-home .swiper-slide img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
  }

  /* SP用画像を強制表示・PC用を非表示（全ページ共通） */
  #firstview .swiper-slide img.for_pc,
  #firstview .inner_view img.for_pc {
    display: none !important;
  }
  #firstview .swiper-slide img.for_sp,
  #firstview .inner_view img.for_sp {
    display: block !important;
  }
  
  /* ===============================================
     Dropdown Menu (SP)
     =============================================== */

  /* Divisionsは常に開いた状態 */
  #globalNavi ul#naviList li.has-dropdown > a {
    pointer-events: none;
    opacity: 0.7;
  }

  #globalNavi ul#naviList li.has-dropdown > a:after {
    content: none;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu {
    display: block;
    list-style: none;
    padding: 10px 0 0 0;
    margin: 0;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li {
    margin: 0 auto 12px;
    padding: 0;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li:last-child {
    margin-bottom: 0;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li a {
    color: #888;
    font-size: 11px;
    font-weight: 400;
    text-decoration: none;
    display: block;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li a:after {
    content: none;
  }

  #globalNavi ul#naviList li.has-dropdown .dropdown-menu li a:hover {
    color: #050505;
  }


  /* ===============================================
     PC/SP表示切り替え
     =============================================== */

  .sp {
    display: inline;
  }

  .pc {
    display: none;
  }


  /* ===============================================
     2 Column Thumb List
     =============================================== */

  ul.thumb_list_2col li {
    width: 48.5%;
    margin-bottom: 6%;
  }

  ul.thumb_list_2col li:nth-of-type(2n) {
    margin-right: 0;
  }


  /* ===============================================
     Top Page - Thumb List Notes
     =============================================== */

  #mainContents #contents_pageLinks .thumb_list li .thumb_listNotes p {
    font-size: clamp(9px, 1.5vw, 10px) !important;
  }

  .thumb_listNotes p.up {
    font-size: clamp(9px, 2vw, 10px) !important;
  }


  /* ===============================================
     Division Pages - Swiper
     =============================================== */

  .machine-slide {
    width: 100% !important;
    height: auto !important;
  }

  .machine-slide .swiper-wrapper {
    height: auto !important;
  }

  .machine-slide .swiper-slide {
    height: auto !important;
  }

  .machine-slide .swiper-pagination {
    bottom: 20px !important;
  }


  /* ===============================================
     システム開発セクション
     =============================================== */

  .biz_system_section {
    margin-bottom: 16%;
  }

  .biz_system_content {
    margin-bottom: 2rem;
  }

  .biz_system_images {
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }


  /* ===============================================
     Privacy / Legal Notice Pages
     =============================================== */

  #pageTitle.fades {
    margin-bottom: 30px;
  }

  .privacy_content.clearfix {
    width: 100%;
    padding: 0 15px;
  }

  .raw_content.clearfix {
    width: 100%;
    padding: 20px 10px;
  }

  .privacy_content p {
    margin-bottom: 25px;
  }

  .raw_content table {
    font-size: clamp(12px, 3vw, 14px);
  }

  .raw_content table td {
    padding: 12px 8px;
    font-size: clamp(12px, 3vw, 14px);
  }

  .raw_content table td:first-child {
    width: 25%;
  }

  .raw_content table td:last-child {
    width: 75%;
  }


  /* ===============================================
     News Page
     =============================================== */

  .block_newslist {
    width: 100%;
    padding: 0 15px;
  }

  .block_newslist .newslist_item {
    flex-direction: column;
    gap: 20px;
    padding: 30px 0;
  }

  .block_newslist .newslist_image {
    width: 60%;
    margin: 0 auto;
  }

  .block_newslist .newslist_content {
    width: 100%;
  }

  .block_newslist .newslist_date {
    margin-bottom: 15px;
  }

  .block_newslist .newslist_text {
    margin-bottom: 12px;
  }

  .block_newslist .newslist_text:last-of-type {
    margin-bottom: 15px;
  }


  /* ===============================================
     Pagination
     =============================================== */

  .pagination {
    width: 100%;
    padding: 0 15px;
    margin: 40px auto 0;
    gap: 8px;
  }

  .pagination .page-numbers {
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
  }


  /* ===============================================
     Footer
     =============================================== */

  #footer_companyAdd img {
    max-width: 120px;
  }


  /* ===============================================
     Intro Section (Top Page)
     =============================================== */

  .intro_section {
    padding: 40px 20px;
  }

  .intro_title {
    margin-bottom: 15px;
  }

  .intro_text {
    margin-bottom: 20px;
  }

  .intro_text br {
    display: none;
  }

  .intro_btn {
    margin-top: 20px;
  }

  .intro_btn a {
    padding: 8px 40px;
  }

}


/* ===============================================
   Creative Systems - btn_more fix
   =============================================== */

.biz_system_section .btn_more a span:before,
.biz_system_section .btn_more a span:after {
  content: "" !important;
  position: absolute !important;
  background: #121212 !important;
  transform: translateY(-50%) !important;
  top: 52% !important;
  transition: 0.2s all !important;
}

.biz_system_section .btn_more a span:before {
  width: 1px !important;
  height: 11px !important;
  right: -2px !important;
}

.biz_system_section .btn_more a span:after {
  width: 11px !important;
  height: 1px !important;
  right: -7px !important;
}


/* ===============================================
   Firstview Overlay Catch (Neo Sports, etc.)
   =============================================== */

#firstview.has-overlay {
  position: relative;
}

#firstview.has-overlay .view_list {
  position: relative;
}

/* 画像を暗くするオーバーレイ */
#firstview.has-overlay .inner_view {
  position: relative;
}

#firstview.has-overlay .inner_view::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.35);
  pointer-events: none;
  z-index: 1;
}

#firstview.has-overlay #page_catchBloc.overlay-catch {
  position: absolute;
  top: calc(50% + 30px);
  transform: translateY(-50%);
  left: 0;
  right: 0;
  z-index: 10;
  text-align: center;
  color: #fff;
  padding: 0 5%;
}

#firstview.has-overlay #page_catchBloc.overlay-catch #pageCatch {
  color: #fff;
  font-size: clamp(16px, 2.2vw, 24px);
  font-weight: 700;
  letter-spacing: 0.15em;
  margin-bottom: 40px;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

#firstview.has-overlay #page_catchBloc.overlay-catch p {
  color: #fff;
  font-size: clamp(14px, 2vw, 18px);
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.1em;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

#firstview.has-overlay #page_catchBloc.overlay-catch p span {
  font-size: clamp(11px, 1.3vw, 13px);
  font-weight: 400;
  display: block;
  margin-top: 40px;
}

@media screen and (max-width: 768px) {
  /* SP版の隙間対策 - contents.cssの100vh設定を上書き */
  #firstview.has-overlay ul#viewList li img,
  #firstview.has-overlay .inner_view li img {
    height: auto !important;
    max-height: none !important;
  }

  #firstview.has-overlay #page_catchBloc.overlay-catch {
    top: calc(50% + 25px);
  }

  #firstview.has-overlay #page_catchBloc.overlay-catch #pageCatch {
    font-size: 13px;
    margin-bottom: 8px;
  }

  #firstview.has-overlay #page_catchBloc.overlay-catch p {
    font-size: 12px;
    line-height: 1.7;
  }

  #firstview.has-overlay #page_catchBloc.overlay-catch p span {
    font-size: 10px;
    margin-top: 8px;
  }
}


/* ===============================================
   Top Page (is-home) - Firstview Overlay
   トップページ専用のオーバーレイスタイル
   =============================================== */

/* トップページ用オーバーレイ（Swiper構造対応） */
#firstview.is-home.has-overlay .swiper-container {
  position: relative;
}

#firstview.is-home.has-overlay .swiper-wrapper::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.45);
  pointer-events: none;
  z-index: 1;
}

/* トップページ用テキストスタイル（大きめ） */
#firstview.is-home.has-overlay #page_catchBloc.overlay-catch {
  position: absolute;
  top: calc(50% + 30px);
  transform: translateY(-50%);
  left: 0;
  right: 0;
  z-index: 10;
  text-align: center;
  color: #fff;
  padding: 0 3%;
}

#firstview.is-home.has-overlay #page_catchBloc.overlay-catch #pageCatch {
  color: #fff;
  font-size: clamp(20px, 2.8vw, 32px);
  font-weight: 700;
  letter-spacing: 0.15em;
  margin-bottom: 40px;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
  white-space: nowrap;
}

#firstview.is-home.has-overlay #page_catchBloc.overlay-catch p {
  color: #fff;
  font-size: clamp(18px, 2.6vw, 26px);
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.1em;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

#firstview.is-home.has-overlay #page_catchBloc.overlay-catch p span {
  font-size: clamp(15px, 1.8vw, 18px);
  font-weight: 400;
  display: block;
  margin-top: 40px;
}

/* SP版 - トップページ */
@media screen and (max-width: 768px) {
  #firstview.is-home.has-overlay #page_catchBloc.overlay-catch {
    top: calc(50% + 25px);
  }

  #firstview.is-home.has-overlay #page_catchBloc.overlay-catch #pageCatch {
    font-size: 20px;
    margin-bottom: 20px;
    white-space: normal;
  }

  #firstview.is-home.has-overlay #page_catchBloc.overlay-catch p {
    font-size: 18px;
    line-height: 1.9;
  }

  #firstview.is-home.has-overlay #page_catchBloc.overlay-catch p span {
    font-size: 15px;
    margin-top: 20px;
  }
}
