@charset "UTF-8";
/* company */


/*-------------------------------------
  サイドメニュー　会社案内のみ
*/
/*1200未満で2列*/
@media screen and (max-width: 1199px) {
  .flow_contents_wrap ._side_menu ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .flow_contents_wrap ._side_menu li {
    font-size: 1.3rem;
    width: 45%;
  }
}

/*該当ページのみ赤に*/
.flow_contents_wrap ._side_menu._menu_01_on li a._menu_01,
.flow_contents_wrap ._side_menu._menu_02_on li a._menu_02,
.flow_contents_wrap ._side_menu._menu_03_on li a._menu_03,
.flow_contents_wrap ._side_menu._menu_04_on li a._menu_04,
.flow_contents_wrap ._side_menu._menu_05_on li a._menu_05,
.flow_contents_wrap ._side_menu._menu_06_on li a._menu_06,
.flow_contents_wrap ._side_menu._menu_07_on li a._menu_07,
.flow_contents_wrap ._side_menu._menu_08_on li a._menu_08,
.flow_contents_wrap ._side_menu._menu_09_on li a._menu_09,
.flow_contents_wrap ._side_menu._menu_10_on li a._menu_10 {
  color: var(--col-01);
}
.flow_contents_wrap ._side_menu._menu_01_on li a._menu_01::before,
.flow_contents_wrap ._side_menu._menu_02_on li a._menu_02::before,
.flow_contents_wrap ._side_menu._menu_03_on li a._menu_03::before,
.flow_contents_wrap ._side_menu._menu_04_on li a._menu_04::before,
.flow_contents_wrap ._side_menu._menu_05_on li a._menu_05::before,
.flow_contents_wrap ._side_menu._menu_06_on li a._menu_06::before,
.flow_contents_wrap ._side_menu._menu_07_on li a._menu_07::before,
.flow_contents_wrap ._side_menu._menu_08_on li a._menu_08::before,
.flow_contents_wrap ._side_menu._menu_09_on li a._menu_09::before,
.flow_contents_wrap ._side_menu._menu_10_on li a._menu_10::before {
  background: var(--col-01);
}

/*-------------------------------------
  会社案内トップ
*/
body.cp_top {}

/*画面幅100%*/
.company-content {
  /*margin: 20px auto 0; */
}

/*会社案内トップの共通タイトル*/
.cp_top .cp_top__ttl ._en {
  font-size: 1.4rem;
  color: var(--col-01);
  display: block;
}
.cp_top .cp_top__ttl ._jp {
  font-size: clamp( 20px, calc( 14.260204081632654px + 1.530612244897959vw ), 26px );
  display: block;
  line-height: 1.6;
  margin-top: 16px;
}
/*センター寄せ*/
.cp_top .cp_top__ttl._center {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .company-content {
    /*margin: 60px auto 0; */
  }
  .cp_top .cp_top__ttl ._jp {
    font-size: clamp( 20px, calc( 5.777777777777779px + 1.8518518518518516vw ), 28px );
    margin-top: 18px;
  }
}
@media screen and (min-width: 1200px) {
  .cp_top .cp_top__ttl ._en {
    font-size: 1.6rem;
  }
  .cp_top .cp_top__ttl ._jp {
    font-size: clamp( 28px, calc( 4px + 2vw ), 36px );
  }
}

/*メインイメージ（背景）*/
.cp_top .local_heading {
  display: flex;
  position: relative;
  width: 100%;
  overflow: hidden;
}
.cp_top .local_heading::before {
  background: url(/images/company/cp_top_main.jpg) no-repeat center center;
  background-size: cover;
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 35vw;
  z-index: -1;
  animation: zoomout 10s ease;
}

