@charset "UTF-8";

html {
  scroll-behavior: smooth;
}
main {
    overflow-x: hidden;
}
/*------------------
    font-family
------------------*/
:root {
    --outfit: "Outfit", sans-serif;
    --Zen-Kaku-Gothic-New: "Zen Kaku Gothic New", "Noto Sans JP", sans-serif;
    --Jost: "Jost", sans-serif;
}

/*------------------
    color
------------------*/
:root {
    --wh: #FFFFFF;
    --bl: #5A93D8;
    --red: #E54E4E;
    --dark-gray:#2F2F2F;
    --bk: #000000;
    --sensor: #5A93D8;
    --dmah: #2C2FAE;
    --research: #E54E4E;
    --medical: #BC2E2E;
}


/*------------------
    共通設定
------------------*/
body {
  font-family: var(--Zen-Kaku-Gothic-New);
  color: var(--wh);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.03em;
  scroll-behavior: smooth;
  background-color: var(--bk);
  overflow-x: hidden;
}
picture img, picture source {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
    object-fit: cover;
}
.sp-br {
  display: none;
}
.pc-br {
  display: block;
}

    @media(max-width:768px){
    .sp-br {
    display: block;
    }
    .pc-br {
    display: none;
    }

}


/*------------------
  cssのみでページ遷移フェードアニメーション
------------------*/
.fade-body {
  animation: fadein .8s ease-out;
}
  @keyframes fadein {
  0% {
    opacity: .8;
    }
  100% {
    opacity: 1;
    }
  }


/*------------------
  fvフェードアニメーション
------------------*/
/* クラスを指定すれば自動でふわっと表示 */
.fade-in {
  opacity: 0;
  transform: translateY(6px);
  animation: fadeInUp 0.6s ease-out forwards;
  animation-delay: 0.1s; /* 少し遅らせると自然 */
}

/* アニメーション本体 */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(6px); /* 下から */
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}


/*------------------
  フォントサイズ管理
------------------*/
/* 1025–1920px */
:root {
--fz_170: clamp(91px, 8.8542vw, 170px);
--fz_120: clamp(64px, 6.25vw, 120px);
--fz_97: clamp(52px, 5.0518vw, 97px);
--fz_70: clamp(38px, 3.6458vw, 70px);
--fz_64: clamp(34px, 3.333vw, 64px);
--fz_62: clamp(33px, 3.6458vw, 62px);
--fz_60: clamp(32px, 3.1250vw, 60px);
--fz_45: clamp(24px, 2.3437vw, 45px);
--fz_40: clamp(22px, 2.0833vw, 40px);
--fz_35: clamp(21px, 1.8229vw, 35px);
--fz_33: clamp(20px, 1.7187vw, 33px);
--fz_30: clamp(18px, 1.5625vw, 30px);
--fz_28: clamp(18px, 1.4583vw, 28px);
--fz_25: clamp(16px, 1.3020vw, 25px);
--fz_24: clamp(16px, 1.25vw, 24px);
--fz_23: clamp(16px, 1.197vw, 23px);
--fz_22: clamp(16px, 1.1458vw, 22px);
--fz_20: clamp(15px, 1.0416vw, 20px);
--fz_18: clamp(14px, 0.9375vw, 18px);
--fz_17: clamp(14px, 0.8541vw, 17px);
--fz_16: clamp(13px, 0.8333vw, 16px);
}

 /* 1240–1920px */
:root {
--m-fz_12-14: clamp(12px, 0.29vw, 14px);
}

/* 768–1024px */
:root {
--s-fz_36-56: clamp(36px, 7.81vw, 56px); 
}




/*===============================
        ttl1
===============================*/
h2:first-letter {
  color: var(--red);
}
.c-title .first-letter {
  color: var(--red);
}
/*===============================
        ttl2
===============================*/
.under-title {
  position: relative;
  padding: 0 5%;
  height: 60vh;
}
.under-title__inner {
    max-width: 1720px;
    margin: 0 auto;
}
.under-title__inner .c-title {
    font-size: clamp(100px, 6.25vw, 120px);
    line-height: 1.5;
    position: absolute;
    top: 50%;
    left: 5%;
}
.under-title__inner .c-subtitle {
    font-size: var(--fz_25);
    position: absolute;
    top: 50%;
    left: 5%;
}

.under-title__bg img {
  width: 100%;
}
.under-title__wrap {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.under-title__wrap h2 {
    font-family: var(--outfit);
    font-size: var(--fz_120);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;
    text-transform: uppercase;
}
.under-title__wrap p {
    font-size: var(--fz_25);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1;
}


/* 地球下層ページ共通地球 */
.under-title__bg.lottie-pc {
  overflow: hidden;
  width: 56vw;/*76-20*/
  height: 56vw;
  position: relative;    /* 子要素の絶対位置指定の基準 */
}
dotlottie-wc.lottie-background.lottie-pc {
    position: fixed;
    right: -20vw;
    top: -20vw;
    z-index: -1;
    width: 76vw;
    height: 76vw;
}

dotlottie-wc.lottie-background.lottie-sp {
    display: none;
}

.lottie-background {
  opacity: 1; /* 初期値を念のため明示 */
  transition: none; /* GSAPが制御するのでCSSトランジションは不要 */
  width: 100%;
  height: 100%;
  pointer-events: none;

}


    @media(max-width:768px){
    .under-title__bg.lottie-sp {
    overflow: hidden !important;
    width: 80vw;/*100-20*/
    height: 80vw;
    position: relative;    /* 子要素の絶対位置指定の基準 */
    }
    dotlottie-wc.lottie-background.lottie-sp {
    position: fixed;
    right: -40vw;
    top: -20vw;
    z-index: -1;
    width: 120vw;
    height: 120vw;
    display: block;
    }
    dotlottie-wc.lottie-background.lottie-pc {
    display: none;
    }
    .under-title__bg.lottie-sp {
    pointer-events: none;
    }
    dotlottie-wc.lottie-background.under-title__bg.lottie-sp {
    display: none;
    }

    }



      @media(max-width:768px){
      .under-title {
      aspect-ratio: 390 / 315;
      height: auto;
      }
      .under-title__wrap {
      position: absolute;
      top: auto;
      transform: translateY(-50%);
      bottom: 0;
      }
      .under-title__wrap h2 {
      font-size: 42px;
      line-height: 1.4;
      }
      .under-title__wrap p {
      font-size: 11px;
      line-height: 1.45;
      }
      .under-title__inner {
      max-width: 1720px;
      margin: 0 auto;
      height: 100%;
      }
      .under-title__bg.lottie-sp {
      display: block;
      pointer-events: none;
      }
      .under-title__bg.lottie-pc {
      display: none;
      }

    }



/*===============================
        パンくずリスト
===============================*/
.bredcrumb__wrap {
  padding: 0 5% 58px;
}
.bredcrumb {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    color: #A0A0A0;
    font-weight: 500;
    font-size: 18px;
    max-width: 1720px;
    margin: 0 auto;
    position: absolute;
    bottom: 0;
    right: 0;
}
.bredcrumb hr {
  border-top: solid 1px #A0A0A0;
  width: 28px;
  margin: 0 15px;
}
.bredcrumb .active {
  color: var(--wh);
  font-weight: bold;
}

.service__mv--inner .bredcrumb .active {
    color: var(--bk);
}

@media(max-width:768px){
.bredcrumb__wrap {
padding: 0;
top: 65px;
position: absolute;
left: 5%;
width: 90%;
}
.bredcrumb {
position: absolute;
top: 0;
width: 100%;
justify-content: flex-start;
font-size: 10px;
}
.bredcrumb hr {
width: 16px;
margin: 0 10px;
}


.service__mv .bredcrumb {
    color: #fff;
    z-index: 10;
    top: 60px;
    left: 20px;
}
.service__mv .bredcrumb hr {
    border-top: solid 1px #fff;
}
}

/*===============================
        btn__VIEW ALL
===============================*/
.btn__more a {
  font-family: var(--outfit);
  color: var(--wh);
  font-size: 25px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0;
  text-align: left;
  text-decoration: none;
  text-transform: uppercase;
}
.btn__more a span {
  margin-left: 10px;
}
@media(max-width:768px){
  .btn__more a {
    font-size: 20px;
}
}



/* ホバー下線 */
.btn__more a {
    position: relative;
    color: var(--wh);
    text-decoration: none;
    display: flex;
    padding: 10px 10px 0;
    line-height: 1;
    align-items: center;
    font-family: var(--outfit);
    font-weight: bold;
    font-size: var(--fz_25);
}
.btn__more a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -4px;
    width: 0;
    height: 2px;
    background-color: var(--wh);
    transition: width 0.3s ease;
}
.btn__more a:hover::after {
    width: 100%;
}
.t-products .btn__more a {
    padding: 10px 0;
}


/*===============================
        top-page__swiper btn__triangle
===============================*/
.btn-arrow-img {
  display: inline-flex;
  align-items: end;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
  justify-content: space-between;
  border: none;
}
a.btn-arrow-img {
    font-size: var(--fz_30);
    font-weight: bold;
}
.arrow-box {
  display: inline-block;
  width: 50px;
  height: 50px;
  position: relative;
  overflow: hidden;
  background: transparent;
  margin-right: 10px;
  margin-bottom: 10px;
  clip-path: polygon(100% 0, 100% 100%, 0 100%); /* 三角形の形 */
}

/* 右の線 */
.arrow-box::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 100%;
  background: #fff;
}

/* 下の線 */
.arrow-box::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fff;
}

/* 斜めの線（右上 → 左下） */
a.btn-arrow-img::after {
    position: absolute;
    content: "";
    bottom: 10px;
    right: 30px;
    height: 70px;
    width: 1px;
    background: #fff;
    transform-origin: right top;
    transform: rotate(45deg);
}


/* 共通設定 */
.arrow {
  position: absolute;
  transform: translateY(-50%);
  transition: all 0.5s ease;
  top: 70%;
}

/* 初期の細い矢印（中央表示） */
.arrow-thin {
  transform: translate(-50%, -50%);
  opacity: 1;
  width: 13px;
  left: 70%;
}

/* ホバー時に右へ抜けながらフェードアウト */
.btn-arrow-img:hover .arrow-thin {
  left: 120%;
  opacity: 0;
}

img.arrow.arrow-thin {
    width: 13px;
}
img.arrow.arrow-thick {
    width: 13px;
}

/* 初期の太い矢印（左外に配置） */
.arrow-thick {
  left: -20px;
  opacity: 0;
  width: 12px;
}

/* ホバー時に中央へスライドしつつフェードイン */
.btn-arrow-img:hover .arrow-thick {
  opacity: 1;
  left: 50%;
}

/* ホバー解除時にまた左へ戻る（クロスフェード復帰） */
.btn-arrow-img:not(:hover) .arrow-thick {
  left: -20px;
  opacity: 0;
}

/* 背景変化 */
a.btn-arrow-img:hover .arrow-box {
  background: #ffffff;
  border: none;
}

/* 背景画像 */
img.swiper {
    vertical-align: bottom;
    position: absolute;
    z-index: -1;
    object-fit: cover;
    width: 100%;
    aspect-ratio: 579 / 422;

    /* 下が黒で上に向かって透明になるグラデーション */
    -webkit-mask-image: linear-gradient(to bottom, rgba(11,11,11,1), rgba(0,0,0,0));
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-size: cover;

    mask-image: linear-gradient(to bottom, rgba(11,11,11,1), rgba(0,0,0,0));
    mask-repeat: no-repeat;
    mask-size: cover;
}





span.swiper__title {
font-size: var(--fz_30);
color: var(--wh);
margin-left: 30px;
margin-bottom: 30px;
line-height: 1;
}
span.swiper__subtitle {
  text-transform: uppercase;
  font-size: var(--fz_20);
  font-family: var(--outfit);
  font-weight: bold;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.74);
  display: inline-block;
  margin-bottom: 10px;
}

/* スクロールバーカスタム
  ====================*/
.scroll-container::-webkit-scrollbar {
  width: 12px;       /* スクロールバーの幅 */
}

.scroll-container::-webkit-scrollbar-thumb {
  background-color: #ff0000; /* 持ち手の色 */
  border-radius: 6px;
}

.scroll-container::-webkit-scrollbar-track {
  background-color: #f0f0f0; /* 背景 */
}

/* Firefox */
.scroll-container {
  scrollbar-width: thin;
  scrollbar-color: #ff0000 #f0f0f0; /* 持ち手と背景 */
}


/*===============================
        btn__external
===============================*/
.t-recruit__btn-external {
  width: 273px;
  height: 57px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
}
.t-recruit__btn-external a {
    border: solid 1px #fff;
    font-size: clamp(16px, 1.302vw, 25px);
    color: #fff;
    font-family: var(--outfit);
    font-weight: bold;
    line-height: 1;
    border-radius: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: all .3s;
    padding: 15px 25px 15px 40px;
}

.t-recruit__btn-external a img {
  width: 17px;
  height: 17px;
  margin-left: 22px;
}

.t-recruit__btn-external a:hover {
    border: solid 1px #fff;
    background-color: #fff;
    color: #000;
}
#link-icon {
    fill: currentColor;
    transition: fill 0.3s ease;
    margin-left: 22px;
}
/*===============================
        header__bk
===============================*/
.sp__header--wrap {
    display: none;
}
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: clamp(
  52px,
  calc(73px + (100vw - 1440px) * 0.04583),
  95px
  );
  /* z-index: 10001; */
  z-index: 9990;/*lity*/
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 72px 0 50px;
  box-sizing: border-box;
  text-transform: uppercase;
  background-color: rgba(38,38,38,0);
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  transition: none;
  }

header h1 {
/*width: clamp(86px, 8.2vw, 153px);
min-width: 10%;
margin-top: 10px;
position: relative;
z-index: 1001; *//* ドロワーより上に */
	    width: clamp(86px, 8.2vw, 153px);
    min-width: 10%;
    margin-top: 10px;
    position: relative;
    z-index: 1001;
    aspect-ratio: 1 / 0.4;
}
header h1 a {
width: 100%;
height: 100%;
display: block;
	position: relative;
}

header h1 img {
width: 100%; 
height: 100%;
object-fit: contain;
align-items: baseline;
	position: absolute;
    top: 0;
    left: 0;
    width: clamp(86px, 8.2vw, 153px);
    min-width: 10%;
    height: auto;
}

header h1 img.logo--white {
  opacity: 1;
}

header h1 img.logo--black {
  opacity: 0;
}

header h1 img.logo--white,
header h1 img.logo--black {
  position: absolute;
  top: 0;
  left: 0;
  transition: opacity .3s ease;
}
header nav ul {
display: flex;
gap: 45px;
margin: 0;
padding:0;
list-style:none;
align-items: center;
}
header nav ul li {
position: relative;
display: flex;
}
header nav ul li a {
color:var(--wh);
text-decoration:none;
font-weight:700;
}
span.link-icon {
    width: 13px;
    height: 13px;
    display: flex;
    margin-left: 6px;
}
span.link-icon img {
  width: 100%;
  object-fit: cover;
  vertical-align: bottom;
}
span.lang-separator {
    font-weight: bold;
}


/* header-navリンク下線アニメーション */
.header__nav--item a {
position: relative;
color: var(--wh);
text-decoration: none;
display: flex;
padding: 0;
line-height: 1;
align-items: center;
font-family: var(--outfit);
font-weight: bold;
font-size: clamp(13px, 1.1458vw, 22px);
}
.header__nav--item a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -4px; /* 下線の位置 */
  width: 0;
  height: 2px;  /* 下線の太さ */
  background-color: var(--wh); /* 下線の色 */
  transition: width 0.3s ease;
}
.header__nav--item a:hover::after {
  width: 100%; /* 左から右に伸びる */
}
.header__nav--item span {
  color: var(--wh);
}
/* ./ header-navリンク下線アニメーション */

/* 言語切り換え */
.header__nav--lang a {
  text-decoration: none;
  color: var(--wh);
  padding: 0 4px;
}
.header__nav--lang a.active {
  font-weight: bold;
}
.header__nav--lang .lang-separator {
  color: var(--wh);
  padding: 0 2px;
}
p.header__nav--lang-sp .active {
    text-decoration: underline;
}
/* ./ 言語切り換え */


/* li.header__nav--item.has-submenu に active クラスが付いたときに背景色を変える */
/* 通常のサブメニューアイテム */
li.header__nav--item.has-submenu {
  position: relative;
  background-color: transparent;
  transition: background-color 0.3s ease;
  z-index: 1;
}

li.header__nav--item.has-submenu::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;       /* 初期は0で非表示 */
  height: 100%;
  background-color: var(--bk);
  z-index: -1;    /* テキストの下に表示 */
  transition: width 0.3s ease; /* 開閉時にアニメーション */
}

li.header__nav--item.has-submenu.active::before {
  width: calc(100% + 20px);
  height: 65px;
  top: -10px;
  left: -10px;
}
/* ./ li.header__nav--item.has-submenu に active クラスが付いたときに背景色を変える */

/* サブメニュー */
.nav-submenu {
position: absolute;
top: 2em;
left: -10px;
background:var(--bk);
overflow:hidden;
opacity:0;
height:0;
width: max-content;
padding: 10px;
gap: 10px;
display: inline-grid;
z-index: 1;
}
.nav-submenu a {
  display:flex;
  padding:6px 0;
  color:var(--wh);
  position: relative;
  height: auto;
  margin-top: 0;
  font-size: var(--fz_17);
}
.nav-submenu a::after {
  content:"";
  position:absolute;
  bottom:0;
  left:0;
  height:6px;
  width:0;
  background:var(--bl);
  transition: width 0.3s ease;
  opacity: .6;
}
.nav-submenu a:hover::after {
  width:100%;
}
/* ./ サブメニュー */


/* toggle アイコン */
.toggle-icon {
  margin-left: 6px;
  font-weight: bold;
  transition: transform 0.3s ease;
}
/* ./ toggle アイコン */



/*===============================
        header__bk 下層
===============================*/
header.under__header {
    backdrop-filter: blur(30px);
    background-color: rgba(38, 38, 38, 0.28);
}

/*===============================
        header__wh サービス
===============================*/
header.service__header {
  background-color: rgba(255, 255, 255, 0.28);
  backdrop-filter: blur(28px);
}

.hamburger {
  will-change: opacity;
  opacity: 1;
  z-index: 10002;
}

