@charset "utf-8";

/* ・画面幅が最低320pxまでレスポンシブの設定をする
（ブレイクポイントは1024px 768px 480px） */

/* font-family: "Noto Serif JP"; */
/* font-family: "Marcellus", serif; */
/* font-family: "Noto Sans JP"; */

/* 色の変数　　例）color: var(--white); */
:root {
  --black: #000000;
  --black02: #4c4c4c;
  --white: #ffffff;
  --green01: #39b54a;
  --green02: #009245;
  --green03: #006837;
  --green04: #00a03a;
  --green05: rgba(0, 104, 55, 0.9);
  --orange: #f5d29c;
  --gray: #ebebeb;
  --gray02: rgba(242, 242, 242, 0.9);
  --gradation: linear-gradient(90deg, #ffee3b, #ffc13b);
}

/* gradation(yellow):: background-image: linear-gradient(90deg, #ffee3b, #ffc13b); */

:root {
  --Noto-Serif-JP: "Noto Serif JP";
  --Marcellus: "Marcellus";
  --Noto-Sans-JP: "Noto Sans JP";
}

:root {
  --header-height100: 100px;
  --header-height70: 70px;
}

html {
  scroll-behavior: smooth; /* CSSだけで滑らかに移動できる */
}

/* body {
  font-family: "Noto Serif JP";
  font-weight: 500;
} */

main {
  margin-top: var(--header-height100);
}
@media (max-width: 768px) {
  main {
    margin-top: 0;
  }
}

/*******************************************************
ヘッダー
*******************************************************/

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--header-height100);
  z-index: 5;
  background-color: var(--white);
  padding-left: 1.8%;
  padding-right: 1.9%;
  transition: position 0.3s; /* モーダル切り替え用 */

}

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

.header-left {
  display: flex;
  align-items: center;
  flex: 1 1 100%; /* 左右を半々の割合に */
  
  min-width: 0; /* flex内で縮小を許可 */
}

.logo {
    max-width: clamp(185px, 30vw, 216px);
   /* max-width: 216px;  */
  width: 100%;
  display: block;
}

.heder-txt {
   max-width: clamp(90px, 15vw, 180px); 
 /* max-width: 180px; */
  width: 100%;
  /* font-size: 21px;
  font-family: var(--Noto-Serif-JP);
  line-height: 25px;
  color: var(--black);
  text-align: center; */
}

.recruit {
  max-width: clamp(90px, 15vw, 137px); 
  width: 100%;
  font-size: clamp(11px, 2.5vw, 20px);
   line-height: clamp(20px, 5vw, 25px);
  font-family: var(--Marcellus);
  color: var(--white);
  background-color: var(--black);
  padding: 2px 5px;
  text-align: center;
  white-space: nowrap; /* 折り返さない */
}

.header-right {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex: 1 1 50%;
  gap: 20px;
  min-width: 0;
}



@media (max-width: 1024px) {
  

  .header-button {
    display: none;
  }
.header-left {
 flex: 1; 
}

.header-right {
  flex: none; 
}
  
}

@media (max-width: 768px) {
  .header {
    position: static;
    height: var(--header-height70);
     margin-bottom: -12px;
  }
}

@media (max-width: 480px) {
 .heder-txt {
  margin-left: -7px;
 }

 .recruit {
  margin-left: -3px;
  padding: 0;
 }
  
}

@media (max-width: 410px) {
 .logo {
    max-width: clamp(126px, 40vw, 216px);
  width: 100%;
}

.heder-txt {
   max-width: clamp(75px, 15vw, 180px); 
  width: 100%;
}

.recruit {
  max-width: clamp(65px, 15vw, 137px); 
  width: 100%;
  font-size: clamp(11px, 2.5vw, 20px);
   line-height: clamp(15px, 5vw, 25px);
  font-family: var(--Marcellus);
  color: var(--white);
  background-color: var(--black);
  padding: 2px 5px;
  text-align: center;
  white-space: nowrap; 
}
}

/*******************************************************
ハンバーガー
*******************************************************/
.hamburger {
  position: relative;
  width: 43px;
  height: 31px;
  cursor: pointer;
  z-index: 10;
}

/* 線は絶対位置 */
.hamburger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2.5px;
  background-color: var(--black);
  transition: all 0.4s;
}

/* 初期位置 */
.hamburger span:nth-of-type(1) { top: 0; }
.hamburger span:nth-of-type(2) { top: 50%; transform: translateY(-50%); }
.hamburger span:nth-of-type(3) { bottom: 0; }