@keyframes zoomout {
  0%   {
    opacity: 0.9;
    transform: scale(1.2);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/*赤のスライドアニメ*/
.cp_top .local_heading.slider1 {}
.cp_top .local_heading.slider1::after {
  content: '';
  background-color: var(--col-01);
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: right center;/*右中心を起点に塗りが縮む*/
}
.cp_top .local_heading.slider1::after {
  transition: 0.5s 0.1s cubic-bezier(0.97, -0.01, 0.58, 0.99);/* 所要時間 | 待ち時間 */
}
.cp_top .local_heading.slider1.is-animation::after {
  transform: scale(0, 1);
}

/*パーパス部*/
.cp_top .local_heading ._purpose {
  background-color: #fff;
  border-top-left-radius: 50px;
  margin: 30vw 0 0 auto;
  width: 96%;
  height: 100%;
  padding: 40px 30px;
}
.cp_top .local_heading ._purpose ._purpose-txt {
  font-size: clamp( 15px, calc( 14.545454545454545px + 0.12121212121212122vw ), 16px );
  line-height: 2;
  margin-top: 16px;
  max-width: 580px;
}

/*テキスト表示のアニメーション少し遅らす*/
/*.loader-effectの時*/
.cp_top .cp_top__ttl .loader-effect.is-animation.fadeUp {
  animation-delay: 0.7s;
}
.cp_top .cp_top__ttl .loader-effect.is-animation.fadeUp.delay-1 {
  animation-delay: 1s;
}
/*.effectの時*/
.cp_top .cp_top__ttl .effect.is-animation.fadeUp.delay-1 {
  animation-delay: 0.3s;
}

@media screen and (min-width: 768px) {
  .cp_top .local_heading::before {
    height: 100%;
  }
  .cp_top .local_heading ._purpose {
    margin: calc(100vw * (65 / 1600)) 0 0 auto;
    width: calc(100vw * (840 / 1600));
    padding: calc(100vw * (60 / 1600)) calc(100vw * (80 / 1600));
  }
}
@media screen and (min-width: 1200px) {
  .cp_top .local_heading ._purpose ._purpose-txt {
    font-size: 1.7rem;
  }
}

/*トップメッセージ部*/
.cp_top ._top-message-wrap {
  position: relative;
  padding: 4vw 0 10vw;
}
/*背景飾り*/
.cp_top ._top-message-wrap::before {
  background-color: var(--col-01);
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  width: 50vw;
  aspect-ratio: 5 / 2;
  z-index: -1;
}
.cp_top ._top-message {
  display: flex;
  flex-direction: column-reverse;
  gap: 40px calc(100% * (70 / 1380));
  margin: 0 auto;
  position: relative;
}
.cp_top ._main {
  width: 90%;
  margin-inline: auto;
}
.cp_top .sign ._name {
  font-weight: bold;
  font-size: clamp( 20px, calc( 10.433673469387754px + 2.5510204081632653vw ), 30px );
}
.cp_top ._top-message　._bt_01 {}

@media screen and (min-width: 768px) {
  .cp_top ._top-message-wrap {
    padding: 4vw 0;
  }
  .cp_top ._top-message-wrap::before {
    width: 20vw;
  }
  .cp_top ._top-message {
    flex-direction: row;
    align-items: center;
    width: 90%;
    /*max-width: 1380px;*/
  }
  .cp_top ._main {
    flex: 1;
    width: auto;
    margin-inline: 0;
  }
  .cp_top ._main ._inner {
    max-width: 600px;
    margin-inline: auto;
  }
  .cp_top .sign ._name {
    font-size: clamp( 20px, calc( 2.2222222222222214px + 2.314814814814815vw ), 30px )
  }
  .cp_top ._pic {
    width: calc(100% * (690 / 1380));
  }
}
@media screen and (min-width: 1200px) {
  .cp_top .sign ._name {
    /*font-size: 3rem;*/
  }
}

/* about us　グリッド部 */
.cp_top ._cp_navi {
  background-color: #f7f7f7/*var(--col-bg1)*/;
  padding: 70px 0;
}
.cp_top ._cp_navi ._navi_grid-container {
  background-color: #ddd;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  justify-content: center;
  gap: 1px;
  width: 90%;
  max-width: 1400px;
  margin: 50px auto;
}
.cp_top ._cp_navi ._navi_grid-container ._item {
  background-color: #f7f7f7;
  text-align: center;
  /*max-width: 420px;*/
}
.cp_top ._cp_navi ._navi_grid-container ._item a {
  background-color: rgba(255,255,255,0);/*背景白を透明*/
  padding: 10px 10px 24px;
  display: block;
  transition: 0.3s;
}
.cp_top ._cp_navi ._navi_grid-container ._item ._icon {
  width: 60px;
  height: 60px;
  margin: 0 auto 6px;
}
.cp_top ._cp_navi ._navi_grid-container ._item ._name ._sub-name {
  color: #5F5F5F;
  font-size: 1.3rem;
  line-height: 1.2;
  margin-bottom: 4px;
  transition: 0.3s;
}
.cp_top ._cp_navi ._navi_grid-container ._item ._name ._main-name {
  display: flex;
  gap: 8px;
  justify-content: center;
  align-items: center;
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.2;
  position: relative;
  transition: 0.3s;
}
.cp_top ._cp_navi ._navi_grid-container ._item ._name ._main-name::after {
  content:'';
  width: 8px;
  height: 8px;
  border-top: var(--col-01) 2px solid;
  border-right: var(--col-01) 2px solid;
  transform: rotate(45deg);
  transition: 0.3s;
}

/*2列表示の場合の最後の端数セル　スマホのみ表示*/
.cp_top ._cp_navi ._navi_grid-container ._item.sp-only {}

@media screen and (min-width: 768px) {
  .cp_top ._cp_navi {
    padding: 100px 0;
  }
  .cp_top ._cp_navi ._navi_grid-container {
    grid-template-columns: repeat(3, 1fr);
  }
  .cp_top ._cp_navi ._navi_grid-container ._item a {
    padding: 16px 20px 30px;
  }
  .cp_top ._cp_navi ._navi_grid-container ._item ._icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 10px;
  }
  .cp_top ._cp_navi ._navi_grid-container ._item ._name ._sub-name {
    font-size: 1.4rem;
    margin-bottom: 10px;
  }
  .cp_top ._cp_navi ._navi_grid-container ._item ._name ._main-name {
    gap: 10px;
    font-size: 1.8rem;
  }
  /*非表示*/
  .cp_top ._cp_navi ._navi_grid-container ._item.sp-only {
    display: none;
  }
}

@media (hover: hover) {
  .cp_top ._cp_navi ._navi_grid-container ._item a:hover {
    background-color: rgba(255,255,255,0.8);/*背景白*/
  }
  .cp_top ._cp_navi ._navi_grid-container ._item a:hover ._name ._sub-name {
    color: var(--col-01);
  }
  .cp_top ._cp_navi ._navi_grid-container ._item a:hover ._name ._main-name {
    color: var(--col-01);
  }
  .cp_top ._cp_navi ._navi_grid-container ._item a:hover ._name ._main-name::after {
    margin-left: 10px;
  }
}

/*-------------------------------------
  ビジネス
*/

body.cp_business {}

/* section-01 2カラム */
.cp_business #sec-01 .cp_inner_2col {
  display: flex;
  flex-direction: column-reverse;
  gap: 30px calc(100% * (60 / 1040));
}