/* サービスページnav-open時header背景 */
@media(max-width:768px){
header.service__header.drawer-open {
backdrop-filter: blur(30px);
background-color: rgba(38, 38, 38, 0.28);
}
}
        /*===============================
                SP header
        ===============================*/
        /* PC表示 */
        nav.h-nav.sp-nav,
        button.hamburger,
        p.header__nav--lang-sp,
        .header__nav--spWrap {
          display: none;
        }

        @media(max-width:1160px){
        header {
        padding: 0 20px;
        }
        }

        /* SP表示 */
        @media screen and (max-width: 960px) {
        header {
        padding: 0;
        height: 52px;
        }
        header h1 {
          display: none;
        }
        header.service__header h1 {
        display: none;
        }
        p.sp__header--logo {
        width: 121px;
        margin-left: 20px;
        /* 1031test */
        position: relative;
        }
        p.sp__header--logo img {
          width: 100%;
          object-fit: contain;
        }
        .header__nav--spWrap {
        justify-content: end;
        display: flex;
        align-items: center;
        gap: 20px;
        position: fixed;
        right: 20px;
        }
        .sp__header--wrap {
        display: block;
        }

        header.sp__header {
        display: flex;
        width: 100%;
        align-items: center;
        justify-content: space-between;
        }

        nav.h-nav.pc-nav {
        display: none !important; /* ←強制的に隠す */
        }
        nav.h-nav.sp-nav,
        button.hamburger,
        p.header__nav--lang-sp {
        display: block;
        position: relative;
        z-index: 1003;
        }
        p.header__nav--lang-sp a {
          color: var(--wh);
          text-decoration: none;
          padding: 0 4px;
          font-weight: bold;
        }
        nav.h-nav.sp-nav ul {
        display: flex;
        flex-direction: column;
        gap: 0;
        padding: 0;
        align-items: flex-start;
        }


        button.hamburger {
          background: none;
          border: none;
          all: unset;
          width: 30px;
          height: 30px;
          z-index: 99999 !important;
          opacity: 1 !important;
          visibility: visible !important;
          display: block !important;
          }

          button.hamburger span {
          display: block;
          height: 1.5px;
          background: var(--wh);
          transition: 0.3s;
          margin: 6px 0;
          }


        /* SPナビの初期位置（右側に隠す） */
        nav.h-nav.sp-nav {
          position: fixed;
          top: 0;
          right: -100%; /* ←初期は必ず画面外 */
          width: 100%;
          height: 100vh;
          background: #0B0B0B;
          transition: right 0.3s ease;
          z-index: 1000;
          visibility: hidden; /* ←追加: 完全に不可視 */
          opacity: 0;         /* ←追加: 透明 */
        }

        /* ドロワー表示 */
        nav.h-nav.sp-nav.active {
        right: 0;
        background-color: var(--bk);
        width: 90%;
        right: 0;
        visibility: visible;
        opacity: 1;
        height: 100vh;
        overflow-y: scroll;
        overflow-x: hidden;
        padding: 100px 5% 0;
        z-index: 3;
        }

        li.sp-nav__menu {
        border-bottom: solid 0.5px #A8A8A8;
        width: 90%;
        padding: 0 5%;
        }
        li.sp-nav__menu:first-child {
        border-top: solid 0.5px #A8A8A8;
        }

        li.sp-nav__menu a {
        color: var(--wh);
        text-decoration: none;
        }

        /* ハンバーガーの開閉アニメーション */
        button.hamburger.open span:nth-child(1) { transform: rotate(30deg) translateY(8.5px); }
        button.hamburger.open span:nth-child(2) { opacity: 0; }
        button.hamburger.open span:nth-child(3) { transform: rotate(-30deg) translateY(-8.5px); }

        /* 初期は非表示 */
        .sp-nav-childList {
        opacity: 0;
        height: 0;
        overflow: hidden;
        transition: none;
        }
        span.sp-nav__ttl {
        font-family: var(--outfit);
        font-size: 25px;
        font-weight: bold;
        letter-spacing: 0;
        line-height: 1.5;
        text-transform: uppercase;
        }
        span.first-col {
            color: var(--red);
        }
        span.sp-nav__subTtl {
        display: block;
        font-family: var(--Zen-Kaku-Gothic-New);
        font-size: 10px;
        font-weight: bold;
        letter-spacing: 0;
        line-height: 1;
        margin-top: 14px;
        }
        .sp-nav__title--wrap {
        position: relative;
        }
        .sp-nav__lottie--wrap {
        position: absolute;
        z-index: -1;
        bottom: -78px;
        right: -25vw;
        }

        .sp-nav__link--flex {
        display: flex;
        align-items: center;
        justify-content: space-between;
        }
        .toggle-icon {
        transition: transform 0.3s ease;
        width: 22px;
        height: 22px;
        margin: 0;
        object-fit: contain;
        display: block;
        }


        li.sp-nav-childList {
          display: grid;
          grid-template-columns: repeat(2, 1fr);
          gap: 10px;
        }

        /* クラスで3列に変更 */
        li.sp-nav-childList.three-columns {
          grid-template-columns: repeat(3, 1fr);
        }
        .sp-nav-child a {
          font-size: 12px;
          letter-spacing: 0.015em;
          font-weight: 300;
        }
        li.sp-nav-childList {
          list-style-type: disc; /* ・マーク */
          padding-left: 20px;    /* インデントを確保 */
        }
        .sp-nav__menu.active {
        background: linear-gradient(180deg, rgba(11, 11, 11, 0.7) 0%, rgba(11, 11, 11, 1) 50%, rgba(11, 11, 11, 0.7) 100%);
        padding-bottom: 10px;
        }



        /* 子要素2列に */
        nav.h-nav.sp-nav ul.sp-nav-childList {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        margin: 0;
        }
        nav.h-nav.sp-nav ul.sp-nav__list > li.sp-nav__menu:nth-of-type(2) > ul.sp-nav-childList,
        nav.h-nav.sp-nav ul.sp-nav__list > li.sp-nav__menu:nth-of-type(6) > ul.sp-nav-childList {
          grid-template-columns: 4fr 6fr;
        }
        nav.h-nav.sp-nav ul.sp-nav__list > li.sp-nav__menu:nth-of-type(2) > ul.sp-nav-childList li a {
        font-size: 11px;
        }

        li.sp-nav-child {
        list-style: disc;
        font-size: x-small;
        margin-left: 2em;
        min-width: 100px;
        width: 100%;
        margin: 6px 0 6px 2em;
        }

        .sp-nav-child a {
        display: block;
        text-align: left;
        white-space: nowrap;
        padding: 0;
        }

        .sp-nav__title {
        font-size: 24px;
        line-height: 1;
        font-weight: bold;
        font-family: var(--outfit);
        margin-top: 70px;
        text-transform: uppercase;
        width: max-content;
        }
        .sp-nav__title p:nth-child(1) {
        color: var(--bl);
        }
        .sp-nav__title p:nth-child(2) {
        color: var(--wh);
        }
        .sp-nav__title p:nth-child(3) {
        color: var(--red);
        margin-left: 3em;
        }
        .sp-nav__policy a {
        color: #8D8D8D;
        font-weight: bold;
        font-size: 12px;
        font-family: var(--outfit);
        letter-spacing: 0;
        margin-top: 15px;
        text-decoration: none;
        }
        small.sp-nav__small {
        font-size: 11px;
        font-family: var(--outfit);
        font-weight: 400;
        letter-spacing: 0;
        margin: 10px 0 10px;
        display: block;
        text-align: center;
        }
        .sp-nav__title--wrap hr {
        margin: 15px 0;
        }
        .sp-nav__policy {
        text-align: right;
        }
        header nav ul {
        gap: 0;
        }
        .header__border.forSp {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 0.7px;
        background: #fff;
        }

        p.sp__header--logo a img {
        vertical-align: bottom;
        /* 1031test */
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        }
        p.sp__header--logo a {
        width: 100%;
        display: block;
        height: 100%;
        }
			
			p.sp__header--logo a img.logo--white,
p.sp__header--logo a img.logo--black {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  transition: opacity .3s ease;
}

/* 初期状態 */
p.sp__header--logo a img.logo--white {
  opacity: 1;
}

p.sp__header--logo a img.logo--black {
  opacity: 0;
}
			
        }


/* =======================================
 service-page  SPヘッダーロゴ切り替え 1031test
======================================= */
/* SPヘッダーロゴ切り替え */
/* .sp__header--logo {
  position: relative;
  width: 120px;
  height: auto;
} */

/* .sp__header--logo .logo--white,
.sp__header--logo .logo--black {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  transition: opacity 0.3s ease;
} */

/* 初期状態：白ロゴ表示 */
/* .sp__header--logo .logo--white { opacity: 1; }
.sp__header--logo .logo--black { opacity: 0; } */

/* 黒ロゴ表示 */
/* .sp__header--logo.is-black .logo--white { opacity: 0; }
.sp__header--logo.is-black .logo--black { opacity: 1; } */






/*===============================
    service__header
===============================*/
header.service__header h1 a img.forSp {
display: none;
}

        @media(max-width:768px){
        header.service__header h1 a img.forPc {
        display: none;
        }
        header.service__header h1 a img.forSp {
        display: block;
        }

        /* 下線 */
        header.service__header .header__border.forSp {
        background: none;
        }
        header.service__header {
        background-color: rgba(255, 255, 255, 0.28);
        backdrop-filter: blur(3px);
        -webkit-backdrop-filter: blur(2px);
        position: fixed;
        }

        }



/*===============================
        footer__bk
===============================*/
#footer {
    padding: 0 5%;
    position: relative;
    z-index: 2;
    background-color: var(--bk);

}
.footer__inner {
    border-top: solid 1px var(--wh);
    max-width: 1720px;
    margin: 0 auto;
    padding-top: 80px;
    display: flex;
    justify-content: space-between;
}
.footer__logo {
    width: clamp(200px, 17.9687vw, 345px);
}
.footer__logo img {
    width: 100%;
    object-fit: contain;
    vertical-align: bottom;
}
.footer__mark {
    display: flex;
    justify-content: end;
    align-items: center;
    margin: 70px 0 50px;
    gap: 20px;
}
.footer__privacy {
    text-align: end;
    margin-bottom: 20px;
}
.footer__nav--item.footer__nav--lang {
    display: flex;
    justify-content: end;
}
.footer__small {
    text-align: center;
}
.footer__small small {
  font-family: var(--outfit);
  font-weight: 400;
  font-size: var(--fz_20);
  letter-spacing: 0;
  text-transform: uppercase;
  font-size: 11px;
}


a.future-img,
a.partnership-img,
a.iso-img {
    width: auto;
    height: 121px;
    display: block;
}
a.future-img img,
a.partnership-img img,
a.iso-img img {
  height: 100%;
  object-fit: contain;
  vertical-align: bottom;
}

ul.footer__nav--list {
    display: flex;
    gap: 60px;
    justify-content: flex-end;/*0920追加*/
}
/* footer-navリンク下線アニメーション */
nav.f-nav.footer-nav {
    position: relative;
    margin-top: 38px;
}
.footer__nav--item a {
  position: relative;
  color: var(--wh);
  text-decoration: none;
  display: flex;
  padding: 0;
  line-height: 1;
  align-items: center;
  font-family: var(--outfit);
  font-weight: bold;
  text-transform: uppercase;
  font-size: clamp(13px, 1.1458vw, 22px);
}
.footer__nav--item a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -4px;/* 下線の位置 */
  width: 0;
  height: 2px;/* 下線の太さ */
  background-color: var(--wh); /* 下線の色 */
  transition: width 0.3s ease;
}
.footer__nav--item a:hover::after {
  width: 100%; /* 左から右に伸びる */
}
.footer__nav--item span {
  color: var(--wh);
}
/* ./ footer-navリンク下線アニメーション */

.footer__nav--item .nav-submenu {
    top: 2rem;
    left: 105px;
    width: max-content;
}
.footer__nav--item a .nav-submenu a {
    padding: 0;
}

/* 言語切り換え */
.footer__nav--lang a {
  text-decoration: none;
  color: var(--wh);
  padding: 0 4px;
}
.footer__nav--lang a.active {
  font-weight: bold;
  text-decoration: underline;
}
.footer__nav--lang .lang-separator {
  color: var(--wh);
  padding: 0 2px;
}
.footer__nav--item.footer__nav--lang a {
    font-size: clamp(13px, 1.1458vw, 20px);
}
/* ./ 言語切り換え */


/* li.footer__nav--item.has-submenu に active クラスが付いたときに背景色を変える */
/* 通常のサブメニューアイテム */
li.hfooter__nav--item.has-submenu {
  position: relative;
  background-color: transparent;
  transition: background-color 0.3s ease;
  z-index: 1;
}

li.footer__nav--item.has-submenu::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;/* 初期は0で非表示 */
  height: 100%;
  background-color: var(--bk);
  z-index: -1;/* テキストの下に表示 */
  transition: width 0.3s ease; /* 開閉時にアニメーション */
}

li.footer__nav--item.has-submenu.active::before {
  width: 100%;  /* activeのときに背景を広げる */
  height: 65px;
  top: -10px;
}
/* ./ li.footer__nav--item.has-submenu に active クラスが付いたときに背景色を変える */



p.footer__name,
p.footer__post,
p.footer__add {
  color: var(--wh);
  font-weight: 500;
  line-height: 1.66;
  letter-spacing: 0.03em;
  text-align: left;
}
p.footer__name {
  font-size: var(--fz_25);
  font-weight: bold;
  margin-top: 40px;
  margin-bottom: 10px;
}
p.footer__post,
p.footer__add {
  font-size: var(--fz_18);
  font-weight: 500;
}
.footer__privacy a {
    color: #8D8D8D;
    font-weight: bold;
    font-size: var(--fz_20);
    font-family: var(--outfit);
    letter-spacing: 0;
    margin-top: 48px;
    text-transform: uppercase;
    text-decoration: none;
}


.footer__nav--item .nav-submenu {
    left: auto;
}
.footer__nav--item .nav-submenu.active {
    width: max-content;
    z-index: 1;
}

.footer__nav--item.footer__nav--lang.forSp {
  display: none;
}
footer hr {
    padding: 0;
    margin: auto;
    max-width: 1720px;
}

    @media(max-width:768px){
    .service__footer .footer__inner {
    flex-direction: column;
    }
    .footer__nav--item.footer__nav--lang.forPc {
    display: none;
    }
    .footer__nav--item.footer__nav--lang.forSp {
    display: flex;
    align-items: center;
    }
    .footer__mark {
    align-items: start;
    gap: 28px;
    justify-content: end;
    margin-top: 35px;
    }
    .footer__logo {
    width: 166px;
    }
    p.footer__name {
    font-size: 14px;
    margin-top: 10px;
    margin-bottom: 0;
    }
    p.footer__post, p.footer__add {
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0;
    }
    .footer__nav--item .nav-submenu {
    left: auto;
    width: auto;
    }
    .footer__nav--item.footer__nav--lang a,
    span.lang-separator {
    font-size: 13px;
    }
    .footer__small {
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 0;
    }
    .footer__nav--item.footer__nav--lang.forSp {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 60px;
    }
    .footer__nav--item:last-of-type a {
    margin-right: 0;
    }
    .footer__privacy a {
    font-size: 14px;
    }
    .footer__privacy {
    margin-bottom: 14px;
    }
    .footer__mark {
    margin-top: 0;
    gap: 16px;
    }
    a.future-img, a.partnership-img, a.iso-img {
    height: 50px;
    }
    .footer__footer .c-contact {
    padding: 50px 5%;
    }
    .service__footer .footer__inner {
    padding: 40px 5% 0;
    }
    .footer__nav--item .nav-submenu {
        left: 7.5em;
        z-index: -1;
    }
  }

/*===============================
        footer__wh サービスページ
===============================*/
.service__footer {
background-image: url(../images/common/service-footer.png);
background-repeat: no-repeat;
background-size: cover;
padding-top: 70px;
}
.service__footer .footer__inner {
border-top: solid 1px var(--wh);
max-width: 1720px;
margin: 0 auto;
padding: 80px 5% 0;
display: flex;
justify-content: space-between;
}
.service__footer .nav-submenu {
background: #646464;
z-index: -1;
}
.footer__nav--item.footer__nav--lang a {
color: #fff;
text-decoration: none;
}


    @media(max-width:1024px){
      .footer__inner {
        flex-direction: column;
        padding-top: 40px;
    }
    }

        @media(max-width:768px){
          ul.footer__nav--list {
          gap: 20px 40px;
          max-width: 800px;
          margin: 0 auto;
          padding: 0;
          list-style: none;
          flex-wrap: wrap;
          justify-content: flex-start;
          }
          .footer__nav--item a {
          padding: 0;
          font-size: 15px;
          }
          .footer__nav--item {
          text-align: center;
          }
          li.footer__nav--item.has-submenu .toggle-icon {
          transition: transform 0.3s ease;
          width: 15px;
          height: 15px;
          margin: 0 0 0 10px;
          object-fit: contain;
          display: block;
          }
          li.footer__nav--item.has-submenu span.link-icon {
          width: 10px;
          height: 10px;
          margin-left: 10px;
          }
          .footer__nav--item.footer__nav--lang a:last-of-type {
          color: #B7B7B7;
          }
        }

        @media(max-width:425px){
        ul.footer__nav--list {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        }
        }

/*===============================
        comp__CONTACT
===============================*/
.c-contact {
    padding: 230px 5% 133px;
}
.c-contact__title .c-title::before {
  content: "お問い合わせ";
}
.c-contact__title p {
  font-size: var(--fz_22);
  letter-spacing: 0.03em;
  font-weight: 500;
}

.c-contact__item {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0;
  width: clamp(407px, 29.104vw, 557px);
  height: auto;

  /* 背景フィルター効果 */
  backdrop-filter: blur(30px) brightness(1.15);
  /* -webkit-backdrop-filter: blur(30px) brightness(1.15); */

  /* グラデーションを使いたい場合はこちらに差し替えもOK */
  background: linear-gradient(180deg, rgba(11, 11, 11, 0.7) 0%, rgba(11, 11, 11, 1) 50%, rgba(11, 11, 11, 0.7) 100%);
  backdrop-filter: contrast(0.1);
}


a.c-contact__item .c-contact__item {
background: transparent;
backdrop-filter: none;
margin-left: 10%;
width: clamp(337px, 23.958vw, 460px);
gap: 24px;
justify-content: flex-start;
margin-right: 108px;
}
a.c-contact__item {
display: flex;
align-items: center;
padding: 0;
text-decoration: none;
aspect-ratio: 557 / 169;
}
.c-contact__inner {
    display: flex;
    justify-content: space-between;
    max-width: 1720px;
    margin: 0 auto;
}
.c-contact__title {
    width: 30%;
}
.c-contact__list {
    display: flex;
    gap: 47px;
    margin-top: 32px;
}
.c-contact__icon {
    width: 14.2%;
    height: auto;
    margin-right: 20px;
    margin-left: 20px;
}
a.c-contact__item .c-contact__icon {
  margin: 0;
}
.c-contact__icon img {
  width: 100%;
  object-fit: contain;
  aspect-ratio: 1 / 1;
}
.c-contact__text h3,
a.c-contact__item .c-contact__text h3 {
  font-weight: bold;
  letter-spacing: 0.03em;
  color: var(--wh);
  text-decoration: none;
  font-size: clamp(16px, 1.1458vw, 22px);
}
.c-contact__text p,
a.c-contact__item .c-contact__text p {
  font-family: var(--outfit);
    font-size: var(--fz_40);
  font-weight: bold;
  letter-spacing: 0;
  color: var(--wh);
  text-decoration: none;
}

.c-contact__text h3,
.c-contact__text p {
  text-align: left;
}

a.c-contact__item .c-contact__text h3,
a.c-contact__item .c-contact__text p {
  text-align: center;
  align-items: center;
}
.c-contact__arrow {
    margin: auto 22px 18px 0;
}

a.c-contact__item.btn-arrow-img {
    position: relative;
}
a.c-contact__item.btn-arrow-img .arrow-box {
    display: inline-block;
    overflow: hidden;
    background: transparent;
    margin-right: 22px;
    margin-bottom: 18px;
    clip-path: polygon(100% 0, 100% 100%, 0 100%);
} 
a.c-contact__item.btn-arrow-img span.arrow-box {
    position: absolute;
    width: 86px;
    height: 86px;
    right: 0;
    bottom: 0;
}
a.c-contact__item.btn-arrow-img::after {
    position: absolute;
    content: "";
    bottom: -17px;
    right: 22px;
    height: 120px;
    width: 1px;
    background: #fff;
    transform-origin: right top;
    transform: rotate(45deg);
}
a.c-contact__item img.arrow.arrow-thin,
a.c-contact__item img.arrow.arrow-thick {
    width: 13px;
}
a.c-contact__item.btn-arrow-img:not(:hover) .arrow-thick {
    left: -10px;
    opacity: 0;
}
/* 初期の太い矢印（左外に配置） */
.c-contact__item .arrow-thick {
  left: -10px;
  opacity: 0;
  width: 12px;
  transition-delay: 0.05s; /* クロスフェードの順序調整 */
}

/* ホバー時に中央へスライドしつつフェードイン */
.c-contact__item.btn-arrow-img:hover .arrow-thick {
  opacity: 1;
  left: 50px;
}

/* ホバー解除時に左へ戻る */
.c-contact__item.btn-arrow-img:not(:hover) .arrow-thick {
  left: -10px;
  opacity: 0;
}

/* 背景変化 */
a.btn-arrow-img.c-contact__item:hover .arrow-box {
  background: #ffffff;
  border: none;
}