/* アクティブ時（バツに変形） */
.hamburger.active span:nth-of-type(1) {
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.hamburger.active span:nth-of-type(2) {
  opacity: 0;
}

.hamburger.active span:nth-of-type(3) {
  top: 50%;
  transform: translateY(-50%) rotate(-45deg);
}

.hamburger:hover {
  opacity: 0.5;
}



@media (max-width: 768px) {
  .hamburger {
    position: fixed;
}
}

 @media (max-width: 480px) {
.hamburger {

  width: 35px;
  height: 27px;
} 
}

/* ↓↓↓↓↓↓↓↓↓↓ハンバーガー内メニュー↓↓↓↓↓↓↓↓↓↓ */

/* .burger-mask {
  display: none;
  position: fixed;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  background-color: rgba(0, 0, 0, 0.5);
} */

/* .burger-mask.js-active {
  display: block;
} */

.menu-box {
  padding-top: 100px;
  padding-bottom: 90px;
}

.navi {
  position: fixed;
  z-index: 2;
  top: 0;
  right: -100%;
  width: 100%;
  height: 100%;
  background-color: var(--green05);
  text-align: center;
  overflow-x: hidden;
  overflow-y: auto;
  visibility: hidden;
  transition: all 0.6s;
}

.navi.active {
  visibility: visible;
  right: 0;
}

.menu {
  text-align: center;
}

.menu-list {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  color: var(--white);
  text-decoration: none;
  line-height: 1.5;
  padding-top: 45px;
  min-height: 60px;
  border-bottom: #c9ae87 solid 2px;
  width: min(100%, 391px);
  margin: 0 auto;
}

.menu li:first-child a.menu-list {
  padding-top: 0;
}

.menu-text {
  font-size: clamp(25px, 4vw, 32px);
  font-family: var(--Marcellus);

  letter-spacing: 0.05em;
}

.menu-text-jp {
  font-size: clamp(16px, 2.5vw, 19px);
  font-family: var(--Noto-Serif-JP);

  letter-spacing: 0.05em;
}

.menu-list:hover {
  opacity: 0.7;
}

 .section1 {
  scroll-margin-top: 80px;
} 

@media (max-width: 768px) {
  .section1 {
    scroll-margin-top: 0px;
  }
} 

@media (max-width: 768px) {
  .menu-box {
  padding-top: 50px;
  padding-bottom: 60px;
}
}

 @media (max-width: 480px) {

.menu-list {
 
  width: min(100%, 300px);
}
 }

 @media (max-width: 375px) {
.menu-list {
  flex-direction: column;
  padding-top: 35px;
 gap: 0px;
 width: min(100%, 250px);
}
 }


/*******************************************************
ボタン
*******************************************************/
/* ボタン共通 */
.btn {
  position: relative;
  display: flex;
  color: var(--white);
  font-family: var(--Noto-Sans-JP);
  font-weight: normal;
  justify-content: center;
  align-items: center;
  text-align: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
  transition: all 0.2s ease;
  padding: 0 10px;
}

.btn-green01 {
  background-color: var(--green01);
}

.btn-green02 {
  background-color: var(--green02);
}

.btn-white {
  background-color: var(--white);
}

/* ホバー */
.btn:hover {
  opacity: 0.7;
}

/* ヘッダーボタン */
.header-button {
  max-width: 220px;
  width: 100%;
  height: 60px;
}

.header-btn {
  font-size: 15px;
}

/* メニューボタン */
.menu-button {
  max-width: 450px;
  width: 100%;
  height: 78px;
  margin: 0 auto;
}

.menu-btn {
  font-size: 19px;
  color: var(--green03);
}

.br-400 {
    display: none;
  }

/* セクション01下部、アコーディオン下部ボタン */
.bottom-button,
.ac-button {
  max-width: 306px;
  width: 100%;
  height: 80px;
  margin: 0 auto;
}


.bottom-btn,
.ac-btn {
  font-size: 19px;
}

.ac-button {
  margin-top: 60px; /* ボタン上 */
}

.br--480 {
    display: none;
  }



/* セクション05 お仕事検索ボタン */
.search-button01,.search-button02 {
  max-width: 275px;
  width: 100%;
  height: 80px;
}

.search-btn {
  font-size: 21px;
}

@media (max-width: 768px) {
/* メニューボタン */
.menu-button {
  max-width: 300px;
  
}

.menu-btn {
  font-size: 18px;
}

/* セクション01下部、アコーディオン下部ボタン */
.bottom-button,
.ac-button {
 
  width: 60%;
  height: 65px;
}

.bottom-btn,
.ac-btn {
  font-size: 17px;
}


}

@media (max-width: 480px) {
  .br--480 {
    display: block;
  }

  /* メニューボタン */
.menu-button {
      width: 50%;
    height: 65px; 
}

.menu-btn {
  font-size: 17px;
}

/* セクション01下部、アコーディオン下部ボタン */
  .bottom-btn,
.ac-btn {
  font-size: 15px;
}

/* セクション05 お仕事検索ボタン */
.search-button01,.search-button02 {
  width: 75%;
  height: 60px;
}
.search-btn {
  font-size: 17px;
}
}

@media (max-width: 400px) {
  .br-400 {
    display: block;
  }
}

/*******************************************************
矢印
*******************************************************/

/* ↓↓↓↓矢印01↓↓↓↓ */
.btn-arrow01::before,
.btn-arrow01::after {
  position: absolute;
  top: 50%;
  right: 5%;
  content: "";
}

/* 横棒 */
.btn-arrow01::before {
  background-color: var(--white);
  width: 12px; /* 横棒の長さ */
  height: 2px; /* 横棒の太さ */
  transform: translateY(-50%);
}

/* 矢印の先端（斜め部分） */
.btn-arrow01::after {
  width: 8px; /* 矢印の斜め部分の大きさ */
  height: 8px;
  margin-top: -4px; /* 縦位置を中央に補正 */
  transform: rotate(45deg);
  border-top: 2px solid var(--white);
  border-right: 2px solid var(--white);
  display: inline-block;
  vertical-align: middle;
}
/* ↑↑↑↑矢印01↑↑↑↑ */

/* ↓↓↓↓矢印02,03↓↓↓↓ */
.btn-arrow02::before,
.btn-arrow02::after,.btn-arrow03::before,
.btn-arrow03::after {
  position: absolute;
  top: 50%;
  right: 5%;
  content: "";
}

/* 横棒 */
.btn-arrow02::before {
  background-color: var(--white);
  width: 15px; /* 横棒の長さ */
  height: 2px; /* 横棒の太さ */
  transform: translateY(-50%);
}

/* 矢印の先端（斜め部分） */
.btn-arrow02::after {
  width: 12px; /* 矢印の斜め部分の大きさ */
  height: 12px;
  margin-top: -6px; /* 縦位置を中央に補正 */
  transform: rotate(45deg);
  border-top: 2px solid var(--white);
  border-right: 2px solid var(--white);
  display: inline-block;
  vertical-align: middle;
}

/* 横棒 */
.btn-arrow03::before {
  background-color: var(--green03);
  width: 15px; /* 横棒の長さ */
  height: 2px; /* 横棒の太さ */
  transform: translateY(-50%);
}

/* 矢印の先端（斜め部分） */
.btn-arrow03::after {
  width: 12px; /* 矢印の斜め部分の大きさ */
  height: 12px;
  margin-top: -6px; /* 縦位置を中央に補正 */
  transform: rotate(45deg);
  border-top: 2px solid var(--green03);
  border-right: 2px solid var(--green03);
  display: inline-block;
  vertical-align: middle;
}



/* ↑↑↑↑矢印02,03↑↑↑↑ */

@media (max-width: 480px) {
.btn-arrow02::before {
  background-color: var(--white);
  width: 13px; /* 横棒の長さ */
  height: 2px; /* 横棒の太さ */
  transform: translateY(-50%);
}

.btn-arrow02::after {
  width: 10px; /* 矢印の斜め部分の大きさ */
  height: 10px;
  margin-top: -5px; /* 縦位置を中央に補正 */
 
}
}
/*******************************************************
共通
*******************************************************/
.section-inner {
  max-width: 980px;
  width: 100%;
  margin: 0 auto;
}

@media (max-width: 1000px) {
  .section-inner {
    padding-right: max(5%, 15px);
    padding-left: max(5%, 15px);
  }
}

.section-ttl {
  display: flex;
  align-items: center;
  position: relative;
  gap: 17px;
  padding-left: 20px;
}

.section-ttl::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 72.8px;
  background-color: #c8c8c8;
}