@media screen and (min-width: 768px) {
  .cp_business #sec-01 .cp_inner_2col {
    flex-direction: row;
    align-items: center;
  }
  .cp_business #sec-01 .cp_inner_2col ._pic {
    width: calc(100% * (420 / 1040));
  }
  .cp_business #sec-01 .cp_inner_2col ._main {
    flex: 1;
  }
}

/* section-02 */
.cp_business #sec-02 ._lead_01 {
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.6;
  margin-bottom: 10px;
}
.cp_business #sec-02 ._main_pic {
  background-color: #EEF1F8;
  border-radius: 10px;
  margin-bottom: 24px;
}

.cp_business .department {
  color: #E3E3E3;
  font-size: 3rem;
}
.cp_business .department ._num {
  color: var(--col-01);
  display: inline-block;
  margin-right: 6px;
}

/*体制の2カラムのアウター*/
.cp_business .structure_wrap {
  margin: 90px 0;
}
/*体制の2カラム*/
.cp_business .structure_2col {
  display: flex;
  flex-direction: column;
  gap: 30px calc(100% * (50 / 1040));
}

/*部署名*/
.cp_business .structure_2col .department-name {
  /*color: var(--col-01);*/
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 1.5rem;
  line-height: 1.6;
  font-weight: bold;
  margin-bottom: 10px;
}
.cp_business .structure_2col .department-name::before {
  content: '';
  width: 20px;
  height: 20px;
  /*border: 5px solid rgba(234, 0, 11, 0.2);*/
  border-radius: 10px;
}
/*部署カラー*/
.cp_business .dpt-col-01 {
  color: #d3592e;
}
.cp_business .structure_2col .department-name.dpt-col-01::before {
  border: 5px solid rgba(211,89,46,0.50);
}
.cp_business .dpt-col-02 {
  color: #669127;
}
.cp_business .structure_2col .department-name.dpt-col-02::before {
  border: 5px solid rgba(102,145,39,0.5);
}
.cp_business .dpt-col-03 {
  color: #3b7ebf;
}
.cp_business .structure_2col .department-name.dpt-col-03::before {
  border: 5px solid rgba(59,126,191,0.5);
}