/* サービスページ */
.service__footer a.c-contact__item.btn-arrow-img::after,
.service__footer a.btn-arrow-img.c-contact__item:hover .arrow-box,
.service__footer .arrow-box::before,
.service__footer .arrow-box::after {
    background: #505050;
}


    @media(max-width:768px){
    a.c-contact__item.btn-arrow-img span.arrow-box {
    width: 43px;
    height: 43px;
    right: 0;
    bottom: 0;
    }
    a.c-contact__item.btn-arrow-img .arrow-box {
    margin-right: 10px;
    margin-bottom: 10px;
    }
    a.c-contact__item.btn-arrow-img::after {
    bottom: -7px;
    right: 10px;
    height: 59px;
    }
    a.c-contact__item img.arrow.arrow-thin,
    a.c-contact__item img.arrow.arrow-thick {
    width: 10px;
    }
    .c-contact__item.btn-arrow-img:hover .arrow-thick {
    left: 50%;
    }
    }



    @media(max-width:1220px){
      .c-contact__inner {
        flex-direction: column;
    }
    }
        @media(max-width:1024px){
          a.c-contact__list {
          justify-content: center;
          align-items: center;
          }
          .c-contact__list {
          justify-content: center;
          }
        }

            @media(max-width:768px){
              .c-contact__list {
              flex-direction: column;
              align-items: center;
              }
              .c-contact__inner {
              flex-direction: column;
              }
              a.c-contact__item {
              width: clamp(300px, 29.104vw, 560px);
              }
              .c-contact {
              padding: 100px 5% 90px;
              }
              .c-contact__title {
              width: 100%;
              }
              .c-contact__title p {
              font-size: 13px;
              letter-spacing: 0;
              }
              .c-contact__text p,
              a.c-contact__item .c-contact__text p {
              font-size: 30px;
              letter-spacing: 0.032em;
              }
              .c-contact__text h3,
              a.c-contact__item .c-contact__text h3 {
              letter-spacing: 0.02em;
              font-size: 16px;
              }
              .c-contact__arrow .btn-triangle {
              width: 42px;
              height: 42px;
              }
              .c-contact__arrow .btn-triangle::after {
              height: 56px;
              top: -7px;
              right: 20px;
              }
              a.c-contact__item,
              .c-contact__item {
              width: 100%;
              height: 115px;
              max-width: 350px;
              }
              .c-contact__arrow .btn-triangle .btn-arrow {
              right: -8px;
              bottom: -10px;
              }
              .footer__mark--wrap.forSp {
              margin-top: 35px;
              }
              .footer__mark--wrap.forSp {
              display: flex;
              align-items: flex-start;
              justify-content: space-between;
              }
              a.c-contact__item .c-contact__item {
              margin-right: 53px;
              }
            }

    /* service-page */
    .service__footer .c-contact {
        padding: 130px 5% 133px;
    }
    .service__footer .c-contact__item {
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 1) 50%, rgba(255, 255, 255, 0.2) 100%);
    }
    .service__footer .c-contact__text h3,
    .service__footer a.c-contact__item .c-contact__text h3,
    .service__footer .c-contact__text p,
    .service__footer a.c-contact__item .c-contact__text p {
        color: #505050;
    }

    @media(max-width:1190px){
      .c-contact__list {
        justify-content: center;
    }
    }

        @media(max-width:768px){
        .service__footer {
        background-image: url(../images/common/service-footer-sp.png);
        padding-top: 0;
        }
        .service__footer .c-contact__list {
        gap: 20px;
        }
        .service__footer .c-contact {
        padding: 100px 5% 50px;
        }
        }

/*===============================
        component--title
===============================*/
h2.c-title {
  font-family: var(--outfit);
    font-size: var(--fz_70);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 2;
    text-transform: uppercase;
}
h2.c-title::first-letter {
  color: var(--red);
}
.c-title:before {
    position: absolute;
    content: "";
    font-family: var(--Zen-Kaku-Gothic-New);
    font-size: clamp(13px, 1.1458vw, 22px);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1;
}
.service__footer .c-title:first-letter {
    color: #fff;
}
    @media(max-width:768px){
    h2.c-title {
    font-size: 35px;
    }
    .c-title:before {
    font-size: 11px;
    }
    .t-service__text p {
    font-size: 13px;
    }
    }

/* 複数 */
p.first-letter {
    margin-top: -0.5em;
    font-family: var(--outfit);
    font-size: var(--fz_70);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
}
p.first-letter::first-letter {
    color: var(--red);
}
h2.c-title.two-steps {
    white-space: nowrap;
}

/*===============================
        top-page__fv
===============================*/
/* ====
  page1
 ==== */
.page {
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.box {
  width: 400px;
  height: 400px;
  background: var(--wh);
}


/* フィルター */
.page.page1.snap {
  position: relative; /* 疑似要素を載せるために必要 */
  overflow: hidden;
}

.page.page1.snap::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none; /* クリック操作を邪魔しない */

  /* 下は黒透明、上は完全透明のグラデーション */
  background: linear-gradient(to top, rgba(0,0,0,0.6) 20%, rgba(0,0,0,0) 80%);
  
  z-index: -1;
}
/* ./ フィルター */

.fv-bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -3;
  height: 100vh;
  width: 100%;
  overflow: hidden;
}

.fv-bg picture {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
    z-index: -2;
}

.fv-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  vertical-align: bottom;
  opacity: 0; /* 最初は透明 */
}
.fv-video {
  position: fixed;
  z-index: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}
.fv-video.forPc {
    top: calc(100% + 250px);
}
.fv-video.forSp {
    display: none;
}

    @media(max-width:768px){
    .fv-video.forPc {
    display: none;
    }
    .fv-video.forSp {
    display: block;
    bottom: 0;
    }
    }


.fv-video dotlottie-wc {
width: 100%;
height: 100%;
left: 50%;
display: block;
position: relative;
transform: translate(-50%, -50%);
top: calc(100px + 50%);
z-index: -1;
}

        @media(max-width:768px){
        .fv-video dotlottie-wc {
        width: 100%;
        height: 100%;
        left: 50%;
        display: block;
        position: absolute;
        transform: translate(-50%, -50%);
        top: auto;
        bottom: -100px;
        }
        }


.page1 {
  display: flex;
  align-items: center;
  justify-content: center;
}

.content-box {
  width: 90%;
  position: absolute;
  z-index: 1;
  top: calc(50% - 2em);
  transform: translateY(-50%);
}

p.title1,
p.title2,
p.title3 {
  opacity: 0;
  font-size: var(--fz_170);
  text-transform: uppercase;
  line-height: 1;
  font-family: var(--outfit);
  font-weight: bold;
}

p.title1 {
  transform: translateX(100px);
  color: #5A93D8;
}

p.title2 {
  transform: translateX(200px);
  color: #FFFFFF;
}

p.title3 {
    transform: translateX(100px);
  color: #E54E4E;
  margin-left: 2.9em;
}
p.title4 {
  opacity: 0;
  transform: translateY(20px);
  color: #FFFFFF;
  font-size: var(--fz_30);
  text-align: left;
  width: 100%;
  display: flex;
  justify-content: flex-end;
  font-weight: bold;
  letter-spacing: 0;
  line-height: 1.66;
  position: absolute;
  width: 90%;
  margin-right: 5%;
  bottom: 60px;
}
.h-nav {
  opacity: 0;
}
p.title4.forSp {
    display: none;
}

/* PC __js */
.title4.forPc { display: flex; }
.title4.forSp { display: none; }

    @media(max-width:768px){
    p.title1, p.title2, p.title3 {
    font-size: clamp(50px, 1.4871vw, 58px);
    }
    p.title4.forSp {
    margin-top: 0;
    position: absolute;
    bottom: 0;
    left: 0;
    justify-content: normal;
    }

    /* SP __js */
    .title4.forPc {
    display: none;
    }
    .title4.forSp {
    display: block;
    }
    p.title4 {
    font-size: 18px;
    justify-content: flex-start;
    margin: auto;
    bottom: 35px;
    left: 5%;
    }
    }



/* ====
  page2
 ==== */
.page2 {
  position: relative;
  overflow: hidden;
}
.page2_flex {
  display: flex;
  width: 90%;
  justify-content: space-between;
  gap: 0;
  margin: 0 auto;
  align-items: end;
}
.page2_img--left {
  width: 22%;
}
.page2_img--right {
  width: 24%;
}
.page2_img--left img,
.page2_img--right img{
  width: 100%;
  object-fit: contain;
}
.page2_img.forSp {
    display: none;
}
.page2_title {
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  opacity: 0; /* 最初はテキストも透明 */
  width: 100%;
}
.page2_title h3 {
  font-family: var(--outfit);
  font-size: var(--fz_70);
  margin: 0;
}
.page2_title p {
  font-size: var(--fz_33);
  margin-top: 18px;
}
.page2_text p {
  color: #FFFFFF;
  font-size: clamp(13px, 1.1458vw, 22px);
  line-height: 1.8;
  letter-spacing: 0.03em;
  font-weight: 500;
}
.page2_text p:nth-child(2) {
  margin-top: 40px;
}
.page2_text {
  text-align: center;
  width: 50%;
  margin: 40px auto 90px;
}

.page2_text .btn__more {
  margin-top: 90px;
  display: inline-flex;
}
.page2 .box {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 1); /* 黒背景 */
  opacity: 0; /* 最初は透明 */
  z-index: 0;
}



/* 初期状態を非表示で少し下にずらす */
.page2_title {
  opacity: 0;
  transform: translateY(50px);
}
.page2_flex {
  opacity: 0;
  transform: translateY(50px);
}

    @media(max-width:768px){
    .page2_wrap {
    padding-top: 80px;
    }
    .page.page2.snap {
    display: contents;
    }
    .page2_title h3 {
    font-family: var(--outfit);
    font-size: 36px;
    margin: 0;
    }
    .page2_title p {
    font-size: 18px;
    }
    .page2_text {
    width: 100%;
    margin: 26px auto;
    }
    .page2_text p {
    font-size: 13px;
    }
    .page2_flex {
    width: 100%;
    gap: 0;
    }
    .page2_text .btn__more {
    margin-top: 28px;
    }
    .page2_img--left,
    .page2_img--right {
    display: none;
    }
    .page2_flex {
    flex-direction: column;
    }
    .page2_img.forSp {
    display: block;
    margin: 0 5%;
    display: block;
    width: 90%;
    }
    }

    @media(max-width:375px){
    .page2_title p {
    font-size: 16px;
    }
    }


/*===============================
        top-page__SERVICE
===============================*/
.t-service {
  color: #fff;
  padding: 200px 0 0;
  background-color: var(--bk);
}
.t-service__title--inner {
    padding: 0 5%;
}
.t-service__flex {
    display: flex;
    max-width: 1720px;
    margin: 0 auto;
}
.t-service__flex .c-title {
    width: 40%;
}
.t-service__flex .c-title::before {
    content: "事業内容";
}
.t-service__flex .t-service__text {
    width: 60%;
    margin-top: 26px;
}
.t-service__text h3 {
  font-family: var(--Zen-Kaku-Gothic-New);
  font-size: var(--fz_33);
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.033em;
  text-align: left;
}
.t-service__text p {
  font-family: var(--Zen-Kaku-Gothic-New);
  font-size: var(--fz_22);
  font-weight: 500;
  line-height: 1.63;
  letter-spacing: 0.03em;
  text-align: left;
  margin-top: 18px;
}

@media(max-width:768px){
.t-service {
padding: 100px 0 0;
}
.t-service__flex {
flex-direction: column;
}
.t-service__flex .c-title {
    width: 100%;
}
.t-service__flex .t-service__text {
    width: 100%;
    margin-top: 11px;
}
.t-service__text h3 {
    font-size: 23px;
    letter-spacing: 0;
}
.t-service__text p {
    font-size: 13px;
    margin-top: 20px;
    letter-spacing: 0;
}
}


/* swiper */
.t-service__swiper {
    margin-top: 60px;
}

/* スライドの動き等速 */
.swiper-wrapper {
    transition-timing-function: linear;
}
.t-service__swiper a.btn-arrow-img::after {
  bottom: -11px;
  right: 10px;
  height: 70px;
}

@media(max-width:768px){
  .t-service__swiper {
    margin-top: 35px;
}
.swiper-overlay {
    display: none;
}
.t-service__swiper a.btn-arrow-img::after {
  bottom: -11px;
  right: 10px;
  height: 70px;
}
}


/* swiper-画像zoom */
/* 親リンクに overflow:hidden */
.t-service .btn-arrow-img {
  display: block;      /* ブロック化して幅いっぱいに */
  overflow: hidden;    /* 画像がはみ出さないように */
  position: relative;  /* 矢印や他要素の重なり用 */
}

/* 画像ズーム */
.t-service .zoom-img {
  transition: transform 0.3s ease;
}

.t-service .btn-arrow-img:hover .zoom-img {
  transform: scale(1.1);
}
/* ./ swiper-画像zoom */


/*===============================
        top-page__PRODUCTS
===============================*/
.t-products {
  padding: 170px 5% 0;
  background-color: var(--bk);
}
.t-products__inner {
    max-width: 1720px;
    margin: 0 auto;
}
.t-products__inner .btn__more {
    margin-top: 26px;
    display: inline-flex;
}
.t-products__inner .c-title::before {
content: "製品案内";
}
.t-products__text h3 {
    font-size: var(--fz_33);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;
}
.t-products__text p {
    font-size: var(--fz_22);
    font-weight: 500;
    letter-spacing: 0.03em;
    line-height: 1.63;
    margin-top: 30px;
}

.c-products__item {
    display: block;
    text-decoration: none;
    color: inherit;
    padding: 0;
    transition: background-color 0.3s ease;
    background-color: rgba(110, 110, 110, 0.53);
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(0px);
}

.clip {
  width: 309px;
  height: 300px;
  position: relative;
}
.clip-arrow {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 2;
}
.t-products__lists .btn-triangle::before {
    content: "";
    position: absolute;
    inset: 0;
    clip-path: polygon(0 100%, 100% 100%, 100% 0);
    border: 1px solid var(--wh);
    background: var(--bk);
    transition: all 0.3s ease;
    z-index: 0;
}
.t-products__icon {
    width: 34px;
    margin: 0 auto;
    padding-top: 16px;
}
.t-products__icon img {
  width: 100%;
  object-fit: contain;
  vertical-align: bottom;
}
h5.t-products__subTtl {
    text-align: center;
    font-size: var(--fz_40);
    font-weight: bold;
    font-family: var(--outfit);
    letter-spacing: 0;
    color: rgba(255, 255, 255, 0.1);
    padding: 0 10px;
    white-space: nowrap;
}
h4.t-products__h4 {
    text-align: center;
    font-size: var(--fz_25);
    font-weight: bold;
    letter-spacing: 0.03em;
    margin-top: -1.2em;
    padding: 0 10px;
}
p.t-products__p {
  text-align: left;
  font-size: var(--fz_18);
  font-weight: 500;
  line-height: 1.66;
  letter-spacing: 0.03em;
  margin: 20px auto 30px;
  padding: 0 15%;
}
.t-products__flex {
    display: flex;
    justify-content: space-between;
}
.t-products__text {
    width: 40%;
}
.t-products__lists {
    width: 60%;
    display: flex;
    gap: 2%;
    justify-content: space-between;
}

    @media(max-width:1024px){
    .t-products__flex {
    flex-direction: column;
    }
    .t-products__text {
    width: 100%;
    }
    .t-products__lists {
    width: 100%;
    margin-top: 36px;
    }
    }

    @media(max-width:820px){
    .t-products__lists {
    flex-direction: column;
    align-items: center;
    gap: 16px;
    margin-top: 36px;
    width: 100%;
    }
    .t-products {
    padding: 100px 5% 0;
    background-color: var(--bk);
    }
    .t-products__text h3 {
    font-size: 23px;
    }
    .t-products__text p {
        font-size: 13px;
        font-weight: 500;
        letter-spacing: 0;
        line-height: 1.5;
        margin-top: 30px;
    }
    .t-products__text {
    width: 100%;
    }
    .c-products__list {
        display: flex;
    }
    .clip {
        aspect-ratio: 350 / 142;
        width: 100%;
        height: auto;
    }
    h5.t-products__subTtl {
        text-align: left;
        font-size: 30px;
        padding: 0;
    }
    h4.t-products__h4 {
        text-align: left;
        font-size: 18px;
        letter-spacing: 0;
        margin-top: -1em;
        padding: 0;
    }
    p.t-products__p {
        text-align: left;
        font-size: 12px;
        line-height: 1.5;
        margin: 10px auto 0 0;
        padding: 0;
        width: calc(100% - 80px);
    }
    .t-products__icon {
        width: 60px;
        padding-top: 30px;
    }
    .t-products__ttlWrap {
        width: calc(100% - 60px);
    }
    .t-products__icon img {
        width: 30px;
        margin-left: 15px;
    }
    a.c-products__item.clip::after {
    z-index: -1;
    height: 150px;
    position: absolute;
    content: "";
    border: solid 10px var(--bk);
    transform: rotate(45deg);
    bottom: -79px;
    right: -18px;
    }
    a.c-products__item.clip.btn-arrow-img {
        padding-bottom: 30px;
    }
    }


/*===============================
        top-page__products btn
===============================*/
a.c-products__item.clip.btn-arrow-img {
    width: 309px;
    height: auto;
}
.c-products__item.btn-arrow-img {
  align-items: end;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
  justify-content: space-between;
  border: none;
}
a.btn-arrow-img.c-products__item {
    font-size: var(--fz_30);
    font-weight: bold;
}
.c-products__item .arrow-box {
position: absolute;
right: 0;
bottom: 0;
width: 82px;
height: 82px;
overflow: hidden;
clip-path: polygon(0 100%, 100% 100%, 100% 0);
border: 1px solid var(--wh);
background: var(--bk);
transition: background 0.3s ease, border 0.3s ease;
z-index: 0;
margin-right: 0;
margin-bottom: 0
}

a.c-products__item.clip::after {
    height: 130px;
    position: absolute;
    content: "";
    border: solid 1px var(--wh);
    transform: rotate(45deg);
    bottom: -50px;
    right: -1px;
    z-index: 0;
}
/* 斜め線の下*/
a.c-products__item.clip::before {
    height: 140px;
    position: absolute;
    content: "";
    border-right: solid 10px #000000;
    transform: rotate(45deg);
    right: 40px;
    bottom: -24px;
    z-index: -1;
}

/* 下の線 */
.c-products__item .arrow-box::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fff;
}

/* 斜めの線（右上 → 左下） */
a.btn-arrow-img::after {
  position: absolute;
  content: "";
  bottom: 10px;
  right: 30px;
  height: 70px;
  width: 1px;
  background: #fff;
  transform-origin: right top;
  transform: rotate(45deg);
}


/* 共通設定 */
.c-products__item .arrow {
  position: absolute;
  transition: left 0.4s ease, opacity 0.4s ease;
  bottom: 20px;
}

/* 初期の細い矢印（中央表示） */
.c-products__item .arrow-thin {
  opacity: 1;
  width: 13px;
  left: 60px;
}

/* ホバー時に右へ抜けながらフェードアウト */
.c-products__item.btn-arrow-img:hover .arrow-thin {
  left: 120%;
  opacity: 0;
}

.c-products__item img.arrow.arrow-thin {
    width: 13px;
}
.c-products__item img.arrow.arrow-thick {
    width: 13px;
}

/* 初期の太い矢印（左外に配置） */
.c-products__item .arrow-thick {
  left: -20px;
  opacity: 0;
  width: 12px;
  transition-delay: 0.05s; /* クロスフェードの順序調整 */
}

/* ホバー時に中央へスライドしつつフェードイン */
.c-products__item.btn-arrow-img:hover .arrow-thick {
  opacity: 1;
  left: 50px;
}

/* ホバー解除時に左へ戻る */
.c-products__item.btn-arrow-img:not(:hover) .arrow-thick {
  left: -20px;
  opacity: 0;
}

/* 背景変化 */
a.btn-arrow-img.c-products__item:hover .arrow-box {
  background: #ffffff;
  border: none;
}

    @media(max-width:768px){
    a.c-products__item.clip.btn-arrow-img {
    width: 100%;
    height: auto;
    max-width: 400px;
    aspect-ratio: auto;
    }
    .c-products__item .arrow-box {
    width: 66px;
    height: 66px;
    }
    a.c-products__item.clip::after {
    height: 140px;
    bottom: -50px;
    right: -25px;
    }
    a.c-products__item.clip::before {
    height: 140px;
    right: 40px;
    bottom: -40px;
    }
    .c-products__item.btn-arrow-img:hover .arrow-thick {
    left: 40px;
    }
    .c-products__item .arrow-thin {
    left: 46px;
    }
    }



/*===============================
        top-page__NEWS
===============================*/
.t-news {
padding: 277px 5% 0;
}
.t-news__title--flex {
display: flex;
justify-content: space-between;
align-items: end;
}
.t-news__title--flex .c-title::before {
content: "お知らせ";
}

.t-news__inner {
max-width: 1720px;
margin: 0 auto;
}
.t-news__list {
display: grid;
gap: 33px;
margin-top: 52px;
}
.c-news__item {
-webkit-backdrop-filter: blur(0px);
background: linear-gradient(180deg, rgb(11 11 11 / 53%) 0%, rgb(11 11 11) 50%, rgb(11 11 11 / 53%) 100%);
backdrop-filter: contrast(0.7);
}
p.c-news__time {
font-family: var(--outfit);
color: var(--wh);
font-size: var(--fz_22);
font-weight: 500;
line-height: 1.5;
letter-spacing: 0;
text-align: left;
}
span.c-news__tag {
display: inline-flex;
align-items: center;
font-size: var(--fz_16);
font-weight: 400;
letter-spacing: 0.03em;
background-color: #535353;
border-radius: 18px;
color: var(--wh);
padding: 1px 33px;
margin-left: 52px;
}
.c-news__text {
font-size: var(--fz_25);
font-weight: 400;
line-height: 1.6;
letter-spacing: 0.03em;
color: var(--wh);
margin: 18px auto 18px 0;
}