.ttl-eng {
  font-size: 50px;
  font-family: var(--Marcellus);
  color: var(--green03);
  letter-spacing: 0.05em;
  /* padding-bottom: 24px; */
}

.ttl-jp {
  font-size: 19px;
  font-family: var(--Noto-Serif-JP);
  color: var(--green03);
  letter-spacing: 0.2em;
  /* padding-bottom: 1em; */
}


@media (max-width: 1024px) {
  .ttl-eng {
  font-size: 43px;
}
.ttl-jp {
  font-size: 18px;
}
.section-ttl::before {
  height: 62px;
}
}

@media (max-width: 480px) {
.section-ttl {
    display: block;
  }

  .ttl-eng {
  font-size: 38px;
  padding-bottom: 10px;
}
.ttl-jp {
  font-size: 16px;
}
.section-ttl::before {
  height: 70px;
}
}

@media (max-width: 375px) {

  .ttl-eng {
  font-size: 30px;
}
.ttl-jp {
  font-size: 15px;
}
.section-ttl::before {
  height: 65px;
}
}

/*******************************************************
MV
*******************************************************/
.mv {
   position: relative;
    width: 100%;
    aspect-ratio: 1320 / 829;
    overflow: hidden;
}

.mv-slide {
  position: absolute;  /* ← ここを absolute に戻す */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 1s ease-in-out; /* フェード切替 */
}

.mv-slide.active {
  opacity: 1;
  z-index: 1;
}

.mv-slide img {
  width: 100%;
  height: 100%;
    object-fit: contain;      /* 縦横比を保ちつつ全体表示 */
  object-position: center;  /* 中央基準で配置 */
}

@media (max-width: 860px) {

  .mv {
    aspect-ratio: 980 / 1072;
}
  .mv-slide img {
    object-position: center top; /* スマホでは上寄せ */
  }
}

/*******************************************************
1.セクション
*******************************************************/
.section1 {
  position: relative;
  background-color: var(--white);
  padding-top: 67px;
  padding-bottom: 92px;
  overflow: hidden;
  z-index: 0;
}

@media (max-width: 840px) {
.section1 {
    padding-top: 60px;
}
}

@media (max-width: 480px) {
.section1 {
   padding-bottom: 55px;
}
}



.ttl-1 {
margin-bottom: 40px;
}

/* .message-box */

/* .message-box {
  margin-bottom: -50px;
} */

.message-head {
  font-size: 34px;
  font-family: var(--Noto-Serif-JP);
   font-weight: 500;
  color: var(--black);
  padding-bottom: 45px;
}

.message-pair {
  position: relative;
}

.txtbox01,
.txtbox02 {
  position: relative; 
}


.txtbox01 {
  margin-bottom: 266px;
}

.txtbox02 {
  margin-left: auto;
  margin-bottom: 598px;
}

.message-pic01,
.message-pic02 {
  position: absolute;
  z-index: -1;
}

.message-pic01 {
  /* 800 */
   width: 57.77%;
top: 17%;  
  right: 0;     
 
}

.message-pic02 {
   width: 100%;
 top: 38.3%;
}

.message-txtbox {
  background-color: var(--gray02);
  max-width: 700px;
  width: 100%;
  padding: 30px 0;
}

.message-txt {
  font-size: 19px;
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  color: var(--black);
  line-height: 1.8;
  letter-spacing: 0.05em;
  max-width: 625px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
}

.br-640,.br-540,.br-528 {
  display: none;
}

@media (max-width: 1024px) {
  .message-head {
  font-size: 28px;
}


.message-txt {
  font-size: 18px;
}

.txtbox02 {
  margin-bottom: 400px;
}

.message-pic01 {

  top: 23%;  
}

.message-pic02 {
  width: 100%;
  top: 44%;
}
}


@media (max-width: 860px) {
  .message-pic01 {
  top: 27%;  
}

.message-pic02 {
  top: 50%;
}
}

@media (max-width: 840px) {
.br-840-non {
  display: none;
}

.message-txt {
  font-size: 16px;
      max-width: 625px;
    width: 100%;
}

.message-pic01 {
  top: 23%;  
}


}