/*部署タイトル*/
.cp_business .structure_2col .department-ttl {
  margin-bottom: 24px;
}
.cp_business .structure_2col .department-ttl ._l-txt {
  display: block;
  font-size: clamp( 24px, calc( 18.260204081632654px + 1.530612244897959vw ), 30px );
  position: relative;
  padding-bottom: 24px;
}
.cp_business .structure_2col .department-ttl ._l-txt::after {
  background-color: var(--col-01);;
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  width: 60px;
  height: 1px;
}
/*部署　サイン*/
.cp_business .structure_2col .department-sign {
  font-size: clamp( 16px, calc( 10px + 0.5vw ), 18px );
  font-weight: bold;
  line-height: 1.6;
  margin-top: 24px;
}
.cp_business .structure_2col .department-sign ._name {
  display: block;
  font-size: 1.4em;
}
@media screen and (min-width: 768px) {
  .cp_business #sec-02 ._lead_01 {
    font-size: 1.8rem;
  }
  .cp_business #sec-02 .structure_2col {
    flex-direction: row;
    align-items: center;
  }
  .cp_business #sec-02 .structure_2col ._pic {
    width: calc(100% * (400 / 1040));
  }
  .cp_business #sec-02 .structure_2col ._main {
    flex: 1;
  }
  .cp_business .department {
    font-size: clamp( 28px, calc( 9.538461538461537px + 2.403846153846154vw ), 48px );
  }
  .cp_business .structure_2col .department-name {
    font-size: 1.8rem;
  }
  .cp_business .structure_2col .department-ttl ._l-txt {
    font-size: clamp( 24px, calc( 18.46153846153846px + 0.7211538461538461vw ), 30px )
  }
  .cp_business .structure_2col .department-sign {
    font-size: 1.8rem;
  }
}

/*-------------------------------------
  喜一のサービス
*/

body.cp_service {}

/*太字文*/
.cp_service ._lead_01 {
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.6;
  margin-bottom: 16px;
}

/* section-01 */
.cp_service #sec-01 {}

/* TMSボタン */
.cp_service #sec-01 ._bt_01 {
  margin-top: 30px;
}
/* section-01 2カラム */
.cp_service #sec-01 .cp_inner_2col {
  display: flex;
  flex-direction: column;
  gap: 30px calc(100% * (40 / 1040));
}

@media screen and (min-width: 768px) {
  .cp_service #sec-01 .cp_inner_2col {
    flex-direction: row;
  }
  .cp_service #sec-01 .cp_inner_2col ._pic {
    width: calc(100% * (560 / 1040));
  }
  .cp_service #sec-01 .cp_inner_2col ._main {
    flex: 1;
  }
}

/*  3カラム　*/
.cp_service .cp_inner_3col {
  display: flex;
  flex-direction: column;
  gap: 30px calc(100% * (40 / 1040));
  margin-top: 30px;
}

.cp_service .cp_inner_3col ._heading {
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.6;
  margin-bottom: 0.5em;
}
.cp_service .cp_inner_3col ._heading ._red {
  color: var(--col-01);
  display: inline-block;
  margin-right: 0.3em
}

.cp_service .cp_inner_3col ._pic {
  line-height: 0;
  margin-bottom: 16px;
}
.cp_service .cp_inner_3col ._main {
}
@media screen and (min-width: 768px) {
  .cp_service .cp_inner_3col {
    flex-direction: row;
    margin-top: 40px;
  }
  .cp_service .cp_inner_3col ._item {
    width: calc(100% * (320 / 1040));
  }
  .cp_service .cp_inner_3col ._heading {
    font-size: 2.0rem;
  }
}

/* section-02 */
.cp_service #sec-02 {}
.cp_service #sec-02 ._main_pic {
  margin-bottom: 20px;
}

/* section-03 */
.cp_service #sec-03 {}

/* section-03 2カラム */
.cp_service #sec-03 .cp_inner_2col {
  display: flex;
  flex-direction: column;
  gap: 30px calc(100% * (40 / 1040));
}

@media screen and (min-width: 768px) {
  .cp_service #sec-03 .cp_inner_2col {
    flex-direction: row;
  }
  .cp_service #sec-03 .cp_inner_2col ._pic {
    width: 38%;
  }
  .cp_service #sec-03 .cp_inner_2col ._main {
    flex: 1;
  }
}

/*-------------------------------------
  健康経営
*/

body.cp_health {}