.c-news__list--flex {
    margin: 25px 0 25px 50px;
    width: calc(100% - 186px);
}
.service-history_select-item h5 {
  font-family: var(--outfit);
    font-size: var(--fz_25);
    font-weight: bold;
    letter-spacing: 0;
}

    @media(max-width:768px){
      .t-news {
      padding: 120px 5% 0;
      }
      .t-news__list {
      gap: 15px;
      margin-top: 36px;
      }
      p.c-news__time {
      font-size: 11px;
      }
      span.c-news__tag {
      font-size: 11px;
      letter-spacing: 0;
      padding: 1px 17px;
      margin-left: 20px;
      }
      .c-news__text {
      font-size: 13px;
      letter-spacing: 0;
      margin: 11px auto 11px 0;
      }
      .t-news__inner .btn__more.forSp a {
      justify-content: end;
      margin-top: 10px;
      }
      .t-news__inner .btn__more.forSp {
      display: block;
      }
      .t-news__title--flex .btn__more.forPc {
      display: none;
      }
      .service-history_select-item h5 {
      font-size: 13px;
      }
    }


/* ----------------------------
  △ → ボタン
-------------------------------- */
a.c-news__item.btn-arrow-img {
    position: relative;
}
a.c-news__item .c-news__tag--flex {
    display: flex;
}
a.c-news__item .arrow-box {
    z-index: 7;
    display: block;
    width: 86px;
    height: 86px;
    position: absolute;
    overflow: hidden;
    background: transparent;
    margin-right: 50px;
    margin-bottom: 20px;
    clip-path: polygon(100% 0, 100% 100%, 0 100%);
    right: 0;
    bottom: 0;
}
a.c-news__item .arrow-box::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 1px;
    height: 100%;
    background: #fff;
}
/* 右の線 */
a.c-news__item.clip::after {
  height: 136px;
  position: absolute;
  content: "";
  border-right: solid 11px var(--wh);
  transform: rotate(45deg);
  bottom: -70px;
  right: -17px;
  z-index: -1;
}


/* 下の線 */
.c-news__item .arrow-box::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fff;
}

/* 斜めの線（右上 → 左下） */
a.c-news__item.btn-arrow-img::after {
  position: absolute;
  content: "";
  bottom: -15px;
  right: 50px;
  height: 120px;
  width: 1px;
  background: #fff;
  transform-origin: right top;
  transform: rotate(45deg);
}


/* 共通設定 */
.c-news__item .arrow {
  position: absolute;
  transition: left 0.4s ease, opacity 0.4s ease;
  bottom: 20px;
}

/* 初期の細い矢印（中央表示） */
.c-news__item .arrow-thin {
  opacity: 1;
  width: 13px;
  left: 60px;
}

/* ホバー時に右へ抜けながらフェードアウト */
.c-news__item.btn-arrow-img:hover .arrow-thin {
  left: 120%;
  opacity: 0;
}

.c-news__item img.arrow.arrow-thin {
    width: 13px;
}
.c-news__item img.arrow.arrow-thick {
    width: 13px;
}

/* 初期の太い矢印（左外に配置） */
.c-news__item .arrow-thick {
  left: -20px;
  opacity: 0;
  width: 12px;
  transition-delay: 0.05s; /* クロスフェードの順序調整 */
}

/* ホバー時に中央へスライドしつつフェードイン */
.c-news__item.btn-arrow-img:hover .arrow-thick {
  opacity: 1;
  left: 50px;
}

/* ホバー解除時に左へ戻る */
.c-news__item.btn-arrow-img:not(:hover) .arrow-thick {
  left: -20px;
  opacity: 0;
}

/* 背景変化 */
a.btn-arrow-img.c-news__item:hover .arrow-box {
  background: #ffffff;
  border: none;
}

time.c-news__time {
    font-family: var(--outfit);
    color: var(--wh);
    font-size: var(--fz_22);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0;
    text-align: left;
}


@media(max-width:768px){
  a.c-news__item .arrow-box {
    width: 33px;
    height: 33px;
    margin-right: 10px;
    margin-bottom: 8px;
}
a.c-news__item.btn-arrow-img::after {
    bottom: -5px;
    height: 45px;
    right: 10px;
}
.c-news__item img.arrow.arrow-thin,
.c-news__item img.arrow.arrow-thick {
    width: 10px;
}
.c-news__item .arrow-thin {
    left: 22px;
}
.c-news__item.btn-arrow-img:hover .arrow-thick {
    left: 17px;
}
.c-news__list--flex {
    margin: 16px 10px 8px 20px;
    width: calc(100% - 50px);
}
}


.btn__more.forSp {
    display: none;
}

    @media(max-width:768px){
    .btn__more.forSp {
    display: block;
    }
    .btn__more.forPc {
    display: none;
    }

    .c-news__list {
        width: calc(100% - 20px);
    }
    }


/* ===================
  service__footer用
  =================== */
/* 通常時：グレー */
.service__footer .btn-triangle::before {
    border: 1px solid #505050;
}
.service__footer .btn-triangle::after,
.service__footer .btn-arrow::before,
.service__footer .btn-arrow::after,
.service__footer .btn-arrow {
    background: #505050;
}

/* ホバー時：白に反転 */
/* a.c-contact__item を hover した時に矢印を白く */
.service__footer a.c-contact__item:hover .btn-arrow,
.service__footer a.c-contact__item:hover .btn-arrow::before,
.service__footer a.c-contact__item:hover .btn-arrow::after {
    background: #fff;
}

/* 枠も hover で色を変えたいなら */
.service__footer a.c-contact__item:hover .btn-triangle::before {
    background: #505050;
}
/* ./ .service__footer用 */


/* 白矢印（初期表示） */
.btn-arrow .arrow-white {
  background: var(--wh);
  transition: transform 0.3s ease, opacity 0.3s ease;
}

/* 白矢印の先端 */
.btn-arrow .arrow-white::before,
.btn-arrow .arrow-white::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 1px;
  background: var(--wh);
  top: 0;
  right: 0;
  transform-origin: right center;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.btn-arrow .arrow-white::before {
  transform: rotate(45deg);
}
.btn-arrow .arrow-white::after {
  transform: rotate(-45deg);
}

/* hoverで白矢印 → 右に抜けながらフェードアウト */
.btn-triangle:hover .arrow-white,
.c-news__item:hover .btn-triangle .arrow-white {
  transform: translateX(20px);
  opacity: 0;
}

/* ========== 黒矢印 ========== */
.btn-arrow .arrow-black {
  background: var(--bk);
  opacity: 0;
  left: -20px; /* 初期は左に隠す */
  transition: transform 0.3s ease, opacity 0.3s ease, left 0.3s ease;
}

/* 黒矢印の先端 */
.btn-arrow .arrow-black::before,
.btn-arrow .arrow-black::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 1px;
  background: var(--bk);
  top: 0;
  right: 0;
  transform-origin: right center;
}

.btn-arrow .arrow-black::before {
  transform: rotate(45deg);
}
.btn-arrow .arrow-black::after {
  transform: rotate(-45deg);
}

/* hoverで黒矢印 → 左からスライドイン */
.btn-triangle:hover .arrow-black,
.c-news__item:hover .btn-triangle .arrow-black {
  left: 0;
  opacity: 1;
}
/* ./ △ → ボタン */

/*===============================
        top-page__RECRUIT
===============================*/
#t-recruit {
    margin-top: 245px;
    background-color: var(--bk);
}
.t-recruit__container {
    position: relative;
    height: 100vh;
    overflow: hidden;
}
.t-recruit__img {
    position: absolute;
    z-index: 0;
    width: 100%;
    height: 100%;
    left: 50%;
    top: 0; /* 画面上端に固定 */
    transform: translateX(-50%) scale(1);
}
.t-recruit__img::after {
    position: absolute;
    content: "";
    inset: 0;
    background-color: #0B0B0B;
    opacity: 0.5;
    mix-blend-mode: multiply;
    pointer-events: none;
}
.t-recruit__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.t-recruit__text {
    position: absolute;
    z-index: 1;
    left: 50%;
    top: 50%;
    transform: translateX(-50%) translateY(100px); /* 下からスタート */
    opacity: 0;
    text-align: center;
    color: #fff;
    width: 74%;
    max-width: 1133px;
    width: 100%;
}
.t-recruit__text .c-title::before {
  content: "採用情報";
  left: 50%;
  transform: translateX(-50%);
}

.t-recruit__text h3 {
  font-size: var(--fz_70);
  font-family: var(--outfit);
  font-weight: bold;
  letter-spacing: 0;
  line-height: 1.5;
}
.t-recruit__text h4 {
  font-size: var(--fz_33);
  font-weight: bold;
  letter-spacing: 0;
  line-height: 1.5;
  margin-top: 15px;
}
.t-recruit__text p {
  font-size: var(--fz_22);
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.5;
  margin-top: 1.5em;
  width: 100%;
}

.t-recruit__text .t-recruit__btn-external {
  margin-top: 70px;
}

    @media(max-width:768px){
      #t-recruit {
        margin-top: 100px;
    }
    .t-recruit__text h3 {
        font-size: 30px;
    }
    .t-recruit__text {
        width: 100%;
    }
    .t-recruit__text h4 {
        font-size: 17px;
        margin-top: 7px;
    }
    .t-recruit__text p {
        font-size: 13px;
        letter-spacing: 0;
        margin-top: 25px;
    }
    .t-recruit__btn-external a {
        font-size: 20px;
        padding: 0;
        width: 100%;
        height: 100%;
    }
    .t-recruit__text .t-recruit__btn-external {
        width: 218px;
        margin-top: 40px;
        height: 46px;
    }
    }

    @media (max-width: 390px) {
    .t-recruit__text h3 {
      font-size: 29px;
    }
    }


/*===============================
        company-page__下へ移動
===============================*/


/*===============================
        service-page__mv--共通
===============================*/
.service__mv {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.service__mv--inner {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
}
.service__mv--clip {
    height: 1025px;
    position: relative;
}
.service__mv--clip::after {
    z-index: -1;
    position: absolute;
    content: url(../images/common/pc-shape.svg);
    width: 95vw;
    bottom: -30px;
    right: 0;
}
.service__mv--wave {
    margin: 0;
    padding: 0;
    width: 100%;
    overflow: hidden;
    height: 100vh; /* 画面いっぱいに広げる */
    position: relative;
}

/* 擬似要素でフィルターを重ねる */
.service__mv--wave::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none; /* クリックイベントをvideoに通す */
  z-index: -1;
}
.service-sensor .service__mv--wave::before {
  background-color: rgba(116, 162, 216, 0.12);
}
.service-dmah .service__mv--wave::before {
  background-color: rgba(44, 47, 174, 0.08);
}
.service-research .service__mv--wave::before {
  background-color: rgba(229, 78, 78, 0.08);
}
.service-medical .service__mv--wave::before {
  background-color: rgba(173, 143, 143, 0.15);
}

.service__mv--wave video {
    position: fixed;
    z-index: -2;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100vw;
    object-fit: cover;
}
.service__mv-text--inner {
    position: absolute;
    z-index: 10;
    bottom: 50px;
    left: 50%;
    width: 90%;
    transform: translateX(-50%);
    padding: 0 5%;
}
.service__mv-text--wrap {
    max-width: 1720px;
    margin: 0 auto;
}
a.play-video {
    position: absolute;
    bottom: 100px;
    right: 5%;
    z-index: 10;
}

a.play-video dotlottie-player {
  width: 140px;
  height: 140px;
}

    @media(max-width:768px){
    .service__mv a.play-video {
        bottom: 260px;
        right: 20px;
    }

    }