@media (max-width: 768px) {

  .message-head {
  font-size: clamp(21px, 6vw, 28px);
}


.message-txtbox {
  max-width: 678px; 
  width: 100%;
  padding: 30px 15px; 
}

.txtbox01 {
  margin-bottom: 300px;
}

.txtbox02 {
  margin-bottom: 425px;
}

.message-txt {
  justify-content: center;
  width: fit-content;
}

.message-pic01 {
  width: 90%;
  top: 25%;  
}

.message-pic02 {
  top: 47%;
}
}

@media (max-width: 650px) {
  .message-txt {
  font-size: 15px;
}
}

@media (max-width: 640px) {
  .br-640{
   display: block;
  }

  .message-head {
    line-height: 1.6;
  }

  .message-pic01 {
  top: 26%;  
}

.message-pic02 {
  top: 52%;
}
}

@media (max-width: 540px) {
  .br-540,.br-840-non {
    display: block;
  }

  .txtbox01 {
        margin-bottom: 215px;
      }

      .txtbox02 {
  margin-bottom: 370px;
}

  .message-pic01 {
  top: 31%;  
}

.message-pic02 {
  top: 54%;
}
}

@media (max-width: 530px) {

  .txtbox02 {
  margin-bottom: 330px;
}
 
 .message-pic01 {
  top: 33%;  
}

.message-pic02 {
  top: 55%;
}
}

@media (max-width: 528px) {
.br-528 {
  display: block;
}
}

@media (max-width: 480px) {
.message-pic01 {
  top: 34%;  
}

.message-pic02 {
  top: 57%;
}
}

@media (max-width: 450px) {
.message-pic01 {
  top: 34%;  
}

.message-pic02 {
  top: 57%;
}
}

@media (max-width: 435px) {
    .br-435-non {
        display: none;
}

.message-pic02 {
        top: 58%;
}
}

@media (max-width: 400px){
.txtbox01 {
  margin-bottom: 175px;
}

.txtbox02 {
  margin-bottom: 275px;
}

.message-pic01 {
  top: 37%;  
}

.message-pic02 {
        top: 61%;
}
}

@media (max-width: 381px) {
.br-840-non {
    display: none;
  }
}

@media (max-width: 356px) {
.br-528 {
  display: none;
}
}

@media (max-width: 345px) {
  .br-345-non {
    display: none;
  }

  .txtbox01 {
  margin-bottom: 150px;
}

.message-pic01 {
  top: 38%;  
}
}


/* ↓↓↓↓↓↓↓↓↓↓写真スライド01↓↓↓↓↓↓↓↓↓↓ */
.slide-box01 {
  background-color: var(--white);
  display: flex;
  overflow-x: hidden;
  padding-top: 158px;
}

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

.content01 {
  display: flex; 
  align-items: center; 
  justify-content: center; 
  padding-right: 7px;
}

.content01 img {
  width: 487px;

  height: auto;
  display: block;
}

.slideshow {
  animation-name: loop-slide; /* アニメーション名 */
  animation-duration: 30s; /* 開始から終了までの所要時間 */
  animation-iteration-count: infinite; /* アニメーションのループ回数 */
  animation-timing-function: linear; /* 動きの加減速 */
  animation-delay: 1s; /* アニメーションが開始するまでの遅延時間 */
  animation-fill-mode: both; /* アニメーション開始前・終了後の挙動 */
}

@keyframes loop-slide {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

@media (max-width: 860px) {
.slide-box01 {
    padding-top: 60px;
}

  .content01 img {
  width: 265px;
}

.slideshow {
  animation-duration: 20s; /* 開始から終了までの所要時間 */
}
}
/*******************************************************
2.セクション
*******************************************************/

.section2 {
  background-color: var(--gray);
  background-image: 
    url(../img/04-aboutjob/backpic01.jpg),
    url(../img/04-aboutjob/backpic02.jpg),
    url(../img/04-aboutjob/backpic03.jpg);
  background-size: 42% auto, 43% auto, 40% auto;
  background-position: 
    -25% 23%,        /* ← 左に少しはみ出す */
    124% 60%,     /* → 右に少しはみ出す */
    -13% bottom;      /* ← 左下も少しはみ出す */
  background-repeat: no-repeat, no-repeat, no-repeat;
  padding-top: 155px;
  padding-bottom: 207px;
}
.ttl-2 {
margin-bottom: 86px;
}
@media (min-width: 2000px) {
  .section2 {
    background-size: 840px auto, 860px auto, 800px auto; /* 固定値に変える */
    background-position: 0% 23%, 100% 60%, 0% bottom;
  }
}

@media (max-width: 840px) {
.section2 {
    padding-top: 90px;
    padding-bottom: 140px;
}
}

@media (max-width: 768px) {


.section2 {
  
  background-image: none
  
}

.ttl-2 {
margin-bottom: 60px;
}
}

@media (max-width: 480px) {
.section2 {
    padding-top: 60px;
    padding-bottom: 75px;
}
}

/* ===============================
  タブボタン
=============================== */

.tabbutton-list {
  padding: 0 20px;
}

.tab-menu {
  display: flex;

  justify-content: center;
  gap: 19px;
  margin-bottom: 44px;
}

.tab-item {
  flex: 0 0 auto; /* 自動伸縮をやめる */
}

/* タブボタン（ベースデザイン） */
.tab-button {
  position: relative;
  display: flex;
  flex-direction: column;
  text-align: center;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  font-size: 19px;
  font-family: var(--Noto-Sans-JP);
  color: var(--green04);
  background-color: var(--white);
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
  width: 180px;
  height: 80px;
}

/* hover時 */
.tab-button:hover {
  opacity: 0.85;
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0, 176, 171, 0.3);
}