/*健康宣言*/
.cp_health ._lead_box {
  background-color: #f7f7f7;
  padding: 30px;
  border-radius: 10px;
}
.cp_health ._lead_box ._lead_ttl {
  color: var(--col-01);
  border-left: 1px solid var(--col-01);
  font-size: clamp( 20px, calc( 16.444444444444443px + 0.4629629629629629vw ), 22px );
  padding: 0px 0px 0px 12px;
  margin-bottom: 10px;
}
.cp_health ._lead_box .all_txt {
  font-size: clamp( 16px, calc( 14.222222222222221px + 0.23148148148148145vw ), 17px );
}

/* section-01 3カラム */
.cp_health .health_3col {
  display: flex;
  flex-direction: column;
  gap: 30px calc(100% * (40 / 1040));
  margin: 40px auto;
}

/*リンク範囲*/
.cp_health .health_3col ._item a {
  /*background-color: #fff;
  border-radius: 10px;
  box-shadow: 2px 2px 10px -3px rgba(0, 0, 0, 0.5);*/
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px 16px 40px;
  position: relative;
  transition: 0.3s;
  height: 100%;
}
.cp_health .health_3col ._item a::after {
  content: '';
  width: 10px;
  height: 10px;
  border-right: 1px solid var(--col-01);
  border-bottom: 1px solid var(--col-01);
  transform: rotate(45deg);
  position: absolute;
  left: 0;
  right: 0;
  bottom: 16px;
  margin: auto;
}

@media (hover: hover) {
  .cp_health .health_3col ._item a:hover {
    transform: scale(1.05);
  }
}
/*アニメーション*/
/*.effect 遅らす*/
.cp_health .health_3col ._item.effect.is-animation.fadeUp.delay-1 {
  animation-delay: 0.3s;
}
.cp_health .health_3col ._item.effect.is-animation.fadeUp.delay-2 {
  animation-delay: 0.6s;
}

@media screen and (min-width: 768px) {
  .cp_health .health_3col {
    flex-direction: row;
  }
  .cp_health .health_3col ._item {
    width: calc(100% * (320 / 1040));
  }
}

/*心知体アイコン*/
.cp_health .health_3col ._item ._pic {
  background-color: #f7f7f7;
  border-radius: 54% 39% 69% 39% / 55% 50% 50% 56%;/*いびつな円*/
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3% 20%;
}
.cp_health .health_3col ._item:nth-of-type(1) ._pic {
  background-color: rgba(255,245,252,0.9);
}
.cp_health .health_3col ._item:nth-of-type(2) ._pic {
  background-color: rgba(241,255,233,0.9);
  border-radius: 41% 59% 49% 51% / 42% 56% 44% 58%;/*いびつな円*/
}
.cp_health .health_3col ._item:nth-of-type(3) ._pic {
  background-color: rgba(255,249,236,0.9);
}
.cp_health .health_3col ._item ._pic img {
  max-width: 160px;
}

/*心知体テキスト枠*/
.cp_health .health_3col ._item ._main {
  display: flex;
  gap: 16px;
  height: 100%;
}
.cp_health .health_3col ._item ._main ._txt {
  color: var(--col-01);
  line-height: 1.6;
  font-size: clamp( 15px, calc( 12px + 0.25vw ), 16px );
  font-weight: bold;
  flex: 1;
  margin: auto 0;
}
.cp_health .health_3col ._item ._main ._type {
  display: flex;
  align-items: center;
  justify-content: center;
  /*background-color: var(--col-01);*/
  /*border-radius: 8px;
  border-right: 1px solid var(--col-01);
  border-left: 1px solid var(--col-01);*/
  color: var(--col-01);
  font-size: clamp( 24px, calc( 4.137931034482758px + 2.586206896551724vw ), 30px );
  font-weight: bold;
  width: 20%;
}

.cp_health .health_3col ._item {
  container-type: inline-size;/*コンテナクエリ　親*/
}
@container (width <= 280px) {
  .cp_health .health_3col ._item ._main {
    flex-direction: column;
  }
  .cp_health .health_3col ._item ._main ._type {
    width: 100%;
  }
}

/* section-02 健康経営に関する取り組み*/
.cp_health #sec-02 {}