.service__mv--shape {
    height: 100vh;
    width: 100vw;
    object-fit: cover;
}
.service__mv--video {
    position: relative;
    width: 100vw;
}
.service__mv-ttl {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    padding: 0 5%;
    left: 10%;
    max-width: 1720px;
    width: 80%;
}
.clipped video {
    height: 100%;
    object-fit: cover;
    display: block;
    -webkit-clip-path: url(#clip-shape);
    clip-path: url(#clip-shape);
    width: 95vw;
    margin-left: 5vw;
    position: relative;
    z-index: 2;
    aspect-ratio: 1880 / 1030;
    max-width: 95vw;
  }
  .service__mv--clip.forSp {
    display: none;
  } 

@media(max-width:768px){
  .clipped video {
      height: 100%;
      object-fit: cover;
      display: block;
      -webkit-clip-path: url(#clip-shape-sp);
      clip-path: url(#clip-shape-sp);
      width: 95vw;
      margin-left: 5vw;
      position: relative;
      z-index: 2;
      aspect-ratio: 1880 / 1030;
      max-width: 95vw;
  }
    .service__mv--clip.forPc {
    display: none;
    }
    .service__mv--clip.forSp {
    display: block;
    }

}




.service__mv--video::before {
  position: absolute;
  content: url(../video/shape.svg);
  top: 0;
  right: 0;
  width: 95%;
  height: 100%;
}

.service__mv--video .service__mv--ttl {
  position: absolute;
  top: 50%;
  left: 15%;
  transform: translateY(-50%);
  z-index: 3;
  text-align: left;
  color: #fff;
}
.service__mv--video h2 {
    font-size: 97px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.42;
    display: inline;
    text-decoration-line: underline;
    text-decoration-color: rgba(90, 147, 216, 0.8);
    text-decoration-thickness: 32px;
    text-underline-offset: -10px;
}
.service-dmah .service__mv-ttl h2 {
    text-decoration-color: rgba(44, 47, 174, 0.8);
}
.service-research .service__mv-ttl h2 {
    text-decoration-color: rgba(229, 78, 78, 0.8);
}
.service-medical .service__mv-ttl h2 {
    text-decoration-color: rgba(188, 46, 46, 0.8);
}

.service__mv--video h2::first-letter {
  color: var(--wh);
}
.service__mv--video h2 span {
  font-size: 64px;
}
.text-wrap h2 span:first-of-type {
    margin-left: 100px;
}
.bredcrumb__wrap .bredcrumb {
    position: static;
    max-width: 1720px;
    margin: 0 auto;
}
.bredcrumb a {
    color: #A0A0A0;
    font-weight: 500;
    text-decoration: none;
    font-size: var(--fz_18);
}
.bredcrumb span.separator {
    margin: 0 14px;
    color: #A0A0A0;
}
.bredcrumb .active {
    text-transform: uppercase;
    font-size: var(--fz_18);
}
.service__mv-ttl--wrap {
    position: absolute;
    padding: 0;
    bottom: 0;
    left: 0;
    z-index: 10;
    width: 100%;
}

    @media(max-width:768px){
      .bredcrumb span.separator {
        margin: 0 10px;
    }
    .bredcrumb a,
    .bredcrumb .active {
    font-size: 10px;
    }
    }

.service__mv--inner .bredcrumb__wrap {
position: absolute;
padding: 0 5%;
bottom: calc(-3vh - 2em );
right: 0;
z-index: 10;
width: 100%;
}

.service__mv--ttl {
  position: absolute;
  top: 50%;
  left: 15%;
  transform: translateY(-50%);
  z-index: 3;
  text-align: left;
  color: #fff;
}
.service__mv-ttl h2 {
    font-size: var(--fz_97);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.42;
    display: inline;
    text-decoration-line: underline;
    text-decoration-color: rgba(90, 147, 216, 0.8);
    text-decoration-thickness: .4em;
    text-underline-offset: -.15em;
}
.service__mv-ttl h2 span {
  font-size: var(--fz_64);
}


.service__mv--shape img {
    width: 100%;
    max-width: 100%;
    width: 95vw;
    margin-left: 5vw;
}
.service__mv--shape img {
    display: none;
}

/* 見出しの二段目 */
span.service-sensor__mv-ttl--span {
    margin-left: 1em;
}
span.service-dmah__mv-ttl--span {
    margin-left: 3em;
}
h2.service-reserch__mv-ttl--span {
    margin-left: 1em;
}
h2.service-medical__mv-ttl--span {
    margin-left: 1.5em;
}

.service__mv--video {
  position: relative;
  width: 100%;
  height: 100vh; /* ← 高さは画面全体にする場合 */
}

.clipped {
  width: 100%;
  height: 100%;
}




.clip-me{
clip-path: url(#clip-shape);
}
@media(max-width:768px){
  .clip-me{
  clip-path: url(#clip-shape);
}
}

/*===============================
      下層service-page__共通 lity
===============================*/
.lity {
    z-index: 10003;
}

/*===============================
      下層service-page__共通
===============================*/
.service__mv--inner h3 {
    font-size: var(--fz_64);
    color: var(--bk);
    font-weight: bold;
    max-width: 1720px;
    margin: 0 auto;
}
.service__mv--inner h3 span {
    display: block;
    font-size: var(--fz_24);
    color: var(--bl);
    font-weight: bold;
    text-transform: uppercase;
}
.service-dmah .service__mv--inner h3 span {
    color: var(--dmah);
}
.service-research .service__mv--inner h3 span {
    color: var(--research);
}
.service-medical .service__mv--inner h3 span {
    color: var(--medical);
}


.s-about,
.s-strengths,
.s-achievements,
.s-business {
    color: #505050;
}
.s-about__inner,
.s-strengths__inner,
.s-achievements__inner,
.s-business__inner {
    max-width: 1670px;
    margin: 0 auto;
}
h2.c-service__title {
    font-size: 45px;
    margin-top: 23px;
}
h2.c-service__title::first-letter,
h2.c-service__title {
  color: #505050;
  font-size: var(--fz_45);
  font-weight: bold;
  line-height: 1.44;
  letter-spacing: 0;
  text-align: left;
}
.service-medical .s-about__text .c-service__title {
    white-space: nowrap;
}
h3.c-service__subTitle {
    font-family: var(--Jost);
    color: rgba(64, 64, 64, 0.3);
    font-weight: 500;
    letter-spacing: 0em;
    text-align: left;
    text-transform: uppercase;
    position: relative;
    margin-left: 3em;
    font-size: var(--fz_30);
}
h3.c-service__subTitle::before {
  position: absolute;
  content: "";
  border-bottom: solid 1px rgba(64, 64, 64, 0.3);
  width: 3.26em;
  top: 50%;
  left: -4em;
}
.s-strengths__titleWrap p.c-service__text {
  line-height: 1.52;
  margin-top: calc(23px + var(--fz_30) * 1.5);
  font-size: var(--fz_23);
  width: 55%;
  margin-right: 5%;
}
.service__mv-text--inner .bredcrumb {
  letter-spacing: 0.03em;
  color: #4E4E4E;
  font-weight: bold;
}
.service__mv-text--inner .bredcrumb .active {
  color: var(--bk);
  font-weight: bold;
}
.service__mv-text--inner .bredcrumb hr {
    border-top: solid 1px #4E4E4E;
}
.service-dmah .service__mv--inner h3 {
    margin: 0 auto -1em;
}

    @media(max-width:768px){
    .service__mv--inner h3 {
    font-size: 33px;
    position: absolute;
    bottom: 30px;
    left: 20px;
    z-index: 10;
    }
    .service__mv--video h2 {
    font-size: 40.7px;
    text-decoration-thickness: 20px;
    }
    .service__mv--video h2 span {
    font-size: 35px;
    }
    .service__mv-ttl {
    left: 0;
    width: 100%;
    }
    .service__mv--inner h3 span {
    font-size: 10px;/*12*/
    white-space: nowrap;
    letter-spacing: 0;
    }
    h3.c-service__subTitle {
    text-align: right;
    }
    li.s-achievements__item p {
    font-weight: 400;
    font-size: 12px;
    letter-spacing: 0;
    margin-top: 15px;
    }

    section.s-strengths h3.c-service__subTitle,
    section.s-business h3.c-service__subTitle {
    text-align: left;
    margin-left: 0;
    }
    section.s-about h3.c-service__subTitle::before,
    section.s-achievements h3.c-service__subTitle::before {
    right: 8.5em;
    width: 2em;
    left: auto;
    }
    .service__mv--video h2 {
    font-size: 43px;
    text-decoration-thickness: 20px;
    }
    .service__mv--video h2 span {
    font-size: 31px;
    }
    h2.service-medical__mv-ttl--span {
    margin-left: 0;
    }
    span.service-dmah__mv-ttl--span {
    margin-left: 2em;
    }
    h2.service-reserch__mv-ttl--span {
    margin-left: .5em;
    }
    }

    @media(max-width:425px){
      .service__mv--video h2 {
        font-size: 41px;
        text-decoration-thickness: 20px;
    }
    }


/*===============================
        service-page__ABOUT SERVICE
===============================*/
.s-about {
    padding: 155px 5% 0;
}
.s-about__inner {
    display: flex;
    justify-content: space-between;
}
.s-about__text h3.c-service__subTitle {
    text-align: right;
    width: 8em;
    margin-left: auto;
}
.s-about__text {
    width: 41%;
    margin: 0 4% 0 8%;
}
.s-about__img {
    width: 47%;
}
.s-about__img img {
  width: 100%;
  object-fit: contain;
  vertical-align: bottom;
}
p.c-service__text {
    margin-top: 36px;
    line-height: 1.52;
    font-size: var(--fz_23);
    font-weight: 500;
    letter-spacing: 0;
}

@media(max-width:768px){
  .s-about {
    padding: 40px 5% 0%;
}
  .s-about__inner {
    flex-direction: column;
}
.s-about__img {
    width: 100%;
}
.s-about__text {
    width: 100%;
    margin: 0 auto;
}
.s-about__text h3.c-service__subTitle,
.s-strengths h3.c-service__subTitle,
.s-achievements h3.c-service__subTitle,
.s-business h3.c-service__subTitle {
    font-size: 15px;
}
section.s-strengths h3.c-service__subTitle,
section.s-business h3.c-service__subTitle {
    margin-left: 60px;
}

}


/*===============================
        service-page__Strengths
===============================*/
.s-strengths {
    padding: 230px 5% 0;
}
.s-strengths__titleWrap {
    display: flex;
    justify-content: space-between;
    max-width: 1620px;
    margin: 0 auto;
}
ul.s-strengths__list {
    display: flex;
    gap: 2%;
    max-width: 1620px;
    margin: 62px auto 0;
    justify-content: space-between;
}
li.s-strengths__item {
    width: 31%;
    border: solid 5px rgba(90, 147, 216, 0.50);
    border-radius: 38px;
    background-color: var(--wh);/*0923追加*/
    box-shadow: 0 3px 9px rgba(0, 0, 0, 0.16);/*0923追加*/
}
.service-dmah li.s-strengths__item {
    border: solid 5px rgba(44, 47, 174, 0.8);
}
.service-research li.s-strengths__item {
    border: solid 5px rgba(229, 78, 78, 0.8)
}
.service-medical li.s-strengths__item {
    border: solid 5px rgba(188, 46, 46, 0.50);
}



.s-strengths__item--inner {
    width: 85%;
    margin: 32px auto 61px;
}
.s-strengths__item--inner h5 {
    text-align: center;
    font-family: var(--Jost);
    color: rgba(64, 64, 64, 0.5);
    font-weight: 500;
    letter-spacing: 0;
    font-size: clamp(14px, 1.1979vw, 23px);
}
.s-strengths__item--inner h4 {
    text-align: center;
    font-size: var(--fz_35);
    line-height: 1.285;
    margin-top: 9px;
}

.s-strengths__item--inner p {
    text-align: left;
    font-size: var(--fz_20);
    line-height: 1.75;
    margin-top: 22px;
}

li.s-strengths__item img {
    display: block;
    margin: 9px auto 0;
    width: 56%;
    height: auto;
    object-fit: contain;
}

    @media(max-width:768px){
    h2.c-service__title::first-letter, h2.c-service__title {
    font-size: var(--fz_35);
    margin-top: 10px;
    }
    .service-medical .s-about__text .c-service__title {
    font-size: 19.5px;
    }
    p.c-service__text {
    font-size: 13px;
    margin-top: 10px;
    }

    .s-strengths {
    padding: 90px 5% 0;
    }
    .s-strengths__titleWrap {
    flex-direction: column;
        gap: 30px;
    }
    .s-strengths__titleWrap p.c-service__text {
    font-size: 13px;
    width: 100%;
    margin: 0 auto;
    }
    ul.s-strengths__list {
    flex-direction: column;
    gap: 30px;
    margin-top: 30px;
    }
    li.s-strengths__item {
    border-radius: 20px;
    margin: 0 auto;
    width: calc(100% - 10px);
    }
    .s-strengths__item--inner h5 {
    font-size: 13px;
    font-weight: 400;
    }
    .s-strengths__item--inner h4 {
    font-size: 18px;
    }
    .s-strengths__item--inner p {
    font-size: 12px;
    margin-top: 22px;
    max-width: auto;
    margin: 6px auto 0;
    width: 80%;
    }
    .s-strengths__item--inner {
    width: 100%;
    margin: 22px auto 22px;
    }
    }

/*===============================
        service-page__Achievements
===============================*/
.s-achievements {
    padding: 270px 5% 0;
}

.s-achievements__inner {
    display: flex;
    justify-content: space-between;
    max-width: 1620px;
    margin: 0 auto;
}
.s-achievements__titleWrap {
    width: 45%;
    margin-right: 10%;
}
ul.s-achievements__list {
    width: 43%;
    display: flex;
    gap: 98px;
    flex-direction: column;
}
li.s-achievements__item {
  width: 100%;
}
li.s-achievements__item h5 {
    color: rgba(64, 64, 64, 0.50);
    font-weight: 500;
    font-family: var(--Jost);
    font-size: var(--fz_23);
    letter-spacing: 0;
    margin-top: 29px;
}
li.s-achievements__item h5 span {
    color: rgba(90, 147, 216, 0.50);
    font-weight: 500;
    font-family: var(--Jost);
    font-size: var(--fz_23);
    letter-spacing: 0;
}
.service-dmah li.s-achievements__item h5 span {
    color: rgba(44, 47, 174, 0.8)
}
.service-research li.s-achievements__item h5 span {
    color: rgba(229, 78, 78, 0.8)
}
.service-medical li.s-achievements__item h5 span {
    color: rgba(188, 46, 46, 0.50);
}



li.s-achievements__item h4 {
    color: #505050;
    font-weight: bold;
    font-size: var(--fz_35);
    letter-spacing: 0;
    margin-top: 9px;
}
li.s-achievements__item p {
    color: #505050;
    font-weight: 500;
    font-size: var(--fz_20);
    letter-spacing: 0;
    margin-top: 18px;
    line-height: 1.75;
}
li.s-achievements__item img {
    max-width: 100%;
    width: 100%;
    aspect-ratio: 747 / 422;
    border-radius: 38px;
    height: auto;
}


    @media(max-width:768px){
    .s-achievements {
    padding: 100px 5% 0;
    }
    .s-achievements__inner {
    flex-direction: column;
    }
    .s-achievements__titleWrap {
    width: 100%;
    margin: 0 auto;
    }
    ul.s-achievements__list {
    width: 100%;
    display: flex;
    gap: 0;
    flex-direction: column;
    }
    li.s-achievements__item img {
    border-radius: 20px;
    }
    li.s-achievements__item {
    width: 100%;
    margin-top: 50px;
    }
    li.s-achievements__item h5 {
    font-weight: 400;
    font-size: 13px;
    margin-top: 12px;
    }
    li.s-achievements__item p {
    font-weight: 400;
    font-size: 12px;
    margin-top: 15px;
    }
    }


/* ===============================
    service-page spirit-view
=============================== */
.s-achievements {
  overflow-y: hidden;/*0925追加*/
}
.s-achievements__pinWrap {
  position: relative;
  /* 高さ自動調整：中身に応じて */
}
.s-achievements__inner.active .s-achievements__titleWrap {
  position: fixed;
  top: 100px;
  z-index: 10;
}
.s-achievements__inner.active .s-achievements__list {
  position: absolute;
  left: 57%;
  width: 43%;
  z-index: 5;
}
.s-achievements {
  margin-bottom: 0; /* ← 次のセクションとの間隔を一定に */
}

    @media(max-width:768px){
    .s-achievements__pinWrap {
        position: static;
    }
    }





/*===============================
        service-page__Business partner
===============================*/
.s-business {
    padding: 180px 5% 150px;
}
.s-business__inner {
    max-width: 1620px;
    margin: 0 auto;
}
.s-business__flex {
    display: flex;
    justify-content: space-between;
}
.s-business__titleWrap {
    width: 54%;
}
.s-business__ill {
    width: 32%;
}
.s-business__ill img {
    width: 100%;
    object-fit: contain;
}
.s-business__ill.forSp {
    display: none;
}
.s-business__listWrap {
    border: solid 5px rgba(90, 147, 216, 0.50);
    border-radius: 38px;
    padding: 0 5%;
    margin-top: 56px;
}
.service-dmah .s-business__listWrap {
    border: solid 5px rgba(44, 47, 174, 0.8)
}
.service-research .s-business__listWrap {
    border: solid 5px rgba(229, 78, 78, 0.8)
}
.service-medical .s-business__listWrap {
    border: solid 5px rgba(188, 46, 46, 0.50);
}

.s-business__list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  padding: 0;
  margin: 47px auto 0;
  gap: 10px;
}

.s-business__list li {
  font-size: 23px;
  list-style-position: inside; /* マーカーを内側に */
  list-style: disc;
  margin-left: 1em;
}

 /* マーカーだけ青 */
ul.s-business__list li::marker {
  color: var(--bl);
}
.service-dmah ul.s-business__list li::marker {
    color: var(--dmah);
}
.service-research ul.s-business__list li::marker {
    color: var(--research);
}
.service-medical ul.s-business__list li::marker {
    color: var(--medical);
}

p.s-business__list-cap {
    text-align: right;
    max-width: 1326px;
    margin: 1em auto 47px;
    font-size: 23px;
}
.s-business__foot--wrap {
  background-image: url(../images/service__sensor/s_sensor10@2x.jpg);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  color: var(--wh);
  padding: 7vw 7%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-radius: 38px;
}

main.service-dmah .s-business__foot--wrap {
  background-image: url(../images/service__dmah/s_dmah10@2x.jpg);
}
main.service-research .s-business__foot--wrap {
  background-image: url(../images/service__research/s_research10@2x.jpg);
}
main.service-medical .s-business__foot--wrap {
  background-image: url(../images/service__medical/s_medical10@2x.jpg);
}


  @media(max-width:1024px){
    main.service-sensor .s-business__foot--wrap {
    background-image: url(../images/service__sensor/s-sensor10-sp.png);
    }
    main.service-dmah .s-business__foot--wrap {
    background-image: url(../images/service__dmah/s-dmah10-sp.png);
    }
    main.service-research .s-business__foot--wrap {
    background-image: url(../images/service__research/s-research10-sp.jpg);
    }
    main.service-medical .s-business__foot--wrap {
    background-image: url(../images/service__medical/s-medical10-sp.png);
    }
}



.s-business__img img {
    border-radius: 38px;
}

.s-business__img {
    width: 52%;
    margin-right: 6%;
}
.s-business__foot--text {
    width: 44%;
}
.s-business__foot--text h3 {
    font-size: var(--fz_45);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.44;
}
.s-business__foot--text p {
    font-size: var(--fz_23);
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1.52;
    margin-top: 1em;
}

.s-business__bg {
    position: absolute;
    z-index: -1;
    top: 0;
    z-index: 0;
}
.s-business__bg img {
    width: 100%;
    object-fit: cover;
    border-radius: 21px;
    vertical-align: bottom;
}

    @media(max-width:1024px){
    .s-business__foot--wrap {
    flex-direction: column;
    }
    .s-business__titleWrap {
    width: 100%;
    }
    .s-business__ill {
    display: none;
    width: 32%;
    }
    .s-business__foot--text {
    width: 100%;
    }
    .s-business__list li {
    font-size: 17px;
    }
    p.s-business__list-cap {
    font-size: 17px;
    }
    .s-business__img {
    margin: 0 auto;
    width: 100%;
    margin-right: 0;
    }
    .s-business__foot--wrap {
    margin-top: 30px;
    border-radius: 20px;
    }
    }

          @media(max-width:768px){
          .s-business__ill.forPc {
          display: none;
          }
          .s-business__ill.forSp {
          display: block;
          width: 77%;
          margin: 30px auto 0;
          }

          /* 幅が768px以下になったら2列に変更 */
          .s-business__list {
          grid-template-columns: repeat(2, 1fr);
          margin: 25px auto 0;
          }
          .s-business__list li {
          font-size: 13px;
          }
          p.s-business__list-cap {
          font-size: 13px;
          }
          .s-business__listWrap {
          border-radius: 20px;
          margin-top: 40px;
          }
          .s-business__foot--wrap {
          border-radius: 20px;
          }
          .s-business__img img {
          border-radius: 20px;
          object-fit: cover;
          vertical-align: bottom;
          }
          .s-business__foot--wrap {
          padding: 35px 5%;
          margin-top: 30px;
          border-radius: 20px;
          }
          .s-business__img {
          margin: 0 auto;
          width: 100%;
          border-radius: 20px;
          }
          .s-business__foot--text h3 {
          font-size: 25px;
          margin-top: 30px;
          }
          .s-business__foot--text p {
          font-size: 13px;
          font-weight: 400;
          letter-spacing: 0.02em;
          line-height: 1.52;
          margin-top: 1em;
          }
          .s-business {
          padding: 85px 5% 70px;
          }
          }


              @media(max-width:425px){
              .s-business__list li {
              font-size: 10px;
              }
              p.s-business__list-cap {
              font-size: 10px;
              margin: 1em auto 25px;
              }
            }

/*===============================
        products-page
===============================*/
/*===============================
        products-page__INDEX
===============================*/
.p-index {
    padding: 0 5%;
    margin-top: 72px;
}
.p-index__inner {
    max-width: 1720px;
    margin: 0 auto;
}
.p-index__inner h2 {
    color: #fff;
    font-family: var(--outfit);
    font-size: var(--fz_25);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
}
.p-index__inner h2:first-letter {
    color: #fff;
}
ul.p-index__list {
display: flex;
justify-content: space-between;
align-items: center;
margin-top: 25px;
gap: 2%;
}
.p-index__list li {
  width: 28%;
  max-width: 519px;
  height: 90px;
  border: solid 1px #AFAFAF;
}
.p-index__list li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-decoration: none;
  height: 100%;
  max-width: 440px;
  margin: 0 auto;
  width: 90%;
}

.p-index__list li a h3 {
  font-size: var(--fz_33);
  font-weight: bold;
  color: var(--wh);
  line-height: 1.3;
}
.p-index__list li a h3 span {
  display: block;
  font-size: var(--fz_18);
  color: rgba(255, 255, 255, 0.3);
  font-family: var(--outfit);
  font-weight: bold;
}
.p-index__icon {
    display: grid;
    place-content: center;
    width: 10%;
}
.p-index__icon img {
  width: 100%;
  object-fit: contain;
}

    @media(max-width:1340px){
    ul.p-index__list .sp-br {
    display: block;
    }
    .p-index__list li {
    width: 100%;
    }
    }

    @media(max-width:1024px){
    ul.p-index__list {
    flex-direction: column;
    gap: 8px;
    }
    }
    @media(max-width:768px){
    .p-index__inner {
    max-width: 1720px;
    margin: 0 auto;
    }
    .p-index__list li {
    width: 100%;
    height: 66px;
    border: solid 1px #AFAFAF;
    max-width: 350px;
    margin: 0 auto;
    }
    .p-index__inner h2 {
    color: #fff;
    font-family: var(--outfit);
    font-size: 15px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
    }
    .p-index__list li a h3 {
    font-size: 20px;
    font-weight: bold;
    color: var(--wh);
    line-height: 1.3;
    }
    .p-index__list li {
    width: 100%;
    max-width: 519px;
    height: 66px;
    max-width: 350px;
    margin: 0 auto;
    }
    }


/*===============================
        products-page__共通
===============================*/
.c-title--img {
    width: 100%;
    position: relative;
    z-index: -1;
    padding-top: 45px;
}
.c-title--img img,
.c-title--icon img {
  width: 100%;
  object-fit: covser;
  vertical-align: bottom;
}
.c-title--icon {
  position: absolute;
  bottom: 5%;
  right: 5%;
  z-index: 0;
  width: 15%;
  max-width: 80px;
}
.c-title--icon img {
    object-fit: contain;
    width: 100%;
}
.p-index {
    padding: 0 5%;
    margin-top: 110px;
}
    @media(max-width:768px){
    .c-title--icon {
    bottom: 20px;
    right: 20px;
    }
    .c-title--img {
    padding-top: 15px;
    }
    }

/*===============================
        ttl3 product-page
===============================*/
.products-page h3.c-title__en {
  font-family: var(--outfit);
  font-size: var(--fz_25);
  font-weight: bold;
  letter-spacing: 0;
  line-height: 1;
  text-transform: uppercase;
}
.products-page h3.c-title__en::first-letter {
  color: var(--red);
}
.products-page h2.c-title__ja::first-letter {
    color: #fff;
}
.products-page h2.c-title__ja {
    color: #fff;
    font-size: var(--fz_62);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.13;
}
    @media(max-width:768px){
    .products-page h3.c-title__en {
    font-size: 12px;
    }
    .products-page h2.c-title__ja {
    font-size: 32px;
    line-height: 1.4;
    }
    .products-page .p-develop__title h2.c-title__ja {
    font-size: 30px;
    }
    }


/*===============================
        products-page__MEDICAL
===============================*/
#p-medical {
  padding: 150px 5% 180px;
}
.p-medical__inner {
    max-width: 1720px;
    margin: 0 auto;
}
.p-medical__flex {
    display: flex;
    justify-content: space-between;
}
.p-medical__title {
    width: 30%;
}
.p-medical__right {
    width: 65%;
    max-width: 1120px;
    margin-top: var(--fz_25);
}

.p-medical__point--box {
    border: solid 1px #707070;
    position: relative;
    margin-top: 60px;
}
.p-medical__point--box span {
    display: block;
    width: 14%;
    position: absolute;
    top: -1em;
    left: 1.2em;
    z-index: 1;
}
.p-medical__point--box span img {
  width: 100%;
}
.p-medical__point--box span::before {
  position: absolute;
  background-color: var(--bk);
  width: var(--fz_25);
  height: var(--fz_25);
}

.p-medical__point--inner {
    max-width: 1000px;
    margin: calc(66px - 1.25rem) auto calc(50px - 1.25rem);
    width: 88%;
}
.p-medical__ponint--img {
    display: flex;
    gap: 8%;
}
figure.image-caption img {
    display: block;
    object-fit: contain;
    width: 100%;
}
.image-caption figcaption {
  font-size: var(--fz_20);
}
.frame-top-gap {
/* 調整用の変数（好きに変えてOK） */
--gap: 156px;       /* 上辺の切れ目の幅 */
--thick: 1px;      /* 枠線の太さ */
--color: #ffffff;  /* 枠線の色 */
--radius: 0;    /* 角丸。0で直角 */

position: relative;
border-radius: var(--radius);
padding: 1.25rem; /* 内側余白はお好みで */

/* 線を背景の複数グラデーションで描画（上だけ中央を空ける） */
background:
    /* 上辺 左半分 */
    linear-gradient(var(--color) 0 0) top left /
    28px var(--thick) no-repeat,
    /* 上辺 右半分 */
    linear-gradient(var(--color) 0 0) top right /
    calc(100% - var(--gap) + 57px - 5em) var(--thick) no-repeat,
    /* 下辺 全幅 */
    linear-gradient(var(--color) 0 0) bottom left /
    100% var(--thick) no-repeat,
    /* 左辺 全高 */
    linear-gradient(var(--color) 0 0) top left /
    var(--thick) 100% no-repeat,
    /* 右辺 全高 */
    linear-gradient(var(--color) 0 0) top right /
    var(--thick) 100% no-repeat;
    margin-top: 56px;
}
.frame-top-gap::before {
    position: absolute;
    content: "point";
    top: -1em;
    left: 67px;
    font-size: 25px;
    font-weight: bold;
    font-family: var(--outfit);
    letter-spacing: 0;
    text-transform: uppercase;
    color: #ffffff;
}
.frame-top-gap::after {
    width: 5.4rem;
    position: absolute;
    content: "";
    top: 0;
    left: 3.2rem;
    border: solid 8px rgba(90, 147, 216, 0.51);
    z-index: -1;
}
.p-medical__right h4 {
    font-size: var(--fz_33);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;
}
.p-medical__right--text {
    font-size: var(--fz_22);
    margin-top: 20px;
    letter-spacing: 0.03em;
    line-height: 1.63;
    font-weight: 500;
}
.p-medical__point--inner h5 {
    font-size: var(--fz_28);
    margin-top: 40px;
    letter-spacing: 0.03em;
    line-height: 1.8;
    font-weight: 500;
}
.p-medical__point--text {
    font-size: var(--fz_20);
    margin-top: 20px;
    letter-spacing: 0.03em;
    line-height: 1.8;
    font-weight: 500;
}
.frame-top-gap h5.forSp {
    display: none;
}

    @media(max-width:768px){
    #p-medical {
    padding: 100px 5% 0;
    }
    .p-medical__flex {
    flex-direction: column;
    }
    .p-medical__title {
    width: 100%;
    }
    .p-medical__right {
    width: 100%;
    }
    .p-index__icon {
    width: 35px;
    }
    .c-title--img img {
    aspect-ratio: 350 / 205;
    object-fit: cover;
    width: 100%;
    height: auto;
    }
    .p-medical__right--text {
    font-size: 13px;
    margin-top: 1em;
    }
    .c-title--img img {
    height: auto;
    aspect-ratio: 350 / 205;
    object-fit: contain;
    }
    .p-medical__ponint--img {
    flex-direction: column;
    gap: 15px;
    }
    .image-caption img {
    padding: 10px 0 0;
    }
    .image-caption figcaption {
    font-size: 15px;
    letter-spacing: 0.03em;
    font-weight: 500;
    }
    .p-medical__point--inner {
    font-size: 12px;
    width: 100%;
    margin: 20px auto;
    }
    .p-medical__right h4 {
    font-size: 23px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;
    }
    .p-medical__point--inner h5 .forPc {
    display: none;
    }
    .frame-top-gap h5.forSp {
    display: block;
    margin-top: 38px;
    }
    .p-medical__point--inner h5 {
    display: none;
    }

    .p-medical__point--text {
    font-size: 12px;
    margin-top: 20px;
    letter-spacing: 0;
    line-height: 1.5;
    }
    #p-medical .c-title--icon {
    bottom: 20px;
    right: 10px;
    z-index: 0;
    width: 15%;
    max-width: 80px;
    }
    }

/*===============================
        products-page__共通アコーディオン
===============================*/
.products-page .c-accordion__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 108px 5%;
    margin: 100px auto auto;
    width: 100%;
    max-width: 1720px;
}
.c-accordion__item.__pdf {
    display: flex;
    justify-content: flex-end;
    flex-direction: column;
}
.products-page .c-accordion__item {
  width: 30%;
}
.accordion-content h3 {
    position: relative;
    font-size: 25px;
    font-weight: bold;
    font-family: var(--color);
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--wh);
    margin-left: 1rem;
    margin-top: 28px;
    font-family: var(--outfit);
}
.accordion-content h3::before {
    width: 5.4rem;
    position: absolute;
    content: "";
    top: 1.2rem;
    left: -1rem;
    border: solid 8px rgba(90, 147, 216, 0.51);
    z-index: -1;
}
.accordion-content p {
    font-size: var(--fz_20);
    letter-spacing: 0.03em;
    line-height: 1.8;
    font-weight: 500;
}
.accordion-content_point--text p {
    font-size: var(--fz_20);
    letter-spacing: 0.03em;
    line-height: 1.8;
    font-weight: 500;
    margin-top: 24px;
}
.accordion-content_point--text p strong {
    font-weight: bold;
}