/* active時（選択中タブ） */
.tab-button.active {
  color: var(--white);
  background-color: var(--green02);
}

.br-520 {
  display: none;
}

@media (max-width: 1024px) {
.tab-button {
  font-size: 17px;
  width: 140px;
  height: 75px;
}
}


 @media (max-width: 820px) {
  .tabbutton-list {
    padding: 0;
  }

  .tab-menu {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    row-gap: 15px;
    column-gap: 10px;
    position: relative;
  }

  .tab-item:nth-child(-n+3) {
    flex: 0 0 calc((100% - 20px) / 3);
  }


  .tab-item:nth-child(n+4) {
    flex: 0 0 calc((100% - 20px) / 3);
  }

  .tab-item:last-child::after {
    content: "";
    flex: 0 0 calc((100% - 20px) / 3);
  }

  .tab-button {
    width: 100%;
    height: 80px;
    font-size: 19px;
  }
}

 @media (max-width: 520px) {
  .br-520 {
  display: block;
}

 .tab-button {
    height: 70px;
    font-size: 17px;
  }
 }

  @media (max-width: 375px) {

 .tab-button {
    height: 60px;
    font-size: 15px;
  }
 }

/* ===============================
  コンテンツパネル
=============================== */
.tab-inner {
max-width: 980px;
  width: 100%;
  margin: 0 auto;
}

@media (max-width: 1000px) {
  .tab-inner {
    padding-right: max(5%, 15px);
    padding-left: max(5%, 15px);
  }
}

@media (max-width: 768px) {
 .tab-inner {
    max-width: none;
    width: 100%;
    margin: 0;
    padding-right: 0;
    padding-left: 0;
  }
}

/* コンテンツパネル群 */
.tab-panel {
  /* 
  margin: 0 auto;
  
  display: none; */

  background-color: var(--white);
   position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  visibility: hidden;
  pointer-events: none; /* 非表示中クリック防止 */
  transition: opacity 0.4s ease;
  padding-top: 45px;
}



.tab-panel.active {
  /* display: block; */
  position: relative;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 1;
}

.panel-top {
  padding: 0 40px;
}

.contents-head {
  background-image: var(--gradation);
  font-size: 38px;
  font-family: var(--Noto-Serif-JP);
  color: var(--black);
  line-height: 80px;
  letter-spacing: 0.3em;
  text-align: center;
  max-width: 896px;
  width: 100%;
  margin: 0 auto;
  margin-bottom: 33px;
}

.panel-contents {
  display: flex;
  gap: 33px;
  margin-bottom: 58px;
}

.contents-pic {
  width: 431px;
  flex: 1;
}

.contents-txt {
  font-size: 19px;
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  color: var(--black);
  text-align: justify;
   line-height: 2;
  letter-spacing: 0.01em;
  max-width: 431px;
  width: 100%;
}

.oneday-head {
  font-size: 28px;
  font-family: var(--Noto-Serif-JP);
  color: var(--black);
  font-weight: 500;
  text-align: center;
  margin-bottom: 30px;
}

.oneday-contents {
  display: flex;
  gap: 20px;
  margin-bottom: 58px;
}

.day-box {
  display: flex;
  flex-direction: column;
  gap: 15px;
  max-width: 209px;
  width: 100%;
}

.day-head {
  background-color: var(--orange);
  font-size: 19px;
  font-family: var(--Noto-Serif-JP);
  color: var(--black);
  line-height: 59px;
  font-weight: 500;

  text-align: center;
}

.day-txt {
  font-size: 15px;
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  color: var(--black);
  line-height: 1.7;
  letter-spacing: 0.04em;
  text-align: justify;
}

@media (max-width: 940px) {
  
.contents-head {
  font-size: 33px;
  line-height: 75px;
}

.contents-txt {
    font-size: 16px;
        max-width: 360px;
    width: 100%;
}

.oneday-head {
    font-size: 26px;
}
.day-head {
    font-size: 17px;
    line-height: 56px;
}
}

@media (max-width: 777px) {
.contents-head {
          font-size: 31px;
        line-height: 55px;
}

.panel-contents {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-bottom: 35px;
}
.contents-pic {
  max-width: 350px;
  width: 100%;
}

.contents-txt {
font-size: 15px;
width: fit-content;
  }

  .day-box {
    max-width: 260px;
    width: 100%;
  }

  .oneday-contents {
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
  }
}

@media (max-width: 703px) {
   .day-box {
    width: 45%;
  }

      .day-head {
        line-height: 46px;
      }

  .day-txt {
    font-size: 14px;
  }
}

@media (max-width: 600px) {
.oneday-head {
        font-size: 22px;
    }
}
@media (max-width: 480px) {

  .panel-top {
  padding: 0 20px;
}

   .day-box {
    max-width: 340px;
    width: 100%;
  }

  .day-txt {
    font-size: 15px;
  }
}

@media (max-width: 417px) {

  .tab-panel {
        padding-top: 30px;
  }

  .contents-head {
        font-size: 25px;
      }
}

@media (max-width: 340px) {
  .contents-head {
        font-size: 20px;
                line-height: 46px;
      }
}
/* ===============================
  アコーディオン
=============================== */

/* アコーディオンヘッダー全体 */
.accordion-header {
  position: relative;
  font-size: 28px;
  font-family: var(--Noto-Serif-JP);
  color: var(--black);
  background-color: var(--white);
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  cursor: pointer;
  border-bottom: var(--black) solid 1px;
   padding-bottom: 14px;
  width: min(100%, 896px);
  margin-bottom: 50px;
 
}

/* プラスマイナスアイコン */
.plus-minus {
  position: relative;
  width: 30px;
  height: 30px;
  left: 20%;
  display: inline-block;
  flex-shrink: 0;
}