/* 2カラム*/
.cp_health .health_2col {
  display: flex;
  flex-direction: column;
  gap: 30px 2%;
  margin: 70px auto;
}
.cp_health .health_2col ._main {
  display: flex;
  flex-direction: column;
  gap: 30px 3%;
}
/*右側の写真*/
.cp_health .health_2col ._pic {
  text-align: right;
  width: 90%;
  margin-inline: auto;
}
.cp_health .health_2col ._pic img {
  /*border-radius: 10px;*/
}
/*2枚目の写真*/
.cp_health .health_2col ._pic img:nth-of-type(2n) {
  width: 70%;
  margin: 30px -5% 0 auto;
}
.cp_health .health_2col ._main ._inner_pic {
  text-align: center;
  width: 80%;
  max-width: 220px;
  margin: 0 auto;
}
/*心知体の文字*/
.cp_health .health_2col ._main ._inner_pic ._type {
  display: inline-block;
  justify-content: center;
  /*border-radius: 8px;
  border-right: 1px solid var(--col-01);
  border-left: 1px solid var(--col-01);*/
  color: var(--col-01);
  font-size: 2.4rem;
  font-weight: bold;
  padding: 0.3em 1em;
}
/*左のイラスト 1つ目*/
.cp_health .health_2col:nth-of-type(1) ._main ._inner_pic {
  background-color: rgba(255, 245, 252, 0.9);
  border-radius: 54% 39% 69% 39% / 55% 50% 50% 56%;/*いびつな円*/
}
.cp_health .health_2col:nth-of-type(2) ._main ._inner_pic {
  background-color: rgba(241,255,233,0.9);
  border-radius: 41% 59% 49% 51% / 42% 56% 44% 58%;/*いびつな円*/
}
.cp_health .health_2col:nth-of-type(3) ._main ._inner_pic {
  background-color: rgba(255,249,236,0.9);
  border-radius: 54% 39% 69% 39% / 55% 50% 50% 56%;
}

/*取り組みのリスト*/
.cp_health .health_2col ._main .torikumi_list li {
  margin-bottom: 20px;
}
.cp_health .health_2col ._main .torikumi_list ._ttl01 {
  font-size: clamp( 18px, calc( 11.379310344827587px + 0.8620689655172413vw ), 20px );
  margin-bottom: 0.5em;
}
@media screen and (min-width: 768px) {
  .cp_health .health_2col {
    flex-direction: row;
  }
  /*右側の写真*/
  .cp_health .health_2col ._pic {
    width: 28%;
    margin-inline: 0;
  }
  
  .cp_health .health_2col ._main {
    flex-direction: row;
    flex: 1;
  }
  .cp_health .health_2col ._main ._inner_pic {
    padding: 2%;
    margin: 0 auto auto;
    width: 28%;
  }
  /*2枚目の写真*/
  .cp_health .health_2col ._pic img:nth-of-type(2n) {
    margin: 30px -8% 0 auto;
  }
  .cp_health .health_2col ._main ._inner_main {
    flex: 1;
  }
  /*取り組みのリスト*/
  .cp_health .health_2col ._main .torikumi_list {
    margin-top: 30px;
  }
  /*リストのタイトル*/
  .cp_health .health_2col ._main .torikumi_list ._ttl01 {
    
  }
}

/*-------------------------------------
  人材育成
*/

body.cp_hrd {}

/* section-01 */
.cp_hrd #sec-01 {}

/* section-01 2カラム */
.cp_hrd #sec-01 .cp_inner_2col {
  display: flex;
  flex-direction: column;
  gap: 30px calc(100% * (50 / 1040));
  margin-bottom: 50px;
}