/* ここから */
.accordion {
border-bottom: 1px solid #A8A8A8;
max-width: 100%;
}

/* ヘッダー部分 */
.accordion-header {
display: flex;
justify-content: space-between;
align-items: center;
cursor: pointer;
padding: 12px 0;
font-weight: bold;
font-size: var(--fz_28);
letter-spacing: 0.03em;
line-height: 1.8;
}

/* トグルアイコン（最初は＋） */
.accordion-icon {
font-size: 22px;
transition: opacity 0.3s ease;
}

/* 開いたら上のトグルを消す */
.accordion.open .accordion-icon {
opacity: 0;
pointer-events: none;
}

/* コンテンツ部分 */
.accordion-content {
max-height: 0;
overflow: hidden;
transition: max-height 0.4s ease, padding 0.4s ease;
padding: 0 16px;
position: relative;
}

.accordion.open .accordion-content {
max-height: 500px;
padding: 16px 0;
}


/* 下のトグル（開いたときだけ出す） */
.accordion-footer {
text-align: right;
margin-top: 12px;
cursor: pointer;
font-size: 22px;
display: none;
}
.accordion.open .accordion-footer {
display: block;
}
.accordion-content {
max-height: 0;
overflow: hidden;
transition: max-height 0.4s ease;
}
.accordion-header .sp-br {
display: none;
}

    @media(max-width:768px){
    .accordion-header .sp-br {
    display: block;
    }
    .c-accordion__list {
    display: block;
    margin: 100px auto 0;
    width: 100%;
    }
    .accordion {
    max-width:100%;
    margin-bottom: 40px;
    }
    .accordion-content p {
    font-size: 12px;
    letter-spacing: 0;
    line-height: 1.5;
    font-weight: 500;
    }
    .products-page .c-accordion__list {
    flex-direction: column;
    gap: 0;
    margin-top: 40px;
    }
    .products-page .c-accordion__item {
    width: 100%;
    }
    .p-medical__right .frame-top-gap h5.forSp {
    display: block;
    margin-top: 20px;
    }
    .accordion.open .accordion-content {
    padding: 16px 0;
    }
    section#p-medical .accordion__img img {
    aspect-ratio: 350 / 209;
    object-fit: cover;
    vertical-align: bottom;
    }
    }

/* ここまで */

/*===============================
        products-page__HEALTH CARE
===============================*/
#p-healthcare {
padding: 150px 5% 180px;
}
.p-health__inner {
    max-width: 1720px;
    margin: 0 auto;
}

.p-health__right h4 {
    font-size: var(--fz_33);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;
}
.p-health__right--text {
    font-size: var(--fz_22);
    margin-top: 20px;
    letter-spacing: 0.03em;
    line-height: 1.63;
    font-weight: 500;
}
.p-health__right {
    width: 65%;
    max-width: 1120px;
    margin-top: var(--fz_25);
}
.p-health__title {
    width: 30%;
}
.p-health__flex {
    display: flex;
    justify-content: space-between;
}
.c-accordion__item--linkImg {
    display: block;
    width: 30%;
    margin: 0 auto;
    max-width: 164px;
}

.c-accordion__item--linkImg img {
  width: 100%;
  object-fit: contain;
  vertical-align: bottom;
}
.c-accordion__item--linkTtl {
    text-align: center;
}
a.c-accordion__item--link {
  color: var(--wh);
  font-size: var(--fz_22);
  font-weight: bold;
  letter-spacing: 0.03em;
  text-decoration-line: underline;   /* 下線を表示 */
  text-decoration-color: var(--wh);       /* 下線の色を白に */
  text-decoration-thickness: 1px;    /* 下線の太さを1pxに */
  line-height: calc(1.8 * 1.2727);
  margin-bottom: 12px;
  position: relative;
  margin-left: 1em;/*疑似要素分*/
}
a.c-accordion__item--link::before {
    position: absolute;
    content: "■";
    color: #fff;
    top: 50%;
    left: -1em;
    transform: translate(-50%, -50%);
}


.c-accordion__item--linkTtl {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 20px;
}
span.c-accordion__item--dot {
    margin-right: 0.5em;
}
    @media(max-width:768px){
    .c-accordion__item--linkImg {
    width: 100px;
    height: 120px;
    margin: 40px auto 0;
    }
    .p-health__right h4 {
    font-size: 23px;
    }
    #p-healthcare {
      padding: 120px 5% 0;
    }
    .p-health__right--text {
    font-size: 13px;
    margin-top: 15px;
    letter-spacing: 0;
    }
    a.c-accordion__item--link {
    font-size: 14px;
    }
    #p-healthcare .c-title--icon {
    bottom: 20px;
    right: 10px;
    z-index: 0;
    width: 15%;
    max-width: 80px;
    }

    }


/*===============================
        products-page__開発／各種センサー活用
===============================*/
#p-development {
  padding: 150px 5% 20px;
}
.p-develop__inner {
    max-width: 1720px;
    margin: 0 auto;
}
.p-develop__title {
    width: 30%;
}
.p-develop__flex {
    display: flex;
    justify-content: space-between;
}
.p-develop__right {
    width: 65%;
    max-width: 1120px;
    margin-top: var(--fz_25);
}
p.p-develop__right--text {
    font-size: var(--fz_22);
    margin-top: 20px;
    letter-spacing: 0.03em;
    line-height: 1.63;
    font-weight: 500;
}
.p-develop__title .c-title--img {
    width: 100%;
    position: relative;
    z-index: -1;
    padding-top: calc(var(--fz_62) * 2);
}
.p-develop__right h4 {
    font-size: var(--fz_33);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;
}
.p-develop__right--text {
    font-size: var(--fz_22);
    margin-top: 20px;
    letter-spacing: 0.03em;
    line-height: 1.63;
    font-weight: 500;
}
.c-contact__banner--img img {
    width: 100%;
    object-fit: contain;
    vertical-align: bottom;
}
.c-contact__banner {
padding: 170px 5% 20px;
}
.c-contact__banner a {
height: auto;
display: block;
margin: 0 auto;
position: relative;
width: clamp(407px, 29.104vw, 557px);
}
.c-contact__banner .arrow-box {
    display: inline-block;
    width: 15.5%;
    height: 36%;
    position: absolute;
    overflow: hidden;
    background: transparent;
    margin-right: 0;
    margin-bottom: 0;
    clip-path: polygon(100% 0, 100% 100%, 0 100%);
    right: 0;
    bottom: 0;
    z-index: 2;
}
.c-contact__banner a.btn-arrow-img::after {
    position: absolute;
    content: "";
    width: 1px; 
    bottom: -66px;
    right: 0;
    height: 73%;
    background: #fff;
    transform-origin: right top;
    transform: rotate(45deg);
}
.c-contact__banner .btn-arrow-img:hover .arrow-thick {
    opacity: 1;
    left: 60%;
}
    @media(max-width:768px){
    .c-contact__banner .arrow-box {
    width: 50px;
    height: 50px;
    }
    .c-contact__banner .btn-arrow-img:hover .arrow-thick {
    left: 28px;
    }
    .c-contact__banner a {
    width: 337px;
    }
    .c-contact__banner a.btn-arrow-img::after {
      height: 79%;
    }
    }



.c-contact__inner {
    display: flex;
    justify-content: unset;
    max-width: 1720px;
    margin: 0 auto;
    position: relative;
}
.c-contact__list {
    display: flex;
    gap: 47px;
    margin-top: 32px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}
.c-contact__icon {
    width: 16%;
    height: auto;
}

    @media(max-width:1024px){
    .c-contact__title {
    width: 100%;
    }
    .c-contact__list {
    position: static;
    transform: none;
    }
    }

    @media(max-width:768px){
    #p-development {
    padding: 100px 5% 0;
    }
    .p-health__flex {
    justify-content: space-between;
    flex-direction: column;
    }
    .p-health__title {
    width: 100%;
    }
    .p-health__right {
    width: 100%;
    }
    .p-develop__flex {
    justify-content: space-between;
    flex-direction: column;
    }
    .p-develop__right h4 {
    font-size: 23px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;
    }
    .p-develop__title {
    width: 100%;
    }
    .p-develop__right {
    width: 100%;
    max-width: 1120px;
    margin-top: 2rem;
    }

    .p-develop__title .c-title--img {
    padding-top: 15px;
    }
    p.p-develop__right--text {
    font-size: 13px;
    margin-top: 20px;
    letter-spacing: 0;
    line-height: 1.63;
    font-weight: 500;
    }
    .c-contact__icon {
    width: 40px;
    }
    #p-development .c-title--icon {
    bottom: 20px;
    right: 10px;
    z-index: 0;
    width: 15%;
    max-width: 80px;
    }
    }
        @media (max-width: 425px) {
        .p-develop__right h4 {
          font-size: 22px;
        }
        }

/*===============================
        NEWS-page__archive
===============================*/
.t-news.news-page {
    padding: 18px 5% 0;
}

/* セレクトボックス   */
.news-page select {
  background-color: #000;
  color: #fff;
  border: 1px solid #AFAFAF;
  padding: 15px 50px;
  border-radius: 0;
  appearance: none;
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 20px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16'><text x='0' y='14' font-size='16' fill='white'>▼</text></svg>");
  width: clamp(254px, 19.1145vw, 367px);
  font-size: var(--fz_20);
  letter-spacing: 0.03em;
  font-weight: 500;
  font-family: var(--Zen-Kaku-Gothic-New);
}
.news-page option {
  padding: 10px; /* 効かないことが多い */
  background-color: #000;
  color: #fff;
}
.container.select-type,
.container.select-year {
    margin-top: 13px;
}
.t-news__select--flex form {
    display: flex;
    gap: 40px;
    align-items: end;
}

/* 絞り込む */
.search button {
    font-size: var(--fz_20);
    letter-spacing: 0.025em;
    font-weight: bold;
    border: none;
    cursor: pointer;
    background: transparent;
    color: #fff;
    display: flex;
    align-items: center;
  position: relative;
  margin: 15px 15px 15px 40px;
}
.search button:hover::after {
  width: 100%;
}
.search button::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 0;
  height: 2px;
  background-color: var(--wh);
  transition: width 0.3s ease;
}
img.search-icon {
  width: 15px;
  margin-left: .5em;
  vertical-align: bottom;
}
.year-search__flex {
  display: flex;
  align-items: end;
}

    @media(max-width:768px){
    .t-news__select--flex form {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    }
    .t-news.news-page {
    padding: 80px 5% 0;
    }
    img.search-icon {
    width: 13px;
    }
    }


        @media(max-width:768px){
        .news-page select {
        padding: 10px 50px 10px 10px;
        width: 210px;
        font-size: 13px;
        letter-spacing: 0.025em;
        font-weight: bold;
        }
        .t-news__select--flex {
        flex-direction: column;
        gap: 20px;
        }
        .container.select-type, .container.select-year {
        margin-top: 0;
        }
                
        .search button {
        font-size: 13px;
        margin: 10px 10px 10px 30px;
        }

        }


/*===============================
        NEWS-pagination
===============================*/
/* ボタン本体 */
.pagination .pagination__btn {
  position: relative;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease;
}
.pagination__btn a svg {
  vertical-align: bottom;
  object-fit: contain;
}
.pagination .pagination__btn:active {
  transform: scale(0.95);
}

/* 六角形の枠（SVG） */
.pagination .hex-shape {
  fill: none;
  stroke: #fff;
  stroke-width: 1;
  transition: fill 0.3s ease, stroke 0.3s ease;
}

/* hover時と同じスタイルを現在地ボタンにも適用 */
.pagination .pagination__btn:hover .hex-shape,
.pagination .pagination__btn.current .hex-shape {
  fill: #fff;
  stroke: #fff;
}

/* 中央の数字 */
.pagination .hex-number {
    left: 50%;
    position: absolute;
    /* font-size: 30px; */
    font-size: clamp(20px, 1.5625vw, 30px);
    font-weight: bold;
    color: #fff;
    pointer-events: none;
    transition: color 0.3s ease;
    font-family: var(--outfit);
    top: 50%;
    transform: translate(-50%, -50%);
}
.pagination .pagination__btn:hover .hex-number,
.pagination .pagination__btn.current .hex-number {
  color: #000;
}

/* 右下の直角三角形 */
.pagination .triangle-outline {
    position: absolute;
    bottom: 0;
    right: 0;
}
.pagination .triangle-outline polygon {
  stroke: rgba(255,255,255,0.64);
  stroke-width: 1.5;
  fill: none;
  transition: stroke 0.3s ease;
}
/* hoverで白に */
.pagination .pagination__btn:hover .triangle-outline polygon,
.pagination .pagination__btn.current .triangle-outline polygon {
  stroke: #fff;
}
.pagination {
    display: flex;
    gap: 15px;/*削り分と合わせて30px*/
    justify-content: end;
    max-width: 1720px;
    margin: 100px auto 0;
}
.pagination__dots {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    margin-right: -15px;
}
.t-news__inner .pagination{
  gap: 30px;
  margin-right: 50px;
}
.t-news__inner .pagination .pagination__btn svg {
  width: 42.4px;
  height: 57.6px;
}
.t-news__inner .pagination .pagination__btn svg.triangle-outline {
  width: 14px;
  height: 14px;
}

        @media(max-width:768px){
        .pagination {
        gap: 20px;
        margin: 64px auto 0;
        justify-content: center;
        }
        .pagination .hex-number {
        font-size: 15px;
        font-weight: 500;
        }
        .pagination .pagination__btn {
        width: 34px;
        height: 40px;
        }
        .pagination .triangle-outline {
        bottom: 0;
        right: 0;
        width: 8px;
        height: 13px;
        }
        .t-news__inner .pagination .pagination__btn svg {
        width: 34px;
        height: 40px;
        }
        .t-news__inner .pagination .pagination__btn svg.triangle-outline {
        width: 10px;
        height: 10px;
        right: 2px;
        }
        }


/*===============================
        NEWS-page__post
===============================*/
.news-post {
  padding: 0 5%;
}
.news-post__inner {
    max-width: 1720px;
    margin: 0 auto;
}
.news-post .c-news__list {
    border-bottom: solid;
}
.news-post__title--wrap {
    display: block;
    justify-content: center;
    align-items: center;
    max-width: 982px;
    width: 100%;
    border-bottom: solid 1px #A8A8A8;
}
.news-post__item {
    max-width: 982px;
    margin: 0 auto;
}
.news-post__tag--flex {
    display: flex;
}
h3.news-post__title {
  font-size: var(--fz_30);
    font-weight: bold;
    line-height: 1.33;
    letter-spacing: 0.03em;
    color: var(--wh);
    margin: 22px auto 22px 0;
}
.news-post__time {
    font-family: var(--outfit);
    color: var(--wh);
    font-size: var(--fz_22);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0;
    text-align: left;
}
.news-post__tag {
    display: inline-flex;
    align-items: center;
    font-size: var(--fz_16);
    font-weight: 400;
    letter-spacing: 0.03em;
    background-color: #535353;
    border-radius: 18px;
    color: var(--wh);
    padding: 1px 33px;
    margin-left: 52px;
}
.news-post__contents {
    padding: 50px 0;
    font-size: var(--fz_22);
    line-height: 1.6;
    letter-spacing: 0.03em;
    text-align: left;
    font-weight: 500;
}

.news-post__contents img {
  width: 100%;
  height: auto;
  object-fit: contain;
  vertical-align: bottom;
  max-width: 567px;
  margin: 0 auto;
  display: block;
}
.news-post .prevnext {
  margin-top: 125px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  letter-spacing: 0.03em;
  font-size: 22px;
  width: 24%;
  margin: 100px auto 0;
  gap: 33px;
}

/* ボタン全体 */
.news-post a.prevpostlink,
.news-post a.nextpostlink,
.news-post a.larger {
  justify-content: center;
  width: 58px;
  height: 60px;
  display: flex;
  align-items: center;
  text-decoration: none;
  font-size: 22px;
  letter-spacing: 0.03em;
  font-weight: bold;
  color: var(--wh);
  border: solid 0.7px #fff;
  transition: all 0.3s ease;
}
.news-post a.prevpostlink {
  width: 51px;
  padding: 0 5px 0 0;
}
.news-post a.nextpostlink {
  width: 51px;
  padding: 0 0 0 5px;
}
.news-post a.prevpostlink img {
  transform: rotate(180deg);
  transition: filter 0.3s ease;
}

/* span（一覧へ戻る） */
.back-link {
  border: solid 0.7px #fff;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  aspect-ratio: 284 / 60;
  width: 60%;
  height: auto;
  min-width: 146px;
  min-height: 40px;
}
.prev-link,
.next-link {
  border: solid 0.7px #fff;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  width: 13%;
  height: auto;
  aspect-ratio: 1 / 1;
  min-width: 40px;
  min-height: 40px;
}
img.nextpostlink,
img.prevpostlink {
    width: 18px;
}
span.prev-link a img, span.next-link a img {
    position: relative;
    top: 50%;
    transform: translate(-50%, -50%);
    left: 50%;
    width: 45%;
}
a.back {
  text-decoration: none;
  color: var(--wh);
}

/* hover時の共通スタイル */
.news-post a.prevpostlink:hover,
.news-post a.nextpostlink:hover,
.news-post a.larger:hover,
.news-post .prevnext span:hover {
  background-color: #fff; /* 背景白 */
  color: #000;            /* 文字黒 */
  border-color: #000;      /* ボーダー黒 */
}