/* 横線（常に表示） */
.plus-minus::before,
.plus-minus::after {
  content: "";
  position: absolute;
  background-color: var(--green02);
  transition: transform 0.2s;
}

/* 横棒 */
.plus-minus::before {
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  transform: translateY(-50%);
}

/* 縦棒（開閉で動かす） */
.plus-minus::after {
  top: 0;
  left: 50%;
  width: 2px;
  height: 100%;
  transform: translateX(-50%);
}

/* 開いたとき（マイナスに） */
.accordion-item.active .plus-minus::after {
  transform: translateX(-50%) scaleY(0);
}

.tab-content {
  display: none; /* デフォルト非表示 */
}

.tab-content.active {
  display: block; /* 選択タブだけ表示 */
  height: auto;
}

 .accordion-content {
  /* max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease; */
  
  overflow: hidden;
  transition: max-height 0.4s ease;
  max-height: 0;
  padding-bottom: 0;

}

.accordion-item.active .accordion-content {
  /* overflow: visible; 
   height: auto; */
   max-height: 9999px;
  overflow: visible;
  padding-bottom: 80px; 
}

/* .person-box {
  width: 100%;
  z-index: 0;
  padding: 0 64px;
   padding-bottom: 80px!important;  
  } */

.person-box {
    width: 100%;
  padding: 0 64px;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
}


.person-inner {
  display: flex;

  gap: 38px;
  margin-bottom: 28px;
}

.person-pic {
      flex: 1;
}

.person-head-box {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 28px;
}

.person-head {
  font-size: 24px;
  font-weight: 500;
  line-height: 50px;
  color: var(--black);
  font-family: var(--Noto-Serif-JP);
  background-image: var(--gradation);
  width: fit-content;
  padding: 0 10px 0 14px;
}



.person-txt .person-list {
  font-size: 19px;
  color: var(--black);
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  line-height: 1.4;
}

.person-list {
  display: flex;
  flex-direction: column;
}

.person-txt {
  display: flex;
  gap: 17px;
   align-items: center;
}

.deco {
  width: 6px;
  height: 75.6px;
  background-color: #c8c8c8;
}

.person-item {
  display: flex;
}

.a-list li {
  position: relative;
  padding-left: 10px;
}

.a-list li::before {
  content: "";
  position: absolute;
  display: inline-block;
  width: 4px;
  height: 4px;
  background-color: var(--black);
  border-radius: 50%; /* 真円にする */
  transform: translateY(-50%);
  left: 0%;
  top: 50%;
}

.person-name {
  font-size: 34px;
  color: var(--black);
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  line-height: 1.6;
}

.person-name span {
  font-size: 15px;
  color: var(--black);
}

.faq-list {
  padding-bottom: 47px;
}

.q-box {
  display: flex;
  align-items: center;
  gap: 9px;
  padding-bottom: 20px;
}