@media screen and (min-width: 768px) {
  .cp_hrd #sec-01 .cp_inner_2col {
    flex-direction: row;
    margin-bottom: 70px;
  }
  .cp_hrd #sec-01 .cp_inner_2col:nth-of-type(2n) {
    flex-direction: row-reverse;
  }
  .cp_hrd #sec-01 .cp_inner_2col ._pic {
    width: calc(100% * (500 / 1040));
  }
  .cp_hrd #sec-01 .cp_inner_2col ._main {
    flex: 1;
  }
}
/* 共通　2カラム */
.cp_hrd .hrd_2col {
  display: flex;
  flex-direction: column;
  gap: 30px calc(100% * (50 / 1040));
}
.cp_hrd .hrd_2col ._pic {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
/*1枚目の写真*/
.cp_hrd .hrd_2col ._pic img:nth-of-type(1){
  width: 70%;
}
/*2枚目の写真*/
.cp_hrd .hrd_2col ._pic img:nth-of-type(2){
  width: 50%;
  margin: -5vw 0 auto auto;
}
@media screen and (min-width: 768px) {
  .cp_hrd .hrd_2col {
    flex-direction: row;
  }
  .cp_hrd .hrd_2col ._pic {
    width: calc(100% * (320 / 1040));
  }
  /*1枚目の写真*/
  .cp_hrd .hrd_2col ._pic img:nth-of-type(1){
    width: 80%;
  }
  /*2枚目の写真*/
  .cp_hrd .hrd_2col ._pic img:nth-of-type(2){
    width: 60%;
    margin: -15px 0 auto auto;
  }
  .cp_hrd .hrd_2col ._main {
    flex: 1;
  }
}

/*共通リスト*/
  .cp_hrd ._hrd_list li {
    margin-bottom: 25px;
  }
.cp_hrd ._hrd_list li ._list_ttl {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  position: relative;
}
.cp_hrd ._hrd_list li ._list_ttl::before {
  content: '';
  background-color: #ddd;
  width: 6px;
  height: 6px;
  border-radius: 3px;
}
.cp_hrd ._hrd_list li ._list_ttl ._txt01 {
  font-size: 1.8rem;
  line-height: 1.6;
  color: var(--col-01);
  }

/* section-02 */
.cp_hrd #sec-02 {}

/* section-03 */
.cp_hrd #sec-03 {}


/*-------------------------------------
  サステナビリティ
*/

body.cp_sustainability {}
/*グレー背景*/
.cp_sustainability ._bg_box {
  background-color: #f7f7f7;
  padding: 40px 30px;
  border-radius: 10px;
}
/*1段*/
.cp_sustainability ._section {
  margin-bottom: 40px;
}
.cp_sustainability ._section:last-of-type {
  margin-bottom: 0;
}

/*先頭数字、赤文字タイトル*/
.cp_sustainability ._ttl01 {
  color: var(--col-01);
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 2rem;
  line-height: 1.2;
  margin-bottom: 20px;
}
.cp_sustainability ._ttl01 ._num {
  font-size: 3.2rem;
}

/*ピクトとテキストの2カラム*/
.cp_sustainability .cp_inner_2col {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.cp_sustainability .cp_inner_2col ._pic {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2%;
  max-width: 400px;
}

/*記事内の画像配置*/
.cp_sustainability ._inner_pic {
  display: flex;
  justify-content: space-between;
  margin: 40px 0;
}
.cp_sustainability ._inner_pic figure {
  width: 48%;
}
@media screen and (min-width: 768px) {
  .cp_sustainability .cp_inner_2col {
    flex-direction: row;
  }
  .cp_sustainability .cp_inner_2col ._main {
    width: 70%;
  }
  .cp_sustainability .cp_inner_2col ._pic {
    width: 30%;
    max-width: auto;
  }
}

/*-------------------------------------
  働く環境
*/

body.cp_environment {}
/*グレー背景*/
.cp_environment ._lead_box {
  background-color: #f7f7f7;
  padding: 30px;
  border-radius: 10px;
}
.cp_environment ._lead_box ._lead_ttl {
  color: var(--col-01);
  border-left: 1px solid var(--col-01);
  font-size: clamp( 20px, calc( 16.444444444444443px + 0.4629629629629629vw ), 22px );
  padding: 0px 0px 0px 12px;
  margin-bottom: 10px;
}
.cp_environment ._lead_box .all_txt {
  /*font-size: clamp( 16px, calc( 14.222222222222221px + 0.23148148148148145vw ), 17px )*/;
}

/* sec-01 本社オフィス */
.cp_environment #sec-01 {}
.cp_environment #sec-01 ._section {
  margin-top: 50px;
}
.cp_environment #sec-01 ._section:first-of-type {
  margin-top: 60px;
}
.cp_environment #sec-01 ._section .cp_inner_2col {
  display: flex;
  flex-direction: column-reverse;
}
.cp_environment #sec-01 ._section .cp_inner_2col ._main {
  background-color: #fff;
  box-shadow: 5px 5px 10px -5px rgba(0, 0, 0, 0.3);
  padding: 20px;
  z-index: 2;
  margin: 3vw 1vw;
}
.cp_environment #sec-01 ._section .cp_inner_2col ._pic {
  position: relative;
  z-index: 1;
  }