.prev-link:hover img,
.next-link:hover img {
  filter: brightness(0); /* 黒くする */
}

span.prev-link a,
span.next-link a {
    width: 100%;
    height: 100%;
}
span.prev-link a {
    transform: rotate(180deg);
}



/* 矢印画像も黒に */
.news-post a.prevpostlink:hover img,
.news-post a.nextpostlink:hover img {
  filter: brightness(0); /* 白→黒に変換 */
}

a.back-link span {
    color: var(--wh);
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all .3s;
    font-size: clamp(14px, 1.1458vw, 22px);
}
a.back-link {
    text-decoration: none;
}
span.prev-link a,
span.next-link a {
    display: flex;
}

    @media(max-width:768px){
    .news-post {
    padding: 70px 10% 0;
    }
    .news-post__time {
    font-size: 13px;
    }
    .news-post__tag {
    font-size: 11px;
    padding: 1px 16px;
    margin-left: 22px;
    }
    h3.news-post__title {
    font-size: 15px;
    font-weight: 500;
    margin: 14px auto 14px 0;
    letter-spacing: 0;
    }
    .news-post__contents {
    padding: 18px 0;
    font-size: 12px;
    line-height: 1.5;
    letter-spacing: 0;
    text-align: left;
    font-weight: 500;
    }
    .news-post .prevnext {
    margin-top: 50px;
    gap: 40px;
    font-size: 14px;
    }
    .news-post a.nextpostlink {
    width: 37px;
    padding: 0 0 0 5px;
    height: 38px;
    }
    .news-post a.prevpostlink {
    width: 37px;
    padding: 0 5px 0 0;
    height: 38px;
    }
    .news-post a.nextpostlink img,
    .news-post a.prevpostlink img {
    width: 16px;
    height: 17px;
    }
    span.prev-link a img, span.next-link a img {
    width: 12px;
    }
    .back-link {
    width: 146px;
    height: 40px;
    }
    .prev-link, .next-link {
    width: 40px;
    height: 40px;
    }
    /* 0923追加 */
    .t-news__inner .pagination {
    gap: 20px;
    margin-right: 0;
    }
    }



/*===============================
        FAQ&CONTACT-page__input
===============================*/
.faq {
padding: 67px 5% 0;
}
.faq__inner h2::before {
position: absolute;
content: "よくある質問";
}
.faq__inner {
display: flex;
max-width: 1720px;
margin: 0 auto;
width: 100%;
}
.faq__inner h2 {
width: 40%;
max-width: 700px;
}
.faq__accordion__list {
display: flex;
flex-wrap: wrap;
max-width: 1020px;
justify-content: flex-start;
width: 60%;
}
.faq__accordion__item {
width: 100%;
}
.faq__accordion {
border-bottom: 1px solid #A8A8A8;
}
.faq__accordion-header {
display: flex;
justify-content: space-between;
align-items: center;
cursor: pointer;
padding: 40px 0;
font-weight: bold;
font-size: var(--fz_28);
letter-spacing: 0.03em;
line-height: 1.8;
}
.faq__accordion-icon {
font-size: 22px;
transition: opacity 0.3s ease;
display: flex;
align-items: center;
}
.faq__accordion-content {
max-height: 0;
overflow: hidden;
transition: max-height 0.4s ease, padding 0.4s ease;
padding: 0;
position: relative;
}
.faq__accordion-content p {
letter-spacing: 0.025em;
font-weight: 500;
margin: 0 40px;
font-size: var(--fz_22);
line-height: 1.7;
}
.faq__accordion-content h3 {
position: relative;
font-size: 25px;
font-weight: bold;
font-family: var(--color);
letter-spacing: 0;
text-transform: uppercase;
color: var(--wh);
margin-left: 1rem;
margin-top: 28px;
}
.faq__accordion--flex {
display: flex;
justify-content: flex-start;
align-items: flex-start;
}
.faq__accordion-header h3 {
display: flex;
width: calc(100% - 80px);
justify-content: space-between;
font-weight: bold;
letter-spacing: 0.025em; 
align-items: center;
font-size: clamp(17px, 1.302vw, 25px);
line-height: 1.7;
}
.faq__q,
.faq__a {
font-family: var(--outfit);
font-size: var(--fz_70);
font-weight: bold;
letter-spacing: 0;
text-align: left;
width: 80px;
line-height: 1;
}
.faq__accordion-footer {
text-align: right;
padding: 0 0 10px;
font-weight: bold;
font-size: 22px;
}
span.faq__a {
color: var(--bl);
}
.contact-form__inner .c-title {
width: 40%;
}
.contact-form__right {
width: 60%;
margin-top: 1rem;
}

/* ================
    開いたら”+”を非表示
    =================== */
/* 初期は＋（半透明） */
/* .faq__accordion-icon::before {
  content: "+";
  color: rgba(0, 0, 0, 0.3);
  font-weight: bold;
  font-size: 20px;
  display: inline-block;
  width: 1em;
  text-align: center;
} */

/* アコーディオンが開いたらアイコンごと消す */
.faq__accordion.open .faq__accordion-icon {
  display: none;
}
/* /. 開いたら”+”を非表示 */

    @media(max-width:768px){
    .faq__inner {
    flex-direction: column;
    }
    .faq__inner h2 {
    width: 100%;
    }
    .faq__accordion__list {
    width: 100%;
    gap: 0 5%;
    }
    .faq__accordion-content p {
    font-size: 12px;
    letter-spacing: 0;
    font-weight: 500;
    margin: 0;
    width: calc(100% - 40px);
    }
    .faq__accordion-header h3 {
    width: calc(100% - 40px);
    font-size: 14px;
    letter-spacing: 0;
    }
    .faq__q, .faq__a {
    font-size: 28px;
    width: 40px;
    }
    }

/*===============================
        CONTACT-page__swiper
===============================*/
.contact__img--wrap {
margin-top: 175px;
}
.contact__img {
    width: 100%;
}
.contact__img img {
width: 100%;
vertical-align: bottom;
object-fit: cover;
}

@media(max-width:768px){
.contact__img img {
object-fit: cover;
width: 100%;
}
.contact__img {
width: 100%;
}
}

/*===============================
        CONTACT-page__form
===============================*/
.form {
    width: 100%;
    font-size:var(--fz_22);
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: 0.03em;
    text-align: left;
}
td.radio-wrap.flex label,
td.radio-wrap.block label {
    font-weight: 400;
    display: flex;
    align-items: center;
    margin-right: 2em;
}
.contact-form {
    padding: 150px 5% 0;
}
.contact-form__inner {
    display: flex;
    justify-content: space-between;
    max-width: 1720px;
    margin: 0 auto;
}
.contact-form__inner .c-title::before {
  position: absolute;
  content: "お問い合わせフォーム";
}
.form__wrap {
    margin-top: 100px;
}
.contact-form__right h4 {
    font-size: var(--fz_24);
    font-weight: bold;
    letter-spacing: 0.05em;
    line-height: 1.75;
}
.form th {
    display: block;
    text-align: left;
}
.form td {
    display: block;
    text-align: left;
}
td.radio-wrap.block label {
    display: block;
}
input[type="radio"] {
    margin-right: 16px;
    margin: auto 13px auto 3px;
}
td.radio-wrap.block label {
    display: flex;
    align-items: center;
}
input#your-office,
input#your-name,
input#ruby,
input#tel,
input#email,
textarea#message {
    width: calc(100% - 60px);
    padding: 16px 32px;
    margin-top: 16px;
    border-radius: 0;
    border: none;
    color: var(--bk);
    font-size:var(--fz_22);
    font-weight: 400;
    font-family: var(--Zen-Kaku-Gothic-New);
}
textarea#message {
  line-height: 1.5;
}
input#post,
input#prefecture,
input#address {
    padding: 16px 32px;
    margin-top: 16px;
    border-radius: 0;
    border: none;
    color: var(--bk);
    font-size:var(--fz_22);
}
input#post {
  padding: 16px 32px 16px 60px;
  width: 120px;
}
input#prefecture {
  width: 180px;
}
input#address {
    width: calc(100% - 60px);
}


/* 〒 */
.postCode-icon {
    position: absolute;
    color: #2E2E2E;
    z-index: 1;
    top: 27px;
    left: 30px;
}
/* ./ 〒 */

.address_wrap {
    position: relative;
    gap: 16px;
    display: flex;
    margin-bottom: 14px;
}
td.radio-wrap.flex {
    margin-top: 16px;
    gap: 60px;
    display: flex;
}
input::placeholder,
textarea::placeholder {
  color: #2E2E2E;
  font-size:var(--fz_22);
  font-weight: 400;
  letter-spacing: 0.03em;
  line-height: 1.5;
  display: flex;
  align-items: center;
  font-family: var(--Zen-Kaku-Gothic-New);
}
label.required {
    position: relative;
}
label.required::after {
    position: absolute;
    content: "*";
    color: var(--red);
    top: -.6rem;
    font-size: clamp(22px, 1.1666vw, 32px);
    right: -1rem;
    font-weight: bold;
}
div#char-count {
    text-align: right;
    font-weight: 400;
    font-size: 12px;
}


/* CONTACT-page__確認ボタン */
td.submit-td {
    text-align: center;
    margin-top: 60px;
}

/* 確認ボタン */
td.submit-td input,
/* 送信ボタン */
input.btn-submit,
/* トップへ戻るボタン */
a.btn-submit {
    border-radius: 0;
    border: solid 1px #000;
    width: 260px;
    height: 54px;
    color: #000;
    background: #fff; /* 通常時は白背景 */
    font-weight: bold;
    cursor: pointer;
    transition: all 0.3s ease; /* スムーズに変化 */
    font-size: 22px;
    padding: 0;
    text-align: center;
    line-height: 54px; /* 高さと同じにして垂直中央揃え */
    display: block;/*a.btn-submit用*/
    margin: 0 auto;/*a.btn-submit用*/
}

      @media(max-width:768px){
      td.submit-td input, input.btn-submit, a.btn-submit {
      width: 160px;
      height: 38px;
      font-size: 14px;
      padding: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      line-height: 1;
      }
      label.required::after {
      top: -.5em;
      font-size: 18px;
      }
      .form__wrap {
      margin-top: 35px;
      }
      input::placeholder,
      textarea::placeholder {
      font-size: 14px;
      }

    }


/* =====
  送信ボタン
  ===== */
.contact-confirm__inner .submit-wrap {
    text-align: center;
}

/* 送信ボタン */
input.btn-submit:hover,
/* 送信ボタン */
td.submit-td input:hover,
/* トップへ戻るボタン */
a.btn-submit:hover {
    border: 1px solid var(--wh);
    background: var(--bk);
    color: var(--wh);
}

/* トップへ戻るボタン */
a.btn-submit {
    text-decoration: none;
}

.under-line {
    color: var(--wh);
    margin-left: 16px;
}
a.checkbox-a {
    text-decoration: underline;
    text-decoration-color: var(--wh);
}
td.privacy-box {
    text-align: center;
}
table.form tbody {
    gap: 40px;
    display: grid;
}
td.radio-wrap.block {
    display: grid;
    gap: 30px;
    margin-top: 16px;
}


    @media(max-width:768px){
    .contact-form__inner {
    flex-direction: column;
    }
    .contact-form__inner .c-title {
    width: 100%;
    }
    .contact-form__right {
    width: 100%;
    margin-top: 1rem;
    }
    .contact-form__right h4 {
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;
    }
    .contact-form {
    padding: 100px 5% 0;
    }

    .form {
    font-size: 14px;
    line-height: 1.5;
    letter-spacing: 0.05em;
    }
    td.radio-wrap.flex {
    display: grid;
    gap: 16px;
    }
    table.form tbody {
    gap: 28px;
    }
    input#your-office, input#your-name, input#ruby, input#tel, input#email, textarea#message {
    width: calc(100% - 40px);
    padding: 10px 20px;
    margin-top: 16px;
    border-radius: 0;
    border: none;
    color: var(--bk);
    font-size: 14px;
    font-weight: 400;
    }
    textarea#message {
    width: calc(100% - 40px);
    }
    input#address {
    width: calc(100% - 40px);
    padding: 10px 20px;
    }


    input#your-office,
    input#your-name,
    input#ruby,
    input#tel,
    input#email,
    textarea#message,
    input#post,
    input#address{
    width: calc(100% - 40px);
    padding: 10px 20px;
    margin-top: 16px;
    border-radius: 0;
    border: none;
    color: var(--bk);
    font-size: 14px;
    font-weight: 400;
    }
    input#prefecture {
    width: 130px;
    padding: 10px 20px;
    font-size: 14px;
    }
    input#post {
    padding: 10px 10px 10px 40px;
    width: 80px;
    }
    .postCode-icon {
    top: 23px;
    left: 20px;
    }
    }

/*===============================
        CONTACT-page__ラジオボタン
===============================*/
/* ラジオボタンのベース */
input[type="radio"] {
    appearance: none;        /* 標準スタイルを消す */
    -webkit-appearance: none;
    -moz-appearance: none;
    position: relative;
    width: 20px;
    height: 20px;
    border: 2px solid #fff;
    border-radius: 50%;      /* 常に円形にする */
    cursor: pointer;
    outline: none;
    margin-right: 8px;
    vertical-align: middle;  /* テキストと高さを揃える */
    background: #fff;        /* 中は白 */
    transition: border-color 0.3s, background 0.3s;
    min-width: 20px;
    min-height: 20px;
}



/* 内側の丸 */
input[type="radio"]::after {
    content: "";
    position: absolute;
    width: 10px;
    height: 10px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: transparent;   /* デフォルトは透明 */
    transition: background 0.3s;
}

/* チェック時に赤丸を表示 */
[type="radio"]:checked::after {
    background: var(--red);
}


/*===============================
        CONTACT-page__プライバシーポリシー
===============================*/
.Form__scrollArea {
  max-height: 200px;   /* 好きな高さに調整 */
  overflow-y: auto;
  padding: 10px;
  background: #f9f9f9;
  margin-bottom: 10px;
  padding: 30px 5%;
  margin-top: 16px;
}
.Form__privacy h2 {
  font-size: 14px;
  margin-top: 0;
}
.Form__privacy h3 {
  font-size: 13px;
  margin: 10px 0 5px;
}
.Form__privacy p {
  font-size: 13px;
  margin: 0 0 10px;
  line-height: 1.6;
}


/* Chrome, Edge, Safari 用 */
.Form__scrollArea::-webkit-scrollbar {
  width: 8px; /* スクロールバーの太さ */
}
.Form__scrollArea::-webkit-scrollbar-thumb {
  background-color: var(--red); /* 持ち手を赤に */
  border-radius: 4px;
}
.Form__scrollArea::-webkit-scrollbar-track {
  background: var(--red); /* 背景グレー */
}

/* Firefox 用 */
.Form__scrollArea {
  scrollbar-width: thin;
  scrollbar-color: var(--red) #eee;
}

.Form__privacy h2,
.Form__privacy h2::first-letter,
.Form__privacy h3,
.Form__privacy h4,
.Form__privacy p {
  color: #2E2E2E;
  letter-spacing: 0.03em;
  line-height: 1.78;
  font-size: 18px;
  font-weight: 400;
  margin-bottom: 1rem;
}


/*===============================
        CONTACT-page__チェックボックス
===============================*/
.privacy-box {
    text-align: center;
    margin-top: 80px;
}
/* チェックボックスを隠す */
/*
.privacy-box input[type="checkbox"] {
  display: none;
}
*/
/* ラベルに背景画像を設定（未チェック状態） *//*
.privacy-box label.checkbox {
  position: relative;
  padding-left: 28px; /* 画像分の余白 */
  cursor: pointer;
  background: url("../images/contact/check_off.svg") no-repeat left center;
  background-size: contain;
}
*/
/* チェック済み時 */
/*
.privacy-box input[type="checkbox"]:checked + label.checkbox {
  background-image: url("../images/contact/check_on.svg");
}*/


input[type=checkbox] {
  position: relative;
  width: 16px;
  height: 16px;
  border: 2px solid #222;
  background-color: rgba(255, 255, 255, 0.5);
  border-radius: 5px;
}
@media screen and (max-width: 768px) {
  input[type=checkbox] {
    border: 1px solid #222;
  }
}

/*===============================
        CONTACT-page__confirm
===============================*/
.contact-confirm__inner h2 {
  text-align: center;
  line-height: 1;
  margin-top: 10px;
}

.contact-confirm {
    padding: 0 5%;
}
.contact-confirm__inner {
    max-width: 1720px;
    margin: 0 auto;
    width: 100%;
}
.contact-confirm__inner::before {
  content: "入力内容確認画面";
  text-align: center;
  display: block;
}
.contact-confirm__form {
    width: 100%;
    max-width: 1290px;
    margin: 40px auto 0;
}
.contact-confirm__form th {
    text-align: right;
    font-size: var(--fz_22);
    width: 43%;
    text-align: right;
    padding: 30px 5% 30px 0;
}
.contact-confirm__form td {
    width: 52%;
    text-align: left;
    padding: 30px 0;
    font-size: var(--fz_22);
}
.contact-confirm__privacy td {
    width: 78%;
}
.contact-confirm__privacy {
    width: 100%;
}
.contact-confirm__privacy h2 {
  text-align: left;
  font-size: 18px;
}
.contact-confirm__privacy tr {
    padding: 30px 0 0;
    display: flex;
    align-items: self-start;
    max-width: 1290px;
    margin: 0 auto;
    font-size: var(--fz_22);
}
.contact-confirm__privacy th {
    padding: 30px 0;
    width: 22%;
    font-size: var(--fz_22);
}
.contact-confirm__privacy .Form__scrollArea {
    max-width: calc(1016px - 10%);
}
.contact-confirm__form--wrap .postCode-icon {
    top: 0;
    left: -20px;
    color: #fff;
}
.contact-confirm__form--wrap .address_wrap {
    margin-left: 20px;
    margin-bottom: 0;
}

    @media(max-width:768px){
    .contact-confirm__inner::before {
    text-align: left;
    }
    .contact-confirm__inner h2 {
    text-align: left;
    margin-top: 0;
    }
    .contact-confirm {
    padding: 85px 5% 23px;
    }

    .contact-confirm__form th {
    text-align: right;
    padding: 5px 0;
    font-size: 14px;
    width: 100%;
    text-align: left;
    display: block;
    }
    .contact-confirm__form td {
    width: 100%;
    text-align: left;
    padding: 5px 0;
    font-size: 14px;
    display: block;
    font-weight: 400;
    margin-bottom: 36px;
    }
    .contact-confirm__form--wrap .postCode-icon {
        top: 0;
        left: -20px;
    }

    table.contact-confirm__privacy tr {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    padding: 0;
    }
    .contact-confirm__privacy th {
    text-align: left;
    padding: 5px 0;
    width: 100%;
    font-size: 14px;
    display: block;
    }
    .contact-confirm__privacy .Form__scrollArea {
    width: 100%;
    }
    .contact-confirm__privacy td {
    width: 90%;
    }
    .under-line {
    color: var(--wh);
    margin-left: 6px;
    }
    .privacy-box label.checkbox {
    font-size: 14px;
    }
    .privacy-box {
    margin-top: 50px;
    }
    .Form__privacy h2, .Form__privacy h2::first-letter, .Form__privacy h3, .Form__privacy h4, .Form__privacy p {
    font-size: 12px;
    }
    .contact-confirm__inner .submit-wrap {
    margin-top: 50px;
    }
    .address_wrap {
    margin-bottom: 0;
    }
    }


/*===============================
        CONTACT-page__thanks
===============================*/
.thanks {
    padding: 70px 5% 20px;
}
.thanks__inner .c-title::before {
  content: "送信完了";
  left: 50%;
  transform: translateX(-50%);
}
.thanks__inner {
  max-width: 1720px;
  margin: 0 auto;
  text-align: center;
}
p.thanks__text {
    margin-top: 70px;
    font-size: var(--fz_25);
    font-weight: bold;
    line-height: 2.28;
    letter-spacing: 0.025em;
    text-align: center;
}
.thanks__inner .submit-wrap {
    margin-top: 100px;
}

    @media(max-width:768px){
    .thanks {
    padding: 67px 4% 0;
    }
    p.thanks__text {
    margin-top: 30px;
    font-size: 13px;
    line-height: 1.67;
    letter-spacing: 0;
    width: 100%;
    }
    .thanks__inner .submit-wrap {
    margin-top: 50px;
    }
    }