.q-icon {
  font-size: 24px;
  color: var(--black);
  font-family: var(--Noto-Serif-JP);
  background-color: var(--orange);
  width: 40px;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.q-icon span {
  transform: translate(-1%, -11%);
}

.q-txt {
  font-size: 23px;
  color: var(--black);
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  flex: 1;
}

.a-box {
  background-color: var(--gray02);
  /* max-width: 850px;
  width: 100%; */
  margin: 0 auto;
  padding: 20px 17px;
}

.a-txt {
  font-size: 17px;
  color: var(--black);
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.01em;
  text-align: justify;
}

.br-480 {
  display: none;
}


@media (max-width: 940px) {
 .accordion-header {
    font-size: 26px;
    width: min(85%, 896px);
}

.plus-minus {
    left: 16%;
  }

  .person-head {
    font-size: 22px;
    line-height: 48px;
    padding: 0 10px;
}
}

@media (max-width: 777px) {
  .plus-minus {
    left: 10%;
  }

  .person-inner {
  flex-direction: column-reverse;
  gap: 30px;
  }

  .person-head {
  font-size: 24px;
  line-height: 50px;
}

.person-pic {
    width: 60%;
    margin: 0 auto;
}

/* .tab-panel {
  padding-bottom: 145px;
} */

.q-txt {
    font-size: 21px;
  }
.a-txt {
    font-size: 15px;
  }
}
@media (max-width: 768px) {
  .accordion-item.active .accordion-content {
    padding-bottom: 60px; /* モバイル調整 */
  }
}

@media (max-width: 600px) {

   .plus-minus {
        width: 26px;
    height: 26px;
    left: 6%;
  }
    .accordion-header {
        font-size: 22px;
    }

        .person-head {
        font-size: 19px;
}

.person-pic {
        width: 80%;}

person-txt .person-list {
    font-size: 16px;
}
/* 
    .tab-panel {
        padding-bottom: 0px;
    } */
}

/* @media (max-width: 517px) {
    .tab-panel {
        padding-bottom: 60px;
    }
} */

@media (max-width: 480px) {
.br-480 {
  display: block;
}

 /* .tab-panel {
        padding-bottom: 10px;
    } */

    .accordion-header {
        text-align: center;
    }

    .person-box {

    padding: 0 20px;
  }


        .person-pic {
        width: 85%;
      }

      .person-head-box {
    gap: 6px;
        margin-bottom: 20px;
  }

      .person-head {
        font-size: 20px;
        line-height: 40px;
}

.person-txt .person-list {
  font-size: 16px;
}

.faq-list:last-of-type {
  padding-bottom: 0;
}

.q-icon {
font-size: 20px;
    width: 30px;
    height: 30px;
}
.q-txt {
        font-size: 18px;
}
}

@media (max-width: 440px) {
.tab-panel {
        padding-bottom: 0;
    }

  .person-head {
        font-size: 18px;
      }
}

/* @media (max-width: 410px) {
  .tab-panel {
        padding-bottom: 60px;
    }
} */
/*******************************************************
3.セクション
*******************************************************/
.section3 {
  background-color: var(--white);
   padding-top: 145px;
  padding-bottom: 96px;
}

@media (max-width: 840px) {
.section3 {
    padding-top: 110px;
}
}

@media (max-width: 480px) {
.section3 {
    padding-top: 80px;
    padding-bottom: 55px;
}
}

.ttl-3 {
margin-bottom: 57px;
}

.data-outer {
  display: flex;
  flex-wrap: wrap;
  row-gap: 56px;
  column-gap: 27px;
  align-items: stretch;
  justify-content: center;
  margin-bottom: 173px;
}

.data-box {
  background-color: var(--gray02);
  max-width: 308px;
  width: 100%;
  overflow: hidden;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.data-head {
  background-color: var(--green02);
  font-size: 25px;
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  color: var(--white);
  line-height: 74px;
  letter-spacing: 0.1em;
  text-align: center;
}

.data-img {
  width: 96.76%;
  margin: 0 auto;
}

.data-contents {
  flex: 1; /* 高さを残りいっぱいに広げる */
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding-top: 27px;
  padding-bottom: 40px;
}

.data-txt {
  font-size: 15px;
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  color: var(--black);
  line-height: 1.6;
  letter-spacing: 0.03em;
  max-width: 263px;
  width: 100%;
  margin: 0 auto;
  text-align: justify;
  flex: 1;
  display: flex;
  align-items: flex-start;
}

.indiv-txt {
  text-align: center;
}

 .br-730 {
    display: none;
  }


@media (max-width: 1000px) {
  .data-outer {
    justify-content: center;
    margin-bottom: 73px;
  }
}

@media (max-width: 860px) {
  .data-outer {
  
    margin-bottom: 0;
  }
}

@media (max-width: 730px) {

  .br-730 {
    display: block;
  }

  .data-box {
  max-width: 250px;
  }

  .data-txt {
    max-width: 230px;
  }

  .data-outer {
    row-gap: 25px;
    column-gap: 14px;
  }

  .indiv-txt {
  margin: 0 auto;
}
}

@media (max-width: 586px) {
  .data-box {
  max-width: 210px;
  }

  .data-head {
font-size: 22px;
    line-height: 60px;
  }

  .data-txt {
    max-width: 190px;
  }
}

@media (max-width: 497px) {

  .br-730 {
    display: none;
  }

   .data-box:nth-child(3) .data-contents,
  .data-box:nth-child(4) .data-contents,
  .data-box:nth-child(5) .data-contents,
  .data-box:nth-child(6) .data-contents {
    gap: 0;
    padding-top: 0;
  }


.data-box {
  max-width: 300px;
  }

  .data-txt {
    max-width: 263px;
  }
}
/* ↓↓↓↓↓↓↓↓↓↓写真スライド02↓↓↓↓↓↓↓↓↓↓ */
.slide-box02 {
  background-color: var(--white);
  display: flex;
  overflow-x: hidden; 
/
}

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

.content02 {
  display: flex; 
  align-items: center; 
  justify-content: center;
  padding-right: 7px;
}

.content02 img {
  width: 487px;

  height: auto;
  display: block;
}


.slideshow {
  animation-name: loop-slide; /* アニメーション名 */
  animation-duration: 30s; /* 開始から終了までの所要時間 */
  animation-iteration-count: infinite; /* アニメーションのループ回数 */
  animation-timing-function: linear; /* 動きの加減速 */
  animation-delay: 1s; /* アニメーションが開始するまでの遅延時間 */
  animation-fill-mode: both; /* アニメーション開始前・終了後の挙動 */
}

/* 省略すると
.slideshow {
  display: flex;
  animation: loop-slide 25s infinite linear 1s both;
}
*/

@keyframes loop-slide {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}


@media (max-width: 860px) {
.slide-box02 {
    padding-top: 60px;
}

  .content02 img {
  width: 265px;
}

.slideshow {
  animation-duration: 20s; /* 開始から終了までの所要時間 */
}
}


/*******************************************************
4.セクション
*******************************************************/
.section4 {
  background-image: url(../img/06-merit/back.jpg);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
    padding-top: 157px;
  padding-bottom: 140px;
}

@media (max-width: 840px) {
.section4 {
    padding-top: 105px;
     padding-bottom: 115px;
}
}

@media (max-width: 480px) {
.section4 {
    padding-top: 60px;
    padding-bottom: 100px;
}
}

.ttl-4 {
margin-bottom: 71px;
}

.merit-outer {
  display: flex;
  flex-wrap: wrap;
  
  row-gap: 40px;
  column-gap: 27px;
  justify-content: center; /* 横中央寄せ */
}
.merit-box {
  background-color: var(--white);
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1 1 308px;
  padding: 35px 22px 40px;
  box-sizing: border-box;
}

.merit-head {
  font-size: 28px;
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  color: var(--black);
  letter-spacing: 0.05em;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  min-height: 74px; /* 高さを固定して中央揃えしやすくする場合 */
}

.merit-img {
  width: 90.07%;
  height: auto;
  margin-bottom: 18px;
}

.merit-textbox {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  justify-content: flex-start;
}

.merit-txt {
  font-size: 15px;
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  color: var(--black);
  line-height: 1.6;
  letter-spacing: 0.03em;
  text-align: justify;
  flex-grow: 1;
}

@media (max-width: 730px) {

  .merit-outer {
 row-gap: 25px;
        column-gap: 14px;
  }

.merit-box {
  max-width: 250px;
  width: 100%;       
}

.merit-head {
  font-size: 26px;
}
}

@media (max-width: 586px) {
 .merit-box {
  max-width: 210px;
  padding: 30px 15px;
  }

.merit-head {
font-size: 22px;
  
  }

}

@media (max-width: 497px) {


.merit-box  {
  max-width: 300px;
  }

}


/*******************************************************
5.セクション
*******************************************************/
.section5 {
  background-color: var(--white);
    padding-top: 153px;
}

@media (max-width: 840px) {
.section5 {
    padding-top: 100px;
}
}

@media (max-width: 480px) {
.section5 {
    padding-top: 70px;
}
}


.ttl-5 {
  margin-top: 0;
margin-bottom: 60px;
}

.search-txt {
  font-size: 19px;
  
  font-family: var(--Noto-Serif-JP);
  font-weight: 500;
  line-height: 1.9;
  letter-spacing: 0.01em;
  color: var(--black);
  margin-bottom: 68px;
}

.search-btn-box {
  display: flex;
  gap: 25px;
  margin-bottom: 122px;
}

.left-btn-outer {
  max-width: 335px;
  width: 100%;
  background-color: var(--gray02);
  padding: 53px 10px;
}

.left-head {
  font-size: 30px;
  font-family: var(--Noto-Serif-JP);
  color: var(--green02);
  text-align: center;
  margin-bottom: 48px;
}

.left-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 25px;
  
}

.right-btn-outer {
  max-width: 624px;
  width: 100%;
  background-color: var(--gray02);
  padding: 53px 10px;
}

.right-head {
  font-size: 30px;
  font-family: var(--Noto-Serif-JP);
  color: var(--green01);
  text-align: center;
  margin-bottom: 48px;
}

.right-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  column-gap: 16px;
  row-gap: 25px;
}