/*画像の背景グレー*/
.cp_environment #sec-01 ._section .cp_inner_2col ._pic::before {
  background-color: #f5f5f5;
  content: '';
  container-type: size;/*container-type プロパティ　縦横幅*/
  position: absolute;
  left: 2cqw;
  bottom: -2cqw;
  z-index: -1;
  width: 100%;
  height: 50%;
}
/*奇数*/
.cp_environment #sec-01 ._section:nth-of-type(even) .cp_inner_2col ._pic::before {
  left: -2cqw;
}
@media screen and (min-width: 600px) {
  .cp_environment #sec-01 ._section .cp_inner_2col ._main {
    margin: 3vw;
    padding: 30px;
  }
}
@media screen and (min-width: 960px) {
  .cp_environment #sec-01 ._section {
    margin-top: 80px;
    padding-bottom: 30px;/*画像背景グレーのはみ出し分*/
  }
  /*sec_ttl_05の調整*/
  .cp_environment #sec-01 .sec_ttl_05 ._txt01 {
    font-size: clamp( 30px, calc( 22px + 0.8333333333333334vw ), 32px );
  }
  .cp_environment #sec-01 ._section .cp_inner_2col {
    flex-direction: row;
  }
  /*奇数*/
  .cp_environment #sec-01 ._section:nth-of-type(odd) .cp_inner_2col {
    align-items: center;
    flex-direction: row-reverse;
  }
  .cp_environment #sec-01 ._section:nth-of-type(odd) .cp_inner_2col ._main {
    width: 46%;
    margin-left: -6%;
  }
  /*偶数*/
  .cp_environment #sec-01 ._section:nth-of-type(even) .cp_inner_2col ._main {
    width: 46%;
  }
  .cp_environment #sec-01 ._section .cp_inner_2col ._main {
    margin: auto 0;
  }
  .cp_environment #sec-01 ._section .cp_inner_2col ._pic {
    width: 60%;
    margin-left: -6%;
  }
}


/* sec-02 シェアオフィス*/
.cp_environment #sec-02 {}
.cp_environment #sec-02 ._section {
  border-top: 1px solid var(--col-06);
  padding-top: 30px;
}
.cp_environment #sec-02 ._section .cp_inner_2col {
  display: flex;
  flex-direction: column-reverse;
  gap: 40px;
}
/*タイトルの下線取る*/
.cp_environment #sec-02 ._section .cp_inner_2col .sec_ttl_06::after,
.cp_environment #sec-03 ._section .cp_inner_2col .sec_ttl_06::after{
  height: 0;
}
@media screen and (min-width: 768px) {
  .cp_environment #sec-02 ._section .cp_inner_2col {
    flex-direction: row;
    gap: 60px;
  }
  .cp_environment #sec-02 ._section .cp_inner_2col ._main {
    width: 50%;
  }
  .cp_environment #sec-02 ._section .cp_inner_2col ._pic {
    flex: 1
  }
}

/* sec-03 海外での業務 */
.cp_environment #sec-03 {}
.cp_environment #sec-03 ._section {
  border-top: 1px solid var(--col-06);
  padding-top: 30px;
}
.cp_environment #sec-03 ._section .cp_inner_2col {
  display: flex;
  flex-direction: column-reverse;
  gap: 40px;
}
@media screen and (min-width: 768px) {
  .cp_environment #sec-03 ._section .cp_inner_2col {
    flex-direction: row;
    gap: 60px;
  }
  .cp_environment #sec-03 ._section .cp_inner_2col ._main {
    width: 50%;
  }
  .cp_environment #sec-03 ._section .cp_inner_2col ._pic {
    flex: 1
  }
}


/*-------------------------------------
  Title
*/




/*-------------------------------------
  margin
*/
.mt50 { margin-top: 50px;}
.mt60 { margin-top: 60px;}
.mt70 { margin-top: 70px;}
.mt80 { margin-top: 80px;}
.mt90 { margin-top: 90px;}
.mt100 { margin-top: 100px;}
.mt120 { margin-top: 120px;}

/*-------------------------------------
  Text
*/

/*基本テキスト：会社案内だけ仕様変更*/
.all_txt {
  font-size: clamp( 15px, calc( 14.5px + 0.12vw ), 16px );
}


.txt-bold { font-weight: bold;}
.txt-red {
  color: var(--col-01);
}
.under-line-red {
  border-bottom: 1px solid var(--col-01);
  padding-bottom: 3px;
  /*display: inline-block;*/
}
.strong-txt {
  font-weight: bold;
  border-bottom: 2px solid #ffb0b4;
  padding-bottom: 3px;
}