/*===============================
        privacy-policy-page__thanks
===============================*/
.privacy {
    padding: 70px 5%;
    font-size: var(--fz_18);
    font-weight: 400;
}
.privacy__inner {
    max-width: 1720px;
    margin: 0 auto;
}
.privacy__inner h2::first-letter {
  color: var(--wh);
}
@media(max-width:768px){
  .privacy {
    padding: 85px 5% 23px;
    font-size: 14px;
    font-weight: 400;
}
}

/*===============================
        固定右下スクロールバー
===============================*/
.bl-scroll {
    position: fixed;
    z-index: 10;
    width: 5px;
    height: 86px;
    transform: translateX(-50%);
    overflow: hidden;
    bottom: 0;
    right: 0;
    background-color: #505050;
}
.scroll_bar {
    display: block;
    position: absolute;
    top: -80px;
    left: 0;
    width: 5px;
    height: 86px;
    animation: shootingStar 4s linear infinite;
    background-color: #fff;
}
@keyframes shootingStar {
  0% {
      transform: translateY(0);
      opacity: 1;
  }
  95% {
      transform: translateY(100vh);
      opacity: 1;
  }
  100% {
      transform: translateY(0);
      opacity: 0;
  }
}


.service__mv--item {
  position: absolute;
  top: 0;
  right: 0;
}
.clip-wrapper {
  position: relative;
  margin: 0 0 0 auto;
  width: 95vw;
  height: 90vh;
}

/* 下の背景 */
.clip-bg {
  position: absolute;
  bottom: -3vh;    /* 下に少しずらす */
  left: 5vw;   /* 右に少しずらす */
  right: 0;
  top: 0;
  width: 90vw;
  height: 93vh;
  background: var(--wh);
  clip-path: url(#clip-shape);
  -webkit-clip-path: url(#clip-shape);
  z-index: 1;
}

/* 上の動画よりも遅らせて表示させるため */
.clip-bg {
  opacity: 0; /* 最初は見えない */
  transition: opacity 0.3s ease;
}

/* 上の画像 */
.clip-top {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  clip-path: url(#clip-shape);
  -webkit-clip-path: url(#clip-shape);
  z-index: 2;
}

.clip-top video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.6);
}

/* 共通：PC用（デフォルト） */
.clip-bg,
.clip-top {
  clip-path: url(#clip-shape);
  -webkit-clip-path: url(#clip-shape); /* Safari対応 */
}

    /* SP用：768px以下で切り替え */
    @media screen and (max-width: 768px) {
    .service__mv {
    padding: 0;
    }
    .clip-bg,
    .clip-top {
    clip-path: url(#clip-shape-sp);
    -webkit-clip-path: url(#clip-shape-sp);
    }
    .clip-wrapper {
    margin: 0;
    width: 100vw;
    height: 85vh;
    }
    .clip-bg {
    bottom: -2vh;
    left: 0;
    right: 0;
    top: 0;
    width: 90vw;
    height: 87vh;
    margin-left: 10vw;
    }
    .service__mv--inner .bredcrumb__wrap {
    position: absolute;
    padding: 0;
    bottom: auto;
    right: 0;
    z-index: 10;
    width: 100%;
    }
    .service__mv-ttl--wrap {
    bottom: -20px;
    }
    .service-dmah .service__mv-ttl--wrap {
    bottom: -50px;
    }
    .service-dmah .service__mv--wave {
    height: calc(100vh + 50px);
    }
    .service__mv-ttl h2 {
    font-size: 40px;
    }
    .service__mv-ttl h2 span {
    font-size: 35px;
    }
    span.service-sensor__mv-ttl--span {
    margin-left: 0.5em;
    }
    .service__mv a.play-video {
    bottom: 60px;
    right: 0;
    }
    .service__mv-ttl {
    left: 50%;
    transform: translate(-50%, -50%);
    width: max-content;
    }
    .service__mv--inner .bredcrumb .active {
    color: var(--wh);
    }
    .service__mv--inner h3 {
        bottom: -60px;
    }
    .service__mv--inner h3 {
        font-size: 30px;
    }
    .service-dmah .service__mv {
        padding: 0;
    }
    }


/*===============================
    wp contact-form
===============================*/
span.wpcf7-form-control.wpcf7-radio.class-name span {
    display: grid;
    gap: 15px;
}
span.wpcf7-spinner {
    display: none;
}
.contact-confirm__form--wrap .form td {
    font-weight: 400;
    display: block;
    text-align: left;
    margin-top: 0;
}
.contact-confirm__form--wrap tr {
    display: flex;
    justify-content: center;
    column-gap: 4%;
}
.contact-confirm__form--wrap td.radio-wrap.flex {
    margin-top: 0;
}
.contact-confirm__form--wrap td.radio-wrap.block {
    margin-top: 0;
}
.contact-confirm__form--wrap .form th {
    width: 40%;
    text-align: right;
}
.contact-confirm__form--wrap .form td {
    width: 56%;
    text-align: left;
}
.contact-confirm__form--wrap .form tr.confirm__policy th {
    width: 20%;
    text-align: right;
}
.contact-confirm__form--wrap .form tr.confirm__policy td {
    width: 76%;
    text-align: right;
}
tr.confirm__policy .Form__scrollArea {
    text-align: left;
}
tr.confirm__policy .Form__privacy h2 {
    text-align: left;
}
.contact-confirm__form--wrap .privacy-box {
    text-align: center;
    margin-top: 40px;
}
.contact-confirm__form--wrap td.prev-td a {
    border-radius: 0;
    border: solid 1px #000;
    width: 260px;
    height: 54px;
    color: #fff;
    background: transparent;
    font-weight: bold;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 22px;
    padding: 0;
    text-align: center;
    line-height: 54px;
    display: block;
    margin: 0 auto;
    border: none;
}
.contact-confirm__form--wrap tr.prev-wrap {
    margin-top: 60px;
    margin-bottom: -20px;
}
.contact-confirm__form--wrap {
    margin-top: 75px;
}

    @media(max-width:768px){
    .contact-confirm__form--wrap {
      margin-top: 30px;
    }
    .contact-confirm__form--wrap tr {
    flex-direction: column;
    }
    .contact-confirm__form--wrap .form th,
    .contact-confirm__form--wrap .form td,
    .contact-confirm__form--wrap .form tr.confirm__policy th,
    .contact-confirm__form--wrap .form tr.confirm__policy td {
    width: 100%;
    text-align: left;
    }
    .contact-confirm__form--wrap .privacy-box {
    margin-top: 20px;
    }
    .contact-confirm__form--wrap td.prev-td a {
    font-size: 14px;
    }
    .contact-confirm__form--wrap tr.prev-wrap {
    margin-top: 0;
    margin-bottom: -20px;
    }
    .contact-confirm__form--wrap td.prev-td a {
    width: 160px;
    height: 38px;
    font-size: 14px;
    display: flex;
    }
    .contact-confirm__inner .submit-wrap {
    margin-top: 0;
    }
    .contact-confirm__form--wrap .form td {
    margin-top: 10px;
    }
    }


.page2_title,
.page2_text,
.page2_flex {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 1s ease-out, transform 1s ease-out;
}

.page2_title.active,
.page2_text.active,
.page2_flex.active {
  opacity: 1;
  transform: translateY(0);
}


/*===============================
    プライバシーポリシー本文
===============================*/
.privacy-scroll {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch; /* iOS でスムーズスクロール */
  max-height: 400px; /* 必要に応じて高さ指定 */
}







/*===============================
        company-page__mv
===============================*/
.under-mv {
    padding: 0 5%;
}
.under-mv__inner {
    max-width: 1720px;
    margin: 0 auto;
    position: relative;
}
.under-mv__inner img {
  width: 100%;
  object-fit: cover;
  vertical-align: bottom;
}
.under-mv__title {
    position: absolute;
    bottom: 0;
    z-index: 1;
}
.under-mv__title h3 {
    font-size: var(--fz_70);
    font-family: var(--outfit);
    font-weight: bold;
    line-height: 1.07;
}
.under-mv__title h3 span.red {
color: var(--red);
}
.under-mv__title h3 span.blue {
  color: var(--bl);
}
.under-mv__title h4 {
    font-size: var(--fz_33);
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;
    margin-top: 20px;
}
.under-mv__title p {
    font-size: var(--fz_22);
    margin-top: 47px;
    margin-bottom: 130px;
    letter-spacing: 0.03em;
    line-height: 1.8;
    font-weight: 500;
}
.under-mv span.mask {
    position: absolute;
    width: 100%;
    height: 100%;
    background: linear-gradient(20deg, #0B0B0B, transparent);
    top: 0;
}

    @media(max-width:768px){
    .under-mv {
    padding: 0;
    margin-top: 60px;
    }
    .under-mv__title {
    bottom: auto;
    top: 50%;
    }
    .under-mv__title h3 {
    font-size: clamp(32px, 0.4427vw, 34px);
    }
    .under-mv__title h4 {
    font-size: 16px;
    }
    .under-mv.fade-in.company-page h4 {
    margin-top: 3px;
    }
    .under-mv__title p {
    font-size: 13px;
    margin-top: 18px;
    margin-bottom: 0;
    line-height: 1.5;
    }
    .under-mv__title {
        bottom: 0;
        top: auto;
        width: 90%;
        margin-left: 5%;
    }
    }

/*===============================
        company-page__Message
===============================*/
.u-message {
padding: 200px 5% 200px;
}
.u-message__inner {
max-width: 1720px;
margin: 0 auto;
display: flex;
justify-content: space-between;
}
.u-message__inner .c-title::before {
content: "代表挨拶";
}
.u-message__right {
width: 60%;
}
.u-message__img img {
aspect-ratio: 1044 / 534;
width: 100%;
object-fit: cover;
vertical-align: bottom;
}
.u-message__text h4 {
font-size: var(--fz_33);
font-weight: bold;
letter-spacing: 0;
line-height: 1.5;
margin-top: 50px;
}
.u-message__text p {
font-size: var(--fz_22);
letter-spacing: 0.03em;
line-height: 1.63;
font-weight: 500;
margin-top: 1em;
}
p.u-message__name {
font-size: var(--fz_33);
letter-spacing: 0;
line-height: 1.63;
font-weight: bold;
margin-top: 20px;
display: flex;
align-items: center;
justify-content: end;
}
p.u-message__name span {
font-size: var(--fz_24);
letter-spacing: 0.03em;
line-height: 1.63;
font-weight: bold;
margin-right: 30px;
}

    @media(max-width:768px){
    .u-message__inner {
    flex-direction: column;
    }
    .u-message__right {
    width: 100%;
    }
    .u-message__text h4 {
    font-size: 23px;
    margin-top: 25px;
    }
    .u-message {
    padding: 110px 5% 0;
    }
    .u-message__img img {
        aspect-ratio: 350 / 214;
    }
    }

        @media(max-width:376px){
        .u-message__text h4 {
        font-size: 22px;
        }
        .u-message__img img {
        aspect-ratio: 350 / 214;
        }
        .u-message__text p {
        font-size: 13px;
        letter-spacing: 0;
        }
        p.u-message__name span {
        font-size: 13px;
        letter-spacing: 0;
        margin-right: 13px;
        }
        p.u-message__name {
        font-size: 18px;
        margin-top: 15px;
        }
        }

/*===============================
        company-page__philosophy,
        company-page__VALUES
===============================*/
.u-philo-values {
padding: 200px 5% 0;
text-align: center;
}
.u-philo-values--wrap {
width: 90%;
padding: 185px 5% 230px;
margin: 0 auto;
}
.u-philosophy__inner .c-title::before {
content: "企業理念";
left: 50%;
transform: translateX(-50%);
}
.u-philosophy span.mask {
position: absolute;
width: 100%;
height: 100%;
background: rgba(11, 11, 11, .7);
top: 0;
}
.u-philosophy__inner img {
width: 100%;
object-fit: cover;
vertical-align: bottom;
}
.u-philosophy__title h4 {
font-size: var(--fz_33);
font-weight: bold;
letter-spacing: 0;
line-height: 1.5;
}
.u-philosophy__title p {
margin-top: .9em;
letter-spacing: 0.03em;
line-height: 1.8;
font-weight: 500;
font-size: clamp(13px, 1.1458vw, 22px);
}

.u_philosophy__inner {
margin: 0 5%;
  position: relative;
}


/* ===============================
    company-page 0926追加
=============================== */
.u-philo-values {
  position: relative;
  overflow: hidden;
}

.u-philo-values .bg-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 0;
}

.u-philo-values .bg {
  width: 90%;
  height: 100%;
  background: url(../images/company/philo-value@2x.jpg) center/cover no-repeat;
  margin: 0 auto;
}

.u-philo-values--wrap {
  position: relative;
  z-index: 2;
  width: 90%;
  margin: 0 auto;
  padding: 200px 5%;
  color: #fff;
}

.fade-text {
  font-size: 2rem;
  margin: 200px 0;
  opacity: 1;
  transition: opacity 0.3s;
}
.u-philosophy__lottie {
  position: absolute !important;
  right: 5% !important;
  bottom: 10% !important;
  left: auto !important;
  top: auto !important;
  z-index: 1;
  width: 17% !important;
}

@media(max-width:768px){
    .u-philo-values .bg {
    background: none;
    }
    .u-philo-values--wrap {
    padding: 60px 5% 80px;
    }
    .fixed-stop {
    display: none;
    }
    }
/* ./ company-page 0926追加 */

    @media(max-width:768px){
      .u-philosophy__lottie {
        display: none;
    }
    }

.u-philosophy__lottie::before {
  position: absolute;
  content: "";
  width: 59%;
  height: 77px;
  z-index: 2;
  aspect-ratio: 1 / 1; 
  background-image: url("../images/common/logo-wh.png");
  background-size: contain;   /* 画像を要素に収める */
  background-repeat: no-repeat;
  background-position: center;
  left: 50%;
  transform: translateX(-50%);
  bottom: 4.5vw;
}
.u-philosophy__title {
  position: relative;
}


.u-values__inner {
margin: 230px auto 0;
}
.u-values {
padding: 0 5%;
margin-top: 210px;
}
.u-values__inner .c-title::before {
content: "行動方針";
left: 50%;
transform: translateX(-50%);
}
.u-values span.mask {
position: absolute;
width: 100%;
height: 100%;
background: rgba(11, 11, 11, .7);
top: 0;
}
.u-values__inner img {
width: 100%;
object-fit: cover;
vertical-align: bottom;
}
.u-values__title h4 {
font-size: var(--fz_45);
font-weight: bold;
letter-spacing: 0;
line-height: 1.5;
font-family: var(--outfit);
}
.u-values__title h4 span {
font-size: var(--fz_30);
font-weight: bold;
letter-spacing: 0;
line-height: 1.5;
font-family: var(--outfit);
}
.u-values__title p {
margin-top: .9em;
letter-spacing: 0.03em;
line-height: 1.8;
font-weight: 500;
font-size: clamp(13px, 1.1458vw, 22px);
}

    @media(max-width:768px){
    .u-philo-values--wrap {
    background-image: url(../images/company/philo-value-sp@2x.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    }
    .u-philo-values--wrap {
    padding: 60px 5% 60px;
    }

/* link-position */
div#com_philosophy {
padding-top: 100px;
margin-top: -100px;
}
/* ./ link-position */


    .u-philo-values {
    padding: 100px 5% 0;
    }

    .u-philosophy__title h4 {
    font-size: 21px;
    }
    .u-philosophy__title p,
    .u-values__title p {
    font-size: 13px;
    margin-top: 1em;
    letter-spacing: 0;
    }
    .u-values__title h4 {
    font-size: 24px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.25;
    font-family: var(--outfit);
    }
    .u-values__title h4 span {
    font-size: 20px;
    }
    .u-values__inner {
    margin: 0 auto;
    padding-top: 80px;
    }
    }


/*===============================
        company-page__OUTLINE
===============================*/
.u-outline__inner .c-title::before {
  content: "会社概要";
}
.u-outline {
    padding: 200px 5% 0;
}
.u-outline__inner {
    max-width: 1720px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}

.u-outline__table {
    max-width: 1044px;
    width: 60%;
}
.u-outline__table td:first-child {
    width: 25%;
    padding: 26px 0;
    font-size: var(--fz_24);
    font-weight: bold;
    letter-spacing: 0.03em;
    line-height: 1.5;
}
.u-outline__table td:nth-child(2) {
    width: 75%;
    padding: 26px 0;
    font-size: var(--fz_24);
    font-weight: 500;
    letter-spacing: 0.03em;
    line-height: 1.5;
}
.u-outline__table td.nth-child {
    font-weight: 500;
}
.u-outline__table  tr {
    border-bottom: solid 1px #A8A8A8;
}

.gm-style {
    filter: grayscale(1);
}

@media(max-width:768px){
  .u-outline__inner {
    flex-direction: column;
}
.u-outline__table {
    width: 100%;
}
.u-outline {
    padding: 100px 5% 0;
}
.u-outline__table td:first-child {
    width: 100%;
    display: block;
    font-size: 14px;
    font-weight: bold;
    padding: 14px 0 10px;
}
.u-outline__table td:nth-child(2) {
    width: 100%;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0;
    display: block;
    padding: 0 0 14px;
}
}


/*===============================
        company-page__HEALTH and Productivity
===============================*/
.u-health {
    padding: 200px 5% 0;
}
.u-health__inner .c-title.two-steps.__hecompanies--ttl::before {
  content: "地域未来牽引企業";
  margin-top: -1.5em;
}
.u-health__inner .c-title.two-steps.__partner--ttl::before {
  content: "パートナーシップ構築宣言";
  margin-top: -1.5em;
}

.u-health__inner {
    display: flex;
    justify-content: space-between;
    max-width: 1720px;
    margin: 0 auto;
}
.u-health__left {
    width: 30%;
}
.u-health__right {
    width: 60%;
    margin-top: 0;
}
.u-health__img {
    width: 74.2%;
    margin: 38px auto 0;
}
.u-health__img.__hecompanies--img {
    width: 74%;
    max-width: 320px;
}
.u-health__img.__partner--img {
    width: 100%;
    max-width: 430px;
}
.u-health__img img {
  width: 100%;
  object-fit: cover;
}
.u-health__right h4 {
  font-size: var(--fz_33);
  font-weight: bold;
  letter-spacing: 0;
  line-height: 1.5;
}
.u-health__right p {
  margin-top: 1em;
  font-size: var(--fz_22);
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.63;
}

.u-health__link {
    display: flex;
    align-items: center;
    justify-content: end;
    margin-top: 30px;
}
.u-health__link a {
  color: var(--bl);
  font-size: var(--fz_22);
  font-weight: 500;
  line-height: 1.63;
  letter-spacing: 0.03em;
  text-align: right;
  display: flex;
  align-items: center;
  text-decoration-thickness: 1px; /* 下線の太さ */
  text-underline-offset: 4px; /* 文字から下線までの距離（余白） */
}
.u-health__link a img {
    width: 20px;
    height: 20px;
}
.u-health__link span {
    margin-right: 0.5em;
    color: var(--wh);
    font-size: var(--fz_22);
}

.u-health__title h2 {
    line-height: 1;
    font-size: var(--fz_60);
}
span.first-letter.margin-l {
    margin-left: .5em;
}


    @media(max-width:768px){
    .u-health__inner {
    flex-direction: column;
    }
    .u-health__img {
    width: 54%;
    margin: 32px auto 0;
    }
    .u-health__left {
    width: 100%;
    }
    .u-health__right {
    width: 100%;
    margin-top: 38px;
    }
    .u-health__right h4 {
    font-size: 23px;
    }
    .u-health__right p {
    font-size: 13px;
    letter-spacing: 0;
    }
    .u-health__link a {
    font-size: 14px;
    }
    .u-health {
    padding: 120px 5% 0;
    }
    .u-health__link {
    justify-content: center;
    }
    }

/*contact*/
/* チェック前：check_off.svg */
.checkbox input[type="checkbox"] + .wpcf7-list-item-label:after {
  background: url(../images/contact/check_off.svg) no-repeat center;
  background-size: contain;
  content: "";
  height: 14px;
  width: 14px;
  position: absolute;
  left: -10px;
  margin-right: 10px;
	top:50%;
	transform: translateY(-50%);
}
.checkbox input[type="checkbox"]:checked + .wpcf7-list-item-label:before {
    border: none;
    background-color: transparent;
}
.checkbox input[type="checkbox"]:checked + .wpcf7-list-item-label:after {
    background: url(../images/contact/check_on.svg) no-repeat center;
    background-size: contain;
    content: "";
    height: 14px;
    margin-right: 10px;
    position: absolute;
    width: 14px;
    left: -10px;
top:50%;
transform: translateY(-50%);
}