.bottom-pic img {

  display: block;
  width: 100%;
}

.br-900,.br-570 {
  display: none;
}

@media (max-width: 900px) {
.br-900 {
  display: block;
}
}
 
@media (max-width: 768px) {
  .search-btn-box {
    margin-bottom: 75px;
  }
}

@media (max-width: 640px) {
.search-txt {
  font-size: 17px;
}
}

@media (max-width: 620px) {
.search-btn-box {
  flex-direction: column;
}

.left-btn-outer {
    max-width: none; 
  }

  .left-box {
    flex-direction: row;
    gap: 16px;
  }

  .right-box {
  display: grid;
  grid-template-columns: repeat(2, 1fr); /* 2列固定 */
  gap: 16px;
  justify-items: center;
}
}

@media (max-width: 570px) {
  .br-900 {
  display: none;
}

.br-570 {
  display: block;
}
}

@media (max-width: 480px) {
 .left-box {
    flex-direction: column;
    gap: 16px;
  }

  .right-box {
  display: flex;
  
  gap: 16px;

}
}


@media (max-width: 435px) {
.search-txt {
  font-size: 15px;
}
}



@media (max-width: 334px) {
.br-570 {
  display: none;
}


}



/*******************************************************
追従ボタン
*******************************************************/

.slidebtn-wrap {
  position: fixed;
  top: 60%;
  right: 0; /* 右端に固定 */
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 17px;
  z-index: 1;
}

.slide-btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 15px;
  color: var(--white);
  font-family: var(--Noto-Sans-JP);
  width: 175px;
  height: 65px;
  text-decoration: none;
  white-space: nowrap;
  transition: transform 0.3s, opacity 0.3s;
}

.slide-color01 {
  background-color: var(--green02);
}

.slide-color02 {
  background-color: var(--green01);
}

.slide-btn:hover {
  transform: translateY(-2px);
  color: var(--white);
    opacity: 0.7;
}



@media (max-width: 768px) {
  .slidebtn-wrap {
    
    flex-direction: row;
    bottom: 0; /* 下に固定 */
    left: 0;
    top: auto;
    width: 100%;
    transform: none;
    gap: 0;
  }

  .slide-btn {
    flex: 1 1 50%;
    min-width: 0;
    height: 70px;
  }
  
}

@media (max-width: 480px) {
  .slide-btn {
    font-size: 15px;
  }
}

@media (max-width: 375px) {
  .slide-btn {
    font-size: 14px;
  }
}

/*******************************************************
トップボタン
*******************************************************/
/* .pagetop {
  display: none; 
  position: fixed;
  z-index: 10;
  bottom: 50px;
  right: 20px;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: transform 1s;
  background-color: #00a6c4;
  cursor: pointer;
} */

/* 上向き矢印を線で表現 */
/* .pagetop::before {
  position: absolute;
  content: "";
  width: 12px;
  height: 12px;
  border-top: 2px solid var(--white);
  border-left: 2px solid var(--white);
  transform: translate(50%, -50%) rotate(45deg);
  top: 53%;
  left: 30%;
} */
/* ホバー時 */
/* .pagetop:hover {
  opacity: 0.7;
  transform: rotateY(360deg);
} */

/* @media (max-width: 768px) {
  .pagetop {
    right: 5px;
  }
} */

/*******************************************************
フッター
*******************************************************/
footer {
 
  background-color: var(--black02);
  color: var(--white);
  font-size: 12px;
  font-weight: 300;
  text-align: center;
      margin-top: -1px;
  
}

.footer-inner {
  padding: 37px 10px;
 
}

.footer-nav {
  padding-bottom: 14px;
  display: flex;
  justify-content: center;
  gap: 10px;
}

.footer-nav > a:not(:first-child)::before {
  content: "｜";
  position: relative;
  right: 3%;
}

@media (max-width: 768px) {
  footer {

    padding-bottom: 70px;
  }
}

@media (max-width: 480px) {
  .footer-nav {
    flex-wrap: wrap;
  }

  .footer-nav > a:last-child::before {
    opacity: 0;
  }
}
