@charset "utf-8";

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

ベース

==================================================*/
html {
	line-height: 1.5;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
  scroll-behavior: smooth;
}
body {
  background-color: #fff;
	color: #5E6975;	
  font-family: "Noto Sans JP", sans-serif;
	font-size: 1.6rem;
	-webkit-font-smoothing: antialiased;
/*	font-feature-settings: "palt";*/
	letter-spacing: 0;
}
body.menu-open{
	overflow: hidden;
}
html.menu-open{
	overflow: hidden;
}

/*========= font family変数指定 ==========*/
/*
:root {
	--font-sans-serif: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
	--font-serif: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.m-title{
	font-family: var(--font-serif);
}
*/
/*===================*/

img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
a {
	color: #5E6975;
	text-decoration: none;
	cursor: pointer;
}

/* フェードイン */
.js-inview {
	opacity: 0;
	transition: opacity .8s;
}
.js-inview.is-show {
	opacity: 1;
}

/* アンカー
--------------------------------------------------*/
.anchor{
  position: relative;
}
/* PC */
@media print,only screen and (min-width: 768px){
  .anchor{
    scroll-margin-top: 6rem;
  }
}

/* SP */
@media screen and (max-width: 767px){
 .anchor{
    scroll-margin-top: 6rem;
  }
}

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

全ページ共通

==================================================*/
/* PC */
@media print, screen and (min-width: 768px) {
	html {
		font-size: 10px;
	}
	.sp {
		display: none!important;
	}
	a:hover {
		text-decoration: underline;
	}
}

/* SP */
@media screen and (max-width: 767px) {
	html {
		font-size: 2.67vw;
	}
	.pc {
		display: none!important;
	}
}

/* form リセット
--------------------------------------------------*/
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}
input[type="checkbox"]{
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

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

ヘッダー

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

/* レイアウト 
--------------------------------------------------*/
.l-header img{
  width: 100%;
}
.l-header a{
	display: block;
}
.l-header{
  width: 100%;
  border-bottom: 1px #CBDEF4 solid;
  position: relative;
}
.l-header__logo{
  position:absolute;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .l-header{
    height: 6.3rem;
  }
  .l-header__logo{
    width: 11.2rem;
    top:1.7rem;
    left:1.2rem;
  }
}

/* SP */
@media screen and (max-width: 767px){	
  .l-header{
    height: 4.8rem;
  }
  .l-header__logo{
    width: 8rem;
    top:0.9rem;
    left:0.8rem;
    z-index: 101;
  }
}

/* グローバルナビ
--------------------------------------------------*/
.nav-global__itemIn{
  color: #1a1a1a;
  font-weight: 500;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .nav-global{
    position:absolute;
    top:0;
    right: 39.5rem;
    display: flex;
    justify-content: flex-end;
  }
  .nav-global__itemIn{
    font-size: 1.4rem;
    padding: 2rem 1rem;
    transition: color .3s ease;
   }
  .nav-global__itemIn:hover{
    color: #005EEA;
    text-decoration: none;
   }
}

/* SP */
@media screen and (max-width: 767px){	
  .nav-global{
    text-align: center;
    margin-bottom: 4rem;
  }
  .nav-global__itemIn{
    font-size: 1.6rem;
    padding: 2rem 1rem;
   }
  .nav-global__itemIn:hover{
    color: #005EEA;
    text-decoration: none;
   }
}

/* ヘッダーナビ
--------------------------------------------------*/
.nav-header__item.-download .nav-header__itemIn{
  color: #005EEA;
  box-shadow: inset 0 0 0 1px #005EEA;
}
.nav-header__item.-contact .nav-header__itemIn{
  color: #fff;
  background: linear-gradient(90deg, #005EEA 0%, #00C2C5 100%);
}
.nav-header__itemIn{
  font-weight: 500;
  border-radius: 0.4rem;
}

/* PC */
@media print,only screen and (min-width: 768px){   
  .nav-header{
    position:absolute;
    top:1.05rem;
    right:1.2rem;
    display: flex;
    justify-content: flex-end;
    gap:0 0.8rem;
  }
  .nav-header__itemIn{
    font-size: 1.4rem;
    padding: 1rem 2.4rem;
    transition: color .3s ease;
    position: relative;
  }
  .nav-header__itemInIn{
    position: relative;
  }
  .nav-header__itemIn:before{
    content: "";
    background-color: #D0E7FF;
    position: absolute;
    inset:0;
    border-radius: 0.4rem;
    opacity: 0;
    transition: opacity .3s ease;
  }
  .nav-header__item .nav-header__itemIn:hover{
    box-shadow: none;
    color: #005EEA;
    text-decoration: none;
  }
  .nav-header__item .nav-header__itemIn:hover:before{
    opacity: 1;
  }
}

@media (min-width: 768px) and (max-width: 1012px) {
  .nav-global{
    right: 33rem;
  }
  .nav-global__itemIn{
    font-size: 1.3rem;
    padding: 2rem 0.6rem;
   }
  .nav-header__itemIn{
    font-size: 1.3rem;
    padding: 1rem 1.5rem;
  }
}
@media (min-width: 768px) and (max-width: 880px) {
  .l-header__logo{
    width: 8rem;
    top:1.1rem;
  }
  .nav-global{
    right: 28.2rem;
  }
  .nav-global__itemIn{
    font-size: 1.2rem;
    padding: 2rem 0.4rem;
   }
  .nav-header__itemIn{
    font-size: 1.2rem;
    padding: 1rem 0.8rem;
  }
}

/* SP */
@media screen and (max-width: 767px){	 
  .nav-header__item{
    margin-bottom: 2rem;
    text-align: center;
  }
  .nav-header__itemIn{
    font-size: 1.6rem;
    padding: 2rem 1rem;
  }
}

/* ハンバーガー
--------------------------------------------------*/

/* PC */
@media print,only screen and (min-width: 768px){ 
	.m-hamburger{
	  display:none;
	}
  .l-header__menus{
    display:block!important;
  }
}

/* SP */
@media screen and (max-width: 767px){	
	.l-header__menus{
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		height:100%;
    z-index: 100;
    position: fixed;
    inset:0;
    background: rgba(255, 255, 255, 0.6);
    backdrop-filter: blur(25px);
    padding: 9.5rem 4.7rem 4.7rem 4.7rem;
    display: none;
	}
	.m-hamburger{
		width: 5.6rem;
		height: 4.8rem;
		position: absolute;
		top: 0;
		right: 0;
		cursor: pointer;
		z-index: 101;
	}
	.m-hamburger__lines{
		height: 50%;
		width:71.43%;
		margin: 20% auto 0 auto;
		position: relative;
	}
	.m-hamburger__lines>div{
		background-color: #005EEA;
		width:100%;
		height:4.8%;
		transition: transform .3s ease, opacity .3s ease;
		position: absolute;
		left:0;
		top:50%;
	}
	.m-hamburger__lines>div:first-child{
		transform: translateY(-300%);
	}
	.m-hamburger__lines>div:last-child{
		transform: translateY(300%);
	}
	.menu-open .m-hamburger__lines>div:first-child{
		transform: rotate(205deg);
	}
	.menu-open .m-hamburger__lines>div:last-child{
		transform: rotate(-205deg);
	}
}

/* 下部固定ナビ
--------------------------------------------------*/
.l-bottomButtons{
  background: rgba(216, 237, 255, 0.65);
  backdrop-filter: blur(8px);
  display: flex;
  justify-content: center;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 99;
}
.l-bottomButton{
  text-align: center;
}
.l-bottomButton__text{
  color: #005EEA;
  font-weight: 500;
}
.l-bottomButton__button.-download .l-bottomButton__buttonIn{
  color: #005EEA;
  box-shadow: inset 0 0 0 1px #005EEA;
}
.l-bottomButton__button.-contact .l-bottomButton__buttonIn{
  color: #fff;
  background: linear-gradient(90deg, #005EEA 0%, #00C2C5 100%);
}
.l-bottomButton__buttonIn{
  font-weight: 500;
  border-radius: 0.4rem;
  display: block;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .l-bottomButtons{
    padding: 1.5rem 3rem;
    gap:0 2rem;
  }
  .l-bottomButton{
    width: 28rem;
  }
  .l-bottomButton__text{
    font-size: 1.2rem;
    margin-bottom: 0.6rem;
  }
  .l-bottomButton__buttonInIn{
    position: relative;
    z-index: 5;
  }
  .l-bottomButton__buttonIn{
    font-size: 1.4rem;
    border-radius: 0.4rem;
    padding: 1.05rem 1rem;
    position: relative;
  }
  .l-bottomButton__buttonIn:before{
    content: "";
    background-color: #D0E7FF;
    position: absolute;
    inset:0;
    border-radius: 0.4rem;
    opacity: 0;
    transition: opacity .3s ease;
  }
  .l-bottomButton__button .l-bottomButton__buttonIn:hover{
    box-shadow: none;
    color: #005EEA;
    text-decoration: none;
  }
  .l-bottomButton__button .l-bottomButton__buttonIn:hover:before{
    opacity: 1;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .l-bottomButtons{
    padding: 1rem;
    gap:0 0.8rem;
  }
  .l-bottomButton{
    width: calc( 50% - 0.4rem );
  }
  .l-bottomButton__text{
    font-size: 0.8rem;
    margin-bottom: 0.4rem;
  }
  .l-bottomButton__buttonIn{
    background-color: #fff;
    font-size: 1.2rem;
    padding: 1.2rem 0.5rem;
  }
}

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

フッター

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

/* フッター1
--------------------------------------------------*/
.l-footer{
  background-color: #fff;
}
.l-footer__logo img{
  width: 100%;
}	
.nav-footers{
  display: flex;
}	
.nav-footer__itemIn{
  display: block;
  position: relative;
  color: #1a1a1a;
}	
.nav-footer__itemIn:before{
  content: "";
  background-color: #005EEA;
  border-radius: 50%;
  position: absolute;
  left: 0;
  display: block;
}	
.l-footer__buttonItemIn{
  color: #1a1a1a;
  display: block;
}	
.nav-footer02{
  display: flex;
}
.nav-footer02__itemIn{
  color: #98A1AC;
  position: relative;
}
.nav-footer02__itemIn:before{
  content: "";
  width: 1px;
  position: absolute;
  left: 0;
  background-color: #98A1AC;
  display: block;
}
.nav-footer02__item:first-child .nav-footer02__itemIn:before{
  content: none;
}
.nav-footer02__item:first-child .nav-footer02__itemIn{
  padding-left: 0;
}
.l-footer__copy{
  color: #98A1AC;
}
.l-footer__text{
  color: #98A1AC;
  line-height: 1.6;
}
.l-footer__marks{
  display: flex;
}
.l-footer__mark img{
  width: auto;
  max-width: auto;
}

/* PC */
@media print,only screen and (min-width: 768px){   
  .l-footer{
    padding: 8rem 3rem 20rem 3rem;
  }
  .l-footer__top,
  .l-footer__bottom{
    display: flex;
    justify-content: space-between;
  }	
  .l-footer__top{
    align-items: flex-start;
    padding-bottom: 4rem;
    border-bottom: 1px #CBDEF4 solid;
  }	
  .l-footer__bottom{
    align-items: center;
    padding-top: 2rem;
  }	
  .l-footer__left{
    width: 30rem;
  }	
  .l-footer__right{
    width: calc( 100% - 32rem );
    display: flex;
    justify-content: flex-end;
  }	
  .l-footer__rightItem{
    display: flex;
    justify-content: flex-end;
    width: fit-content;
  }	
  .l-footer__bottom .l-footer__rightItem{
    flex-wrap: wrap;
    gap:1rem 0;
  }	
  .l-footer__logo{
    width: 10.6rem;
  }	
  .nav-footers{
    display: flex;
  }	
  .nav-footer{
    width: 100%;
    border-right: 1px #CBDEF4 solid;
  }	
  .nav-footer:first-child{
    border-right: none;
  }	
  .nav-footer__itemIn{
    font-size: 1.4rem;
    white-space: nowrap;
    padding: 0.8rem 4rem 0.8rem 1.2rem;
    transition: color .3s ease;
  }	
  .nav-footer__itemIn:hover{
    color: #005EEA;
    text-decoration: none;
  }	
  .nav-footer__itemIn:before{
    width: 0.4rem;
    height: 0.4rem;
    top: 1.15em;
  }	
  .l-footer__button{
    margin-left: 4.8rem;
  }
  .l-footer__buttonItemIn{
    font-size: 1.4rem;
    white-space: nowrap;
    transition: color .3s ease;
  }	
  .l-footer__buttonItemIn:hover{
    color: #005EEA;
    text-decoration: none;
  }	
  .-download .l-footer__buttonItemIn{
    background: url("../images/shared/icon-download.svg") 0 0.1rem no-repeat;
    background-size: 2rem auto;
    padding: 0 0 3.2rem 2.4rem;
    border-bottom: 1px #CBDEF4 solid;
  }
  .-contact .l-footer__buttonItemIn{
    background: url("../images/shared/icon-mail.svg") left bottom no-repeat;
    background-size: 2rem auto;
    padding: 3.2rem 0 0 2.4rem;
  }
  .nav-footer02__itemIn{
    font-size: 1rem;
    padding: 0 1.2rem;
  }
  .nav-footer02__itemIn:before{
    top: 0.3rem;
    bottom: 0.2rem;
  }
  .l-footer__copy{
    font-size: 1rem;
  }
  .l-footer__text{
    font-size: 1rem;
    margin-right: 1.2rem;
  }
  .l-footer__marks{
    gap:0 1.2rem;
  }
  .l-footer__mark img{
    height: 4rem;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .l-footer{
    border-top: 1px #CBDEF4 solid;
    margin-top: 7rem;
    padding: 4rem 1.6rem 10.4rem 1.6rem;
  }
  .l-footer__logo{
    width: 10.6rem;
    margin-bottom: 4rem;
  }	
  .nav-footers{
    display: flex;
    margin-bottom: 3rem;
  }	
  .nav-footer__itemIn{
    font-size: 1.4rem;
    padding: 1.2rem 4rem 1.2rem 1.2rem;
  }	
  .nav-footer__itemIn:before{
    width: 0.4rem;
    height: 0.4rem;
    top: 1.5em;
  }	
  .l-footer__button{
    border-top: 1px #CBDEF4 solid;
    margin-bottom: 1rem;
  }
  .l-footer__buttonItemIn{
    font-size: 1.4rem;
    padding: 2.4rem;
    border-bottom: 1px #CBDEF4 solid;
  }	
  .-download .l-footer__buttonItemIn{
    background: url("../images/shared/icon-download.svg") left center no-repeat;
    background-size: 2rem auto;
  }
  .-contact .l-footer__buttonItemIn{
    background: url("../images/shared/icon-mail.svg") left center no-repeat;
    background-size: 2rem auto;
  }
  .nav-footer02__itemIn{
    font-size: 1rem;
    padding: 0 0.8rem;
  }
  .nav-footer02__itemIn:first-child{
    padding-left: 0;
  }
  .l-footer__copy{
    font-size: 1rem;
    margin-bottom: 1.2rem;
  }
  .l-footer__text{
    font-size: 1rem;
    margin-right: 1.2rem;
  }
  .l-footer__marks{
    gap:0 0.5rem;
    margin-top: 0.8rem;
  }
  .l-footer__mark img{
    height: 3.2rem;
  }
}

/* ページトップ
--------------------------------------------------*/
.l-footer__pagetop {
  width: 3.2rem;
  height: 3.2rem;
  position: fixed;
  z-index: 98;
  cursor: pointer;
  right: 0.8rem;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .l-footer__pagetop {
    bottom: 10.4rem;
  }
}

/* SP */
@media screen and (max-width: 767px){	
  .l-footer__pagetop {
    bottom: 8.5rem;
  }
}

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

セカンド共通

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

/* レイアウト
--------------------------------------------------*/
.l-content{
	line-height: 1.7;
}

/* PC */
@media print,only screen and (min-width: 768px){	
	.l-content__inner{
		font-size: 1.6rem;
		padding: 0 3rem;
		margin: 0 auto 14.4rem auto;		
    box-sizing: content-box;
	}
	.l-content__inner.-w1200{
		max-width: 120rem;
	}
	.l-content__inner.-w996{
		max-width: 99.6rem;
	}
	.l-content__inner.-w792{
		max-width: 79.2rem;
	}
	.l-content__inner.-w588{
		max-width: 58.8rem;
	}
	.l-container{
		max-width: 100rem;
		font-size: 1.6rem;
		display: flex;
		justify-content: space-between;
		padding: 0 3rem;	
		margin: 0 auto 9rem auto;		
    box-sizing: content-box;
	}
	.l-container .l-sidebar{
		width: 27rem;		
	}
	.l-container .l-main{
		width: 78rem;
	}	
}

/* SP */
@media screen and (max-width: 767px){
	.l-content{
		font-size: 1.4rem;
    padding: 0 2rem;
	}
	.l-container{
		font-size: 1.4rem;
	}
}

/* ページタイトル
--------------------------------------------------*/
.m-pageTitle{
  box-sizing: border-box;
}
.m-pageTitle__item{
  color: #005EEA;
	font-weight: bold;	
  text-align: center;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .m-pageTitle{
    height: 36.1rem;
    background: url("../images/shared/title-bg.svg") calc( 50% - 5.5rem ) top no-repeat;
    background-size: 147.6rem auto;
    padding-top: 11.5rem;
    margin-bottom: 14.4rem;
  }
  .m-pageTitle__item{
    font-size: 4rem;
  }
}

/* SP */
@media screen and (max-width: 767px){	
  .m-pageTitle{
    height: 15rem;
    background:url("../images/shared/title-bg.svg") calc( 50% - 5.5rem ) top no-repeat;
    background-size: 60rem auto;
    padding-top: 4rem;
    margin-bottom: 12rem;
  }
  .m-pageTitle__item{
    font-size: 3rem;
  }
}

/* ぱんくず
--------------------------------------------------*/
.m-bread__inner{
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin: 0 auto;
}
.m-bread li{
  color: #5E6975;
}
.m-bread a{
  color: #5E6975;
  position: relative;
}
.m-bread a:after{
  content: "";
  background: url("../images/shared/arrow-bread.svg") center center no-repeat;
  background-size: 100% auto;
  display: inline-block;
}

/* PC */
@media print,only screen and (min-width: 768px){	
  .m-bread{
    padding: 2.4rem 8rem;
  }
  .m-bread__inner{
    max-width: 120rem;
    margin: 0 auto;
  }
  .m-bread li{
    font-size: 1.2rem;
  }
  .m-bread a:after{
    width: 0.8rem;
    height: 0.8rem;
    margin: 0 0.6rem 0 0.8rem;
  }
}

/* SP */
@media screen and (max-width: 767px){		
  .m-bread{
    padding: 1rem 2rem;
  }
  .m-bread li{
    font-size: 1.1rem;
  }
  .m-bread a:after{
    width: 0.8rem;
    height: 0.8rem;
    margin: 0 0.6rem 0 0.8rem;
  }
}

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

トップページ

==================================================*/
/* メイン
--------------------------------------------------*/
.home-cover img{
  width: 100%;
}
.home-cover__left{
  text-align: center;
}
.home-cover__text02{
  color: #1a1a1a;
  font-weight: 600;
}
.home-cover__text03{
  color: #005EEA;
  line-height: 1.32;
  font-weight: 800;
}
.home-cover__image{
  margin: 0 auto;
}

/* PC */
@media print,only screen and (min-width: 768px){   
  .home-cover{
    background: url("../images/home/main-bg.svg") calc( 50% - 3.5rem ) 2rem no-repeat;
    background-size: 226rem auto;
    padding: 6.4rem 3rem 0 3rem;
    height: min( 74.5rem,62.084vw );
    box-sizing: border-box;
  }
  .home-cover__inner{
    max-width: 120rem;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
  }
  .home-cover__left{
    width: 55.5%;
  }
  .home-cover__right{
    width: 38.34%;
    margin-right: min( 2.4rem,2vw);
    background-color: #fff;
    box-shadow: 0 2.6rem 4rem -1.2rem rgba(0, 23, 62, 0.1);
    border-radius: 0.8rem;
    overflow: hidden;
  }
  .home-cover__right iframe{
    aspect-ratio: 197 / 244;
  }
  .home-cover__text01{
    width: 85.12%;
    margin:0 auto min( 1.4rem,1.11666vw) auto;
  }
  .home-cover__text02{
    font-size: min( 3.6rem,3vw);
    margin-bottom: min( 0.1rem,0.8333vw);
  }
  .home-cover__text03{
    font-size: min( 6.6rem,5.5vw);
    margin-bottom: min( 2rem,1.666vw);
    white-space: nowrap;
  }
  .home-cover__text03 span{
    font-size: min( 4.4rem,3.6vw);
  }
  .home-cover__image{
    width: 75.34%;
  }
}

/* SP */
@media screen and (max-width: 767px){	  
  .home-cover{
    background: url("../images/home/main-bg-sp.svg") center bottom no-repeat;
    background-size: 100% auto;
    padding: 3.2rem 1.8rem 2.4rem 1.8rem;
  }
  .home-cover__text01{
    width: 100%;
    margin-bottom: 1.6rem;
  }
  .home-cover__text02{
    font-size: 2.2rem;
    margin-bottom: 0.7rem;
  }
  .home-cover__text03{
    font-size: 4.3rem;
    margin-bottom: 0.3rem;
  }
  .home-cover__image{
    width: 31.6rem;
  }
}

/* 企業
--------------------------------------------------*/
.home-companies{
  overflow-x: hidden;
}
.home-companies__slide{
  overflow: hidden;
}
.home-companies__title{
  color: #1a1a1a;
  font-weight: 500;
  text-align: center;
}
.home-companies__title span{
  color: #005EEA;
}
.home-companies__slideIn{
  display: flex;
  width: max-content;
  flex-wrap: nowrap;
  align-items: center;
  animation: home-companies-marquee var(--home-companies-duration, 50s) linear infinite;
  will-change: transform;
}
.home-companies__slideIn.is-reverse{
  animation-direction: reverse;
}
.home-companies__slideItem{
  flex: 0 0 auto;
}
.home-companies__slide img{
  width: auto;
  max-width: auto;
}

@keyframes home-companies-marquee{
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-50%, 0, 0);
  }
}

@media (prefers-reduced-motion: reduce){
  .home-companies__slideIn{
    animation: none;
    transform: none;
  }
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .home-companies{
    margin-bottom: 11.2rem;
  }
  .home-companies__title{
    font-size: 2.4rem;
    margin-bottom: 4rem;
  }
  .home-companies__slideIn{
    /* gap:0 4.8rem; */
    margin-bottom: 2.4rem;
  }
  .home-companies__slideItem{
    padding-right: 4.5rem;
  }
  .home-companies__slide img{
    height: 3.2rem;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-companies{
    margin-bottom: 4.5rem;
  }
  .home-companies__title{
    font-size: 1.5rem;
    margin-bottom: 1.5rem;
  }
  .home-companies__slideIn{
    /* gap:0 2.4rem; */
    margin-bottom: 1.6rem;
  }
  .home-companies__slideItem{
    padding-right: 2.4rem;
  }
  .home-companies__slide img{
    height: 2rem;
  }
}
	
/* ラインナップ
--------------------------------------------------*/
.home-lineup img{
  width: 100%;
}
.home-lineup__item{
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #fff;
  border: 1px solid #005EEA;
  box-shadow: 0 2.6rem 4rem -1.2rem rgba(0, 23, 62, 0.1);
  border-radius: 0.8rem;
  position: relative;
}
.home-lineup__item:before{
  content: "";
  background-color: #005EEA;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
}
.home-lineup__item:after{
  background: url("../images/shared/next.svg") center center no-repeat;
  content: "";
  background-color: #D0E7FF;
  border-radius: 0.4rem;
  position: absolute;
  top: 0;
  bottom: 0;
  display: block;
  margin: auto 0;
}
.home-lineup__image{
  position: relative;
}
.home-lineup__title{
  color: #000;
  font-weight: 500;
  line-height: 1.85;
}
.home-lineup__text{
  color: #5E6975;
}

/* PC */
@media print,only screen and (min-width: 768px){   
  .home-lineup{
    max-width: 120rem;
    padding: 0 3rem;	
    margin: 0 auto 14.4rem auto;	
    box-sizing: content-box;
  }
  .home-lineup__item{
    padding: 2rem 19.2rem 2rem 1.7rem;
  }
  .home-lineup__item:before{
    width: 27.25%;
  }
  .home-lineup__item:after{
    width: 5.6rem;
    height: 3.2rem;
    background-size: 0.8rem auto;
    border-radius: 0.4rem;
    right: 8rem;
    margin: auto 0;
    transition: all .3s ease;
  }
  .home-lineup__item:hover:after{
    width: 6.72rem;
    height: 3.84rem;
    background: url("../images/shared/next-white.svg") center center no-repeat;
    background-size: 0.8rem auto;
    background-color: #005EEA;
  }
  .home-lineup__item:hover{
    text-decoration: none;
  }
  .home-lineup__image{
    width: 34.34%;
  }
  .home-lineup__texts{
    width: 57.67%;
  }
  .home-lineup__title{
    background: url("../images/home/lineup-icon.svg") left 0.2em no-repeat;
    background-size: 2.8rem auto;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.85;
    margin-bottom: 0.6rem;
    padding-left: 3.6rem;
  }
  .home-lineup__text{
    font-size: 1.4rem;
    line-height: 1.714;
  }
}

/* SP */
@media screen and (max-width: 767px){ 
  .home-lineup{
    margin: 0 2rem 5.4rem 2rem;
  }
  .home-lineup__item{
    padding: 1.1rem;
  }
  .home-lineup__item:before{
    width: 10.4rem;
  }
  .home-lineup__image{
    width: 11.4rem;
  }
  .home-lineup__texts{
    width: 18.7rem;
  }
  .home-lineup__title{
    background: url("../images/home/lineup-icon.svg") left 0.15em no-repeat;
    background-size: 2rem auto;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.85;
    padding-left: 2.3rem;
  }
}
	
/* e2R PROとは
--------------------------------------------------*/
.home-about img{
  width: 100%;
}
.home-about__heading{
  color: #1a1a1a;
  font-weight: bold;
}
.home-about__text01{
  color: #005EEA;
  font-weight: 500;
}
.home-about__text02{
  color: #1a1a1a;
  font-weight: bold;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .home-about{
    max-width: 120rem;
    padding: 0 3rem;	
    margin: 0 auto 14.4rem auto;	
    box-sizing: content-box;
    display: flex;
    justify-content: space-between;
  }
  .home-about__image{
    width: 46.5%;
    order: 1;
  }
  .home-about__texts{
    width: 47.5%;
    order: 2;
  }
  .home-about__heading{
    font-size: 3.6rem;
    margin-bottom: 1.4rem;
  }
  .home-about__text01{
    font-size: 2rem;
    margin-bottom: 0.2rem;
  }
  .home-about__text02{
    font-size: 2.8rem;
    margin-bottom: 1.4rem;
  }
  .home-about__text03{
    font-size: 1.6rem;
    line-height: 1.75;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-about{
    margin: 0 2rem 5.4rem 2rem;
  }
  .home-about__texts{
    margin-bottom: 3.8rem;
  }
  .home-about__heading{
    font-size: 2.6rem;
    margin-bottom: 1.4rem;
  }
  .home-about__text01{
    font-size: 1.6rem;
  }
  .home-about__text02{
    font-size: 2.4rem;
    margin-bottom: 1rem;
  }
  .home-about__text03{
    font-size: 1.4rem;
    line-height: 1.85;
  }
}
	
/* AI活用プロジェクト
--------------------------------------------------*/
.home-project img{
  width: 100%;
}
.home-project{
  background-color: #EEF5FC;
  overflow-x: hidden;
}
.home-project__top{
  position: relative;
}
.home-project__heading{
  color: #1a1a1a;
  font-weight: bold;
}
.home-project__box{
  background-color: #fff;
  border-radius: 0.8rem;
}
.home-project__boxText01{
  color: #1a1a1a;
  font-weight: 600;
}
.home-project__boxLogo{
  border: 1px #005EEA solid;
  border-radius: 0.4rem;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .home-project{
    padding: 10.4rem 3rem 5.4rem 3rem;
    margin-bottom: 14.4rem;
  }
  .home-project__inner{
    max-width: 120rem;
    margin: 0 auto;	
  }
  .home-project__item{
    display: flex;
    justify-content: space-between;
    margin: 0 calc( 50% - 50vw ) 0 0;
  }
  .home-project__itemTexts{
    width: 42rem;
  }
  .home-project__heading{
    font-size: 3.8rem;
    margin-bottom: 2rem;
  }
  .home-project__itemText{
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .home-project__slildeWrapper{
    width: calc( 100% - 52rem );
    margin-bottom: 6.4rem;
  }
  .home-project__box{
    padding: 5.6rem;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
  }
  .home-project__boxTexts{
    width: 47.5%;
  }
  .home-project__boxText01{
    font-size: 2.4rem;
    line-height: 1.416;
    margin-bottom: 2.4rem;
  }
  .home-project__boxText02{
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .home-project__boxLogo{
    width: 47.42%;
  }
  .home-project__boxLogoInner{
    width: 82%;
    max-width: 30.7rem;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-project{
    padding: 5.6rem 2rem 2rem 2rem;
    margin-bottom: 5.4rem;
  }
  .home-project__item{
    margin-bottom: 6rem;
  }
  .home-project__itemTexts{
    margin-bottom: 4rem;
  }
  .home-project__heading{
    font-size: 2.6rem;
    margin-bottom: 1.6rem;
  }
  .home-project__itemText{
    font-size: 1.4rem;
    line-height: 1.85;
  }
  .home-project__slildeWrapper{
    margin:0 -2rem 6rem -2rem;
  }
  .home-project__box{
    padding: 2rem;
  }
  .home-project__boxTexts{
    margin-bottom: 2rem;
  }
  .home-project__boxText01{
    font-size: 2rem;
    margin-bottom: 0.5rem;
  }
  .home-project__boxText02{
    font-size: 1.4rem;
    line-height: 1.96;
  }
  .home-project__boxLogo{
    padding: 1.6rem 2rem;
  }
}

/* AI活用プロジェクト　+　事例　スライダー
--------------------------------------------------*/
.home-case__slideItemIn{
  background-color: #fff;
  border-radius: 0.4rem;
  box-shadow: 0 2.6rem 4rem -1.2rem rgba(0, 23, 62, 0.1);
  display: block;
  position: relative;
  border: 1px #fff solid;
}
.home-case__slideItemIn:after{
  width: 0.4rem;
  height: 0.4rem;
  content: "";
  background-color: #005EEA;
  border-radius: 50%;
  position: absolute;
  right: 0.8rem;
  bottom: 0.8rem;
  display: block;
}
.home-case__slide .slick-slide{
  padding:0 0 4rem 0;
}
.home-case__name{
  color: #1a1a1a;
  font-weight: bold;
  margin: 2rem 0 0.5rem 1.2rem;
}
.home-case__textLogo{
  display: flex;
  justify-content: space-between;
  margin-left: 1.2rem;
}
.home-case__text{
  width: 66%;
  padding-right: 10%;
  font-size: 1.4rem;
  line-height: 1.714;
  position: relative;
}
.home-case__text:after{
  content: "";
  width: 1px;
  background-color: #EEF5FC;
  position: absolute;
  top: 0.2rem;
  right: 0;
  bottom: 0.2rem; 
  display: block;
}
.home-case__logo{
  width: 34%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.home-case__logo img{
  width: 40%;
}
.home-project__controls,
.home-case__controls{
  position: relative;
}
.home-project__arrows .slick-prev,
.home-case__arrows .slick-prev{
  background-image: url("../images/shared/prev.svg");
  left: 0;
}
.home-project__arrows .slick-next,
.home-case__arrows .slick-next{
  background-image: url("../images/shared/next.svg");
  right: 0;
}
.home-project__arrows .slick-arrow,
.home-case__arrows .slick-arrow{
  background-color: #fff;
  border: 1px solid #005EEA;
  border-radius: 0.4rem;  
  background-position: center center;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  text-indent: -9999px;
  cursor: pointer;
  box-sizing: border-box;
}
.home-project__progressbarWrapper,
.home-case__progressbarWrapper{
  margin: 0 auto;
}
.home-project__progressbar,
.home-case__progressbar{
  flex:1;
  height:2px;
  background-color:#cfe0ff;
  border-radius:0.3rem;
  overflow:hidden;
}
.home-project__progressbar-current,
.home-case__progressbar-current{
  height:100%;
  width:0;
  background-color:#005EEA;
  transition:width .3s ease;
}
.home-case__detail{
  display: flex;
  align-items: center;
  gap:0 0.4rem;
  margin: 0.6rem 0 0 1.1rem;
}
.home-case__detailTitle{
  color: #005EEA;
  font-size: 1rem;
  background-color: #EEF5FC;
  border-radius: 10rem;
  padding: 0.3rem 0.8rem;
}
.home-case__detailText{
  font-size: 1.2rem;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .home-project__slildeWrapper{
    width: calc( 100% - 52rem );
    margin-bottom: 12rem;
  }
  .home-case__slideItem{
    width: 33.2rem!important;
  }
  .home-case__slide .slick-slide{
    padding-left:2rem;
  }
  .home-case__slideItemIn{
    padding: 0.8rem 0.8rem 2rem 0.8rem;
    transition: border .3s ease;
    overflow: hidden;
  }
  .home-case__slideItemIn:hover{
    border: 1px #005EEA solid;
    text-decoration: none;
  }
  .home-case__slideItemIn:after{
    transition: all .3s ease;
    transform: scale(1);
    transform-origin: left top;
  }
  .home-case__slideItemIn:hover:after{
    width: 1.4rem;
    height: 1.4rem;
    transform: scale(3.5);
    right: 0.4rem;
    bottom: 0.4rem;
  }
  .home-case__name{
    margin: 2rem 0 0.5rem 1.2rem;
  }
  .home-case__logo img{
    width: 40%;
  }
  .home-case__controls{
    width: 36.7rem;
    margin: 1.8rem auto 0 auto;
  }
  .home-project__controls{
    width: 36.7rem;
    position: absolute;
    right: 0;
    bottom: 8.5rem;
  }
  .home-project__arrows .slick-arrow,
  .home-case__arrows .slick-arrow{
    width: 5.6rem;
    height: 3.2rem;
    border-radius: 0.4rem;  
    background-size: 0.8rem auto;
  }
  .home-project__progressbarWrapper,
  .home-case__progressbarWrapper{
    width: 22.3rem;
  }
  .home-project__progressbar-current,
  .home-case__progressbar-current{
    height:100%;
    width:0;
    background-color:#005EEA;
    transition:width .3s ease;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-project__slildeWrapper{
    margin:0 -2rem 4rem -2rem;
  }
  .home-case__slide .slick-list{
/*    padding-left: 2rem;*/
  }
  .home-case__slideItemIn{
    width: 31.2rem!important;
    margin-left: 2rem;
    padding: 0.8rem 0.8rem 2rem 0.8rem;
  }
  .home-case__name{
    margin: 2rem 0 0.5rem 1.2rem;
  }
  .home-case__logo img{
    width: 40%;
  }
  .home-case__controls,
  .home-case__controls{
    width: 24.8rem;
    margin: 0 auto;
  }
  .home-project__arrows .slick-arrow,
  .home-case__arrows .slick-arrow{
    width: 4rem;
    height: 4rem;
    border-radius: 0.4rem;  
    background-size: 0.8rem auto;
  }
  .home-project__progressbarWrapper,
  .home-case__progressbarWrapper{
    width: 13.6rem;
  }
  .home-project__progressbar-current,
  .home-case__progressbar-current{
    height:100%;
    width:0;
    background-color:#005EEA;
    transition:width .3s ease;
  }
}
	
/* 便利な機能
--------------------------------------------------*/
.home-function img{
  width: 100%;
}
.home-function__heading01{
  color: #005EEA;
  font-weight: 500;
  display: block;
}
.home-function__heading02{
  color: #1a1a1a;
  font-weight: bold;
  display: block;
}
.home-function__item{
  background-color: #fff;
  border: 1px solid #005EEA;
  border-radius: 0.8rem;
  position: relative;
  box-sizing: border-box;
}
.home-function__item:after{
  content: "";
  width: 100%;
  height: 2rem;
  background-color: #EEF5FC;
  border-radius: 0.8rem;
  position: absolute;
  left: 0;
  right: 0;
  display: block;
  z-index: -1;
}
.home-function__text01{
  color: #005EEA;
  font-weight: 500;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .home-function{
    max-width: 120rem;
    padding: 0 3rem;	
    margin: 0 auto 12rem auto;	
    box-sizing: content-box;
  }
  .home-function__heading{
    margin-bottom: 5.2rem;
  }
  .home-function__heading01{
    font-size: 2rem;
    margin-bottom: 0.5rem;
    text-align: center;
  }
  .home-function__heading02{
    font-size: 3.6rem;
    text-align: center;
  }
  .home-function__items{
    display: flex;
    justify-content: space-between;
  }
  .home-function__item{
    width: 47.34%;
    border-radius: 0.8rem;
    padding: 4.8rem;
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }
  .home-function__item:after{
    bottom: -0.8rem;
  }
  .home-function__text01{
    font-size: 2.4rem;
    margin-bottom: 1.3rem;
    text-align: center;
  }
  .home-function__text02{
    font-size: 1.6rem;
    line-height: 1.875;
    margin-bottom: 1.6rem;
    flex: 1;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-function{
    margin: 0 2rem 5.4rem 2rem;
  }
  .home-function__heading{
    margin-bottom: 2rem;
  }
  .home-function__heading01{
    font-size: 1.6rem;
  }
  .home-function__heading02{
    font-size: 2.6rem;
    line-height: 1.3;
  }
  .home-function__item{
    padding: 2.4rem 2.5rem 2rem 2.5rem;
    margin-bottom: 2rem;
  }
  .home-function__item:last-child{
    margin-bottom:0;
  }
  .home-function__item:after{
    bottom: -0.7rem;
  }
  .home-function__text01{
    font-size: 2rem;
    margin-bottom: 0.8rem;
  }
  .home-function__text02{
    font-size: 1.4rem;
    line-height: 1.857;
    margin-bottom: 0.8rem;
  }
  .home-function__image{
    width: 22.5rem;
    margin: 0 auto;
  }
}
	
/* 4つの価値
--------------------------------------------------*/
.home-value img{
  width: 100%;
}
.-blue{
  color: #005EEA;
}
.home-value__heading{
  color: #1a1a1a;
  font-weight: bold;
}
.home-value__headingtext{
  text-align: center;
}
.home-value__item{
  position: relative;
}
.home-value__icon{
  position: absolute;
}
.home-value__title{
  color: #005EEA;
  font-weight: bold;
}
.home-value__text{
  color: #1a1a1a;
  font-weight: 600;
}
.home-value__image{
  background-color: #EEF5FC;
}
.home-value__heading .-large,
.home-theme__heading .-large{
  font-family: "Inter", sans-serif;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .home-value{
    max-width: 120rem;
    margin: 0 auto 14.4rem auto;
    padding: 0 3rem;
    box-sizing: content-box;
  }
  .home-value__heading{
    font-size: 3.8rem;
    margin-bottom: 1.8rem;
    text-align: center;
  }
  .home-value__heading .-large,
  .home-theme__heading .-large{
    font-size: 5.4rem;
    position: relative;
    top: 0.1em;
  }
  .home-value__headingtext{
    font-size: 1.6rem;
    margin-bottom: 4rem;
  }
  .home-value__items{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap:4.8rem 0;
    margin-bottom: 5.6rem;
  }
  .home-value__item{
    width: 47%;
    padding-top: 2.4rem;
    text-align: center;
  }
  .home-value__icon{
    width: 8rem;
    top: -0.4rem;
    right: calc( 50% + 6em );
  }
  .home-value__title{
    font-size: 3.8rem;
    margin-bottom: 2.4rem;
  }
  .home-value__text{
    font-size: 2.4rem;
    margin-bottom: 2.4rem;
  }
  .home-value__image img{
    width: 61%;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-value{
    margin: 0 2rem 5.4rem 2rem;
  }
  .home-value__heading{
    font-size: 2.6rem;
    line-height: 0.8;
    margin-bottom: 2rem;
  }
  .home-value__heading .-large,
  .home-theme__heading .-large{
    font-size: 5.4rem;
    position: relative;
    top: 0.15em;
  }
  .home-theme__heading .-large{
    font-size: 3.8rem;
    top: 0.05em;
  }
  .home-value__headingtext{
    font-size: 1.4rem;
    line-height: 1.857;
    margin-bottom: 3rem;
  }
  .home-value__item{
    border-top: 1px #CBDEF4 solid;
    padding: 3.2rem 0;
    position: relative;
    display: flex;
    justify-content: space-between;
  }
  .home-value__icon{
    width: 9.9rem;
    top: -2rem;
    left: 0;
    right: 0;
    margin: 0 auto;
    position: absolute;
    border: 0.8rem #fff solid;
  }
  .home-value__texts{
    width: 21rem;
  }
  .home-value__title{
    font-size: 2.6rem;
    line-height: 1.4;
    margin-bottom: 1.2rem;
  }
  .home-value__text{
    font-size: 1.8rem;
    line-height: 1.55;
  }
  .home-value__image{
    width: 11rem;
  }
}
	
/* ボタン
--------------------------------------------------*/
.m-button{
  margin: 0 auto;
}
.m-button__item{
  background-color: #005EEA;
  border-radius: 0.4rem;
  display: block;
  color: #fff;
  font-weight: 500;
  position: relative;
  transition: all .3s ease;
}
.-white .m-button__item{
  background-color: #fff;
  color: #005EEA;
}
.m-button__item:after{
  width: 0.8rem;
  height: 1.2rem;
  content: "";
  background: url("../images/shared/next-white.svg") center center no-repeat;
  background-size: 100% auto;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  display: block;
  transition: all .3s ease;
}
.-white .m-button__item:after{
  background: url("../images/shared/next.svg") center center no-repeat;
  background-size: 100% auto;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .m-button{
    width: fit-content;
    margin: 0 auto;
  }
  .m-button__item{
    padding: 1.6rem 6.4rem 1.6rem 5.6rem;
    font-size: 1.6rem;
    transition: all .3s ease;
  }
  .m-button__item:after{
    width: 0.8rem;
    height: 1.2rem;
    right:2rem;
    transition: all .3s ease;
  }
  .m-button__item:hover:after{
    background: url("../images/shared/next.svg") center center no-repeat;
    right: 1.8rem;
  }
  .m-button__item:hover{
    color: #005EEA;
    background-color: #D0E7FF;
    text-decoration: none;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .m-button{
    width: 100%;
  }
  .m-button__item{
    padding: 1.3rem 2.5rem;
    font-size: 1.4rem;
    text-align: center;
  }
  .m-button__item:after{
    width: 0.8rem;
    height: 1.2rem;
    right:1.9rem;
  }
}

/* 4つのテーマ
--------------------------------------------------*/
.home-theme img{
  width: 100%;
}
.home-theme{
  background-color: #36A3F6;
}
.home-theme__heading{
  color: #fff;
  font-weight: bold;
}
.home-theme__headingtext{
  color: #fff;
}
.home-theme__item{
  position: relative;
  background-color: #fff;
  box-shadow: 0 2.6rem 4rem -2.8rem rgba(0, 23, 62, 0.2);
  border-radius: 0.4rem;  
}
.home-theme__icon{
  position: absolute;
  z-index: 10;
}
.home-theme__title{
  background-color: #1a1a1a;
  color: #fff;
  line-height: 1.3;
  font-weight: bold;
  position: relative;
  border-radius: 0.4rem 0.4rem 0 0;
}
.home-theme__title:before{
  width: 1.8rem;
  height: 1.8rem;
  clip-path: polygon(100% 50%, 0 0, 0 100%);
  background-color: #1a1a1a;
  content: "";
  display: block;
  position: absolute;
  bottom: -0.75rem;
  right: 3.15rem;
  transform: rotate(-10deg);
}
.home-theme__text{
  color: #1a1a1a;
  font-weight: 500;
}
.home-theme__listItem{
  background-color: #EEF5FC;
}
.home-theme__listText{
  height: 4rem;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #005EEA;
  font-weight: 500;
}

/* PC */
@media print,only screen and (min-width: 768px){
  .home-theme{
    background: url("../images/home/theme.svg") calc( 50% - 15rem ) 20.5rem no-repeat;
    background-size: 196.2rem auto;
    background-color: #36A3F6;
    border-radius: 6.4rem;
    padding: 8.5rem 3rem 10rem 3rem;	
    margin-bottom: 14.4rem;
    text-align: center;
  }
  .home-theme__inner{
    max-width: 120rem;
    margin: 0 auto;	
  }
  .home-theme__heading{
    font-size: 3.6rem;
    margin-bottom: 1rem;
  }
  .home-theme__headingtext{
    font-size: 1.6rem;
    line-height: 1.875;
    margin-bottom: 5.6rem;
  }
  .home-theme__items{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap:3.5rem 0;
    margin-bottom: 5.6rem;
  }
  .home-theme__item{
    width: 23.5%;
  }
  .home-theme__icon{
    width: 6rem;
    left: 1.1rem;
    top: -1.3rem;
    z-index: 10;
  }
  .home-theme__title{
    font-size: 2.4rem;
    padding: 1.3rem 3rem;
  }
  .home-theme__text{
    font-size: 1.6rem;
    line-height: 1.75;
    margin: 2rem 0;
  }
  .home-theme__list{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap:0.8rem;
    margin: 0 1.6rem 1.6rem 1.6rem;
  }
  .home-theme__listItem{
    width: calc( 50% - 0.4rem );
    border-radius: 0.4rem;
    padding: 2rem 1rem 1.8rem 1rem;
  }
  .home-theme__listIcon{
    width: 5.9rem;
    margin: 0 auto 0.1rem auto;
  }
  .home-theme__listText{
    font-size: 1.2rem;
  } 
}

@media (min-width: 768px) and (max-width: 1230px) {
  .home-theme__item{
    width: 48%;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-theme{
    border-radius:3.2rem;
    padding: 4.5rem 2rem 4rem 2rem;
    margin-bottom: 5.4rem;
  }
  .home-theme__heading{
    font-size: 2.6rem;
    line-height: 1.3;
    margin-bottom: 1rem;
  }
  .home-theme__headingtext{
    font-size: 1.4rem;
    line-height: 1.857;
    margin-bottom: 2rem;
  }
  .home-theme__item{
    margin-bottom: 3.2rem;
    text-align: center;
    padding-bottom: 0.8rem;
  }
  .home-theme__item:last-child{
    margin-bottom: 2rem;
  }
  .home-theme__icon{
    width: 6rem;
    left: 1.1rem;
    top: -1.3rem;
    z-index: 10;
  }
  .home-theme__title{
    font-size: 2rem;
    padding: 1.1rem 3rem 1.1rem 3rem;
  }
  .home-theme__text{
    font-size: 1.4rem;
    line-height: 1.8;
    margin: 1.6rem 0;
  }
  .home-theme__list{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap:0.8rem;
    margin: 0 1.6rem 1rem 1.6rem;
  }
  .home-theme__listItem{
    width: calc( 50% - 0.4rem );
    border-radius: 0.4rem;
    padding: 1.7rem 1rem 1.2rem 1rem;
  }
  .home-theme__listIcon{
    width: 5.9rem;
    margin: 0 auto 0.1rem auto;
  }
  .home-theme__listText{
    font-size: 1.2rem;
  } 
}

/* e2R PROが選ばれる理由
--------------------------------------------------*/
.home-reason img{
  width: 100%;
}
.home-reason__heading{
  color: #1a1a1a;
  font-weight: bold;
}
.home-reason__images{
  display: flex;
}
.home-reason__text01{
  color: #1a1a1a;
  font-weight: 600;
  line-height: 1.6;
}
.home-reason__text02{
  font-size: 1.4rem;
  line-height: 1.92;
}

/* PC */
@media print,only screen and (min-width: 768px){
  .home-reason{
    max-width: 120rem;
    padding: 0 3rem;
    margin: 0 auto 14rem auto;	
    box-sizing: content-box;
  }
  .home-reason__heading{
    font-size: 3.6rem;
    text-align: center;
    margin-bottom: 5.6rem;
  }
  .home-reason__item{
    display: flex;
    justify-content: space-between;
  }
  .home-reason__images{
    width: 42.92%;
    gap:1.6rem;
  }
  .home-reason__image:first-child{
    width: 52.427%;
  }
  .home-reason__image:nth-child(2){
    width: 44.466%
  }
  .home-reason__texts{
    width: 50.42%;
  }
  .home-reason__text01{
    font-size: 2rem;
    margin-bottom: 2.4rem;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-reason{
    margin: 0 2rem 5.4rem 2rem;
  }
  .home-reason__heading{
    font-size: 2.6rem;
    text-align: center;
    margin-bottom: 2rem;
  }
  .home-reason__images{
    margin-bottom: 2rem;
    justify-content: space-between;
  }
  .home-reason__image{
    width: 16.1rem;
  }
  .home-reason__image:nth-child(2){
    width: 16.6rem;
  }
  .home-reason__text01{
    font-size: 2rem;
    margin-bottom: 0.8rem;
  }
}

/* 導入事例
--------------------------------------------------*/
.home-case__heading{
  color: #1a1a1a;
  font-weight: bold;
}
.home-case{
  overflow-x: hidden;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .home-case__inner{
    max-width: 120rem;
    padding: 0 3rem;
    margin: 0 auto 13.5rem auto;	
    box-sizing: content-box;
  }
  .home-case__heading{
    font-size: 3.6rem;
    margin-bottom: 2.2rem;
  }
  .home-case__headingtext{
    width: calc( 100% - 38rem );
    font-size: 1.6rem;
    line-height: 1.875;
    margin-bottom: 6rem;
  }
  .home-case__top{
    position: relative;
  }
  .home-case__slideWrapper{
    margin: 0 calc( 50% - 50vw ) 1.3rem calc( 50% - 50vw );
  }
  .home-case .home-case__slide .slick-list{
    margin-left: -12rem;
  }
  .home-case .home-case__controls{
    position: absolute;
    right: 0;
    bottom: 1.5rem;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-case__inner{
    position: relative;
    margin: 0 2rem 5.4rem 2rem;
  }
  .home-case__heading{
    font-size: 2.6rem;
    margin-bottom: 1.6rem;
  }
  .home-case__headingtext{
    font-size: 1.4rem;
    line-height: 1.857;
    margin-bottom: 2.4rem;
  }
  .home-case__slideWrapper{
    margin: 0 -2rem 6rem -2rem;
  }
  .home-case .home-case__controls{
    position: absolute;
    bottom: 10rem;
    left: 0;
    right: 0;
    margin: 0 auto;
  }
}

/* サポート体制
--------------------------------------------------*/
.home-support img{
  width: 100%;
}
.home-support__heading{
  font-weight: bold;
}
.home-support__heading01{
  color: #005EEA;
  font-weight: 500;
  display: block;
}
.home-support__heading02{
  color: #1a1a1a;
  font-weight: bold;
  display: block;
}
.home-support__text{
  text-align: center;
}
.home-support__item{
  border-radius: 0.4rem;
  background-color: #EEF5FC;
  position: relative;
}
.home-support__item:after{
  content:"";
  position: absolute;
  display: block;
}
.home-support__item:last-child:after{
  content:none;
}
.home-support__icon{
  width: 7.2rem;
  height: 7.2rem;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  color: #fff;
  font-weight: bold;
  font-size: 1.5rem;
  position: absolute;
}
.home-support__icon span{
  font-size: 1.1rem;
}
.home-support__icon:after{
  content: "";
  width: 3rem;
  height: 1px;
  position: absolute;
  bottom: 0.4rem;
  right: 1.5rem;
  display: block;
  transform: rotate(45deg);
}
.home-support__item:first-child .home-support__icon,
.home-support__item:first-child .home-support__icon:after{
  background-color: #6C8CBC;
}
.home-support__item:nth-child(2) .home-support__icon,
.home-support__item:nth-child(2) .home-support__icon:after{
  background-color: #5591F3;
}
.home-support__item:nth-child(3) .home-support__icon,
.home-support__item:nth-child(3) .home-support__icon:after{
  background-color: #36A3F6;
}
.home-support__icon span{
  display: block;
}
.home-support__title{
  color: #1a1a1a;
  font-weight: bold;
  text-align: center;
}
.home-support__title02{
  color: #1a1a1a;
  font-weight: 500;
  position: relative;
}
.home-support__title02:before{
  content: "";
  background-color: #CBDEF4;
  height: 1px;
  position: absolute;
  inset:0;
  margin: auto;
}
.home-support__title02Item{
  background-color: #EEF5FC;
  position: relative;
}
.home-support__listImage{
  display: flex;
  justify-content: space-between;
}
.home-support__list li{
  font-size: 1.4rem;
  padding-left: 1em;
  position: relative;
}
.home-support__list li:before{
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}

/* PC */
@media print,only screen and (min-width: 768px){
  .home-support{
    max-width: 120rem;
    padding: 0 3rem;
    margin: 0 auto 14rem auto;	
    box-sizing: content-box;
  }
  .home-support__heading{
    text-align: center;
  }
  .home-support__heading01{
    font-size: 2rem;
    margin-bottom: 0.5rem;
  }
  .home-support__heading02{
    font-size: 3.6rem;
    margin-bottom: 2rem;
  }
  .home-support__text{
    font-size: 1.6rem;
    line-height: 1.875;
    margin-bottom: 5.8rem;
  }
  .home-support__items{
    display: flex;
    justify-content: space-between;
    gap:0 2.76rem;
    margin-bottom: 5.6rem;
  }
  .home-support__item{
    width: calc( ( 100% / 3 ) - 1.8333rem );
    padding: 3.2rem 2.3rem 2.2rem 2.3rem;
  }
  .home-support__item:after{
    width: 1.2rem;
    height: 2.2rem;
    background: url("../images/home/support-arrow.svg") center center no-repeat;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto 0;
    right: -2rem;
  }
  .home-support__icon{
    top: -3.1rem;
    left: 0.8rem;
  }
  .home-support__title{
    font-size: 2rem;
    margin-bottom: 1.3rem;
  }
  .home-support__title02{
    font-size: 1.2rem;
    margin-bottom: 0.6rem;
  }
  .home-support__title02Item{
    padding-right: 1.2rem;
  }
  .home-support__list{
    width: 74%;
  }
  .home-support__list li{
    line-height: 1.71;
  }
  .home-support__image{
    width: 21.49%;
  } 
}

@media (min-width: 768px) and (max-width: 1170px) {  
  .home-support__icon{
    width: 6.2rem;
    height: 6.2rem;
  }
}

/* SP */
@media screen and (max-width: 767px){
  .home-support{
    margin: 0 2rem 5.4rem 2rem;
  }
  .home-support__heading01{
    font-size: 1.6rem;
    margin-bottom: 0.5rem;
  }
  .home-support__heading02{
    font-size: 2.8rem;
    margin-bottom: 1.4rem;
  }
  .home-support__text{
    font-size: 1.4rem;
    line-height: 1.857;
    margin-bottom: 4.4rem;
  }
  .home-support__item{
    padding: 2.4rem 1.6rem 1.6rem 1.6rem;
    margin-bottom: 3.5rem;
  }
  .home-support__item:last-child{
    margin-bottom: 2rem;
  }
  .home-support__item:after{
    width: 1.2rem;
    height: 2.2rem;
    content: "";
    background: url("../images/home/support-arrow.svg") center center no-repeat;
    background-size: 100% auto;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -2.9rem;
    margin: 0 auto;
    transform: rotate(90deg);
  }
  .home-support__icon{
    top: -2.8rem;
    left: 0.8rem;
  }
  .home-support__title{
    font-size: 1.6rem;
    margin-bottom: 1rem;
  }
  .home-support__title02{
    font-size: 1rem;
    margin-bottom: 0.6rem;
  }
  .home-support__title02Item{
    padding-right: 1.2rem;
  }
  .home-support__list{
    width: calc( 100% - 8rem );
  }
  .home-support__list li{
    line-height: 1.57;
  }
  .home-support__image{
    width: 7.2rem;
  }	
}

/* よくあるご質問
--------------------------------------------------*/
.home-faq__heading{
  color: #1a1a1a;
  font-weight: bold;
  text-align: center;
}
.home-faq__item{
  border: 1px #CBDEF4 solid;
  border-radius: 0.4rem;
  transition: all .3s ease;
}
.home-faq__item:last-child{
  margin-bottom: 0;
}
.home-faq__q{
  position: relative;
  color: #1a1a1a;
  font-weight: 500;
  cursor: pointer;
}
.home-faq__a{
  display: none;
}
.home-faq__button{
  width: 3.2rem;
  height: 3.2rem;
  background-color: #D0E7FF;
  border-radius: 50%;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  transition: background-color .3s ease;
}
.home-faq__button:before,
.home-faq__button:after{
  content: "";
  width: 1.2rem;
  height: 1px;
  background-color: #005EEA;
  position: absolute;
  inset:0;
  margin: auto;
  display: block;
  transition: all .3s ease;
}
.home-faq__button:after{
  transform: rotate(-90deg);
}
.-open .home-faq__button:after{
  transform: rotate(0);
}
.home-faq__item:hover{
  border: 1px #005EEA solid;
  box-shadow: 0 2.6rem 4rem -2.8rem rgba(0, 23, 62, 0.2);
}
.home-faq__item.-open{
  border: 1px #005EEA solid;
}
.home-faq__item:hover .home-faq__button,
.-open .home-faq__button{
  background-color: #005EEA;
}
.home-faq__item:hover .home-faq__button:before,
.home-faq__item:hover .home-faq__button:after,
.-open .home-faq__button:before,
.-open .home-faq__button:after{
  background-color: #fff;
}

/* PC */
@media print,only screen and (min-width: 768px){   
  .home-faq{
    max-width: 120rem;
    padding: 0 3rem;
    margin: 0 auto 14.4rem auto;	
    box-sizing: content-box;
  }
  .home-faq__heading{
    font-size: 3.6rem;
    margin-bottom: 5.6rem;
  }
  .home-faq__items{
    margin-bottom: 5.6rem;
  }
  .home-faq__item{
    border-radius: 0.4rem;
    margin-bottom: 1.6rem;
    transition: all .3s ease;
  }
  .home-faq__q{
    font-size: 1.8rem;
    padding: 2.4rem 7rem 2.4rem 3.2rem;
  }
  .home-faq__a{
    font-size: 1.4rem;
    line-height: 1.714;
    padding: 0.8rem 7rem 2.4rem 3.2rem;
  }
  .home-faq__button{
    right: 2.4rem;
  }
  .home-faq__item:hover{
    border: 1px #005EEA solid;
    box-shadow: 0 2.6rem 4rem -2.8rem rgba(0, 23, 62, 0.2);
  }
}

/* SP */
@media screen and (max-width: 767px){	  
  .home-faq{
    margin: 0 2rem 5.4rem 2rem;
  }
  .home-faq__heading{
    font-size: 2.6rem;
    margin-bottom: 2rem;
  }
  .home-faq__items{
    margin-bottom: 2rem;
  }
  .home-faq__item{
    margin-bottom: 1.6rem;
  }
  .home-faq__q{
    font-size: 1.4rem;
    padding: 1.6rem 5.5rem 1.6rem 1.6rem;
  }
  .home-faq__a{
    font-size: 1.4rem;
    line-height: 1.571;
    padding: 0 1.6rem 1.6rem 1.6rem;
  }
  .home-faq__button{
    right: 1.6rem;
  }
}

/* 人材戦略のあらゆる局面を支えるシステムラインナップ
--------------------------------------------------*/
.home-system img{
  width: 100%;
}
.home-system{
  background-color: #EEF5FC;
}
.home-system__heading02{
  color: #1a1a1a;
  font-weight: 500;
}
.home-system__item a{
  position: relative;
}
.home-system__itemIn{
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #fff;
  box-shadow: 0 2.6rem 4rem -1.2rem rgba(0, 23, 62, 0.1);
  border-radius: 0.4rem;
  display: flex;
  justify-content: space-between;
}
.home-system__itemIn:after{
  content: "";
  background-color: #005EEA;
  border-radius: 50%;
  position: absolute;
  right: 0.8rem;
  bottom: 0.8rem;
  display: block;
}
.home-system__item:first-child .home-system__title{
  background-color: #22B6AA;
}
.home-system__item:nth-child(2) .home-system__title{
  background-color: #0068AA;
}
.home-system__item:nth-child(3) .home-system__title{
  background-color: #FFB200;
}
.home-system__title{
  color: #fff;
  font-weight: 500;
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 1.6rem 2rem 0 1.6rem;
  z-index: 5;
}
.home-system__texts{
  position: relative;
  box-sizing: border-box;
}
.home-system__texts:before{
  content: "";
  background-color: #CBDEF4;
  width: 1px;
  position: absolute;
  left: 0;
  display: block;
}
.home-system__text01{
  font-weight: bold;
}
.home-system__item:first-child .home-system__text01{
  color: #22B6AA;
}
.home-system__item:nth-child(2) .home-system__text01{
  color: #0068AA;
}
.home-system__item:nth-child(3) .home-system__text01{
  color: #FFB200;
}
.home-system__works{
  background-color: #5E6975;
  text-align: center;
  color: rgba(255,255,255,0.4);
  font-size: 1.6rem;
  padding: 6.6rem 3rem;
}

/* PC */
@media print,only screen and (min-width: 768px){  
  .home-system{
    padding: 7.2rem 3rem;
  }
  .home-system__inner{
    max-width: 120rem;
    margin: 0 auto;	
  }
  .home-system__heading{
    margin-bottom: 3.2rem;
    gap:0 2.4rem;
    display: flex;
    justify-content: center;
  }
  .home-system__heading01{
    width: 27.8rem;
  }
  .home-system__heading02{
    font-size: 2rem;
  }
  .home-system__items{
    display: flex;
    justify-content: space-between;
    gap:0 1.6rem;
    margin-bottom: 4.8rem;
  }
  .home-system__item{
    width: calc( ( 100% / 3 ) - 1.0666rem );
    display: flex;
  }
  .home-system__item a{
    display: flex;
  }
  .home-system__itemIn{
    overflow: hidden;
    position: relative;
    padding: 2.6rem 2rem 2rem 2rem;
  }
  .home-system__item a:hover{
    text-decoration: none;
  }
  .home-system__itemIn:after{
    width: 0.4rem;
    height: 0.4rem;
    transition: all .3s ease;
    transform: scale(1);
    transform-origin: left top;
  }
  .home-system__itemIn:hover:after{
    width: 1.4rem;
    height: 1.4rem;
    transform: scale(3.5);
    right: 0.4rem;
    bottom: 0.4rem;
  }
  .home-system__title{
    height: 2.6rem;
    font-size: 1.2rem;
    top: -1rem;
    left: -0.9rem;
    padding: 0 1.6rem;
  }
  .home-system__image{
    width: 23.42%;
  }
  .home-system__texts{
    width: 70.6%;
    padding-left: 6.4%;
  }
  .home-system__texts:before{
    top: 1rem;
    bottom: 0.1rem;
  }
  .home-system__text01{
    font-size: 1.8rem;
  }
  .home-system__text02{
    font-size: 1rem;
    line-height: 1.6;
  }
}

/* SP */
@media screen and (max-width: 767px){ 
  .home-system{
    padding: 5.6rem 2rem;
  }
  .home-system__heading{
    margin-bottom: 3.2rem;
  }
  .home-system__heading01{
    width: 22.2rem;
    margin-bottom: 1.4rem;
  }
  .home-system__heading02{
    font-size: 1.6rem;
    line-height: 1.625;
  }
  .home-system__item{
    margin-bottom: 2.4rem;
  }
  .home-system__itemIn{
    padding: 2.5rem 1.6rem;
  }
  .home-system__item:last-child{
    margin-bottom: 2rem;
  }
  .home-system__itemIn:after{
    width: 0.6rem;
    height: 0.6rem;
  }
  .home-system__title{
    height: 2.6rem;
    font-size: 1.2rem;
    top: -1rem;
    left: -1rem;
    padding: 0 1rem;
  }
  .home-system__image{
    width: 8.2rem;
  }
  .home-system__texts{
    width: 20.5rem;
    padding-left: 1.6rem;
  }
  .home-system__texts:before{
    top: 0.8rem;
    bottom: 0.1rem;
  }
  .home-system__text01{
    font-size: 1.8rem;
  }
  .home-system__text02{
    font-size: 1rem;
    line-height: 1.6;
  }	
}

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

機能一覧

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

/* ページナビ
--------------------------------------------------*/
.m-pagenavi__title{
  color: #1a1a1a;
  font-weight: 500;
  text-align: center;
}
.m-pagenavi__item{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.m-pagenavi__itemInIn{
  background: url("../images/shared/arrow-down.svg") right 1.8rem center no-repeat;
  background-size: 0.9rem auto;
  border: 1px #005EEA solid;
  border-radius: 0.4rem;
  color: #005EEA;
  font-weight: 500;
  text-align: center;
  display: block;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .m-pagenavi{
    margin-bottom: 14.4rem;
  }
  .m-pagenavi__title{
    font-size: 1.8rem;
    margin-bottom: 1.6rem;
  }
  .m-pagenavi__item{
    gap:1.6rem;
  }
  .m-pagenavi__itemIn{
    width: 19.2rem;
  }
  .m-pagenavi__itemInIn{
    font-size: 1.6rem;
    padding: 1rem 3rem;
    transition: all .3s ease;
  }
  .m-pagenavi__itemInIn:hover{
    border: 1px #EEF5FC solid;
    background-color: #EEF5FC;
    text-decoration: none;
  }
}

/* SP */
@media screen and (max-width: 767px){	
  .m-pagenavi{
    margin-bottom: 9rem;
  }
  .m-pagenavi__title{
    font-size: 1.6rem;
    margin-bottom: 1.2rem;
  }
  .m-pagenavi__item{
    gap:1.2rem;
  }
  .m-pagenavi__itemIn{
    width: calc( 50% - 0.6rem );
  }
  .m-pagenavi__itemInIn{
    font-size: 1.3rem;
    padding: 0.9rem 3rem;
  }
}

/* 機能一覧
--------------------------------------------------*/
.l-content .function-content:last-child{
  margin-bottom: 0;
}
.function-title{
  color: #1a1a1a;
  font-weight: bold;
}
.function-link__item{
  color: #005EEA;
  font-weight: 500;
  position: relative;
}
.function-link__item:after{
  background: url("../images/shared/next.svg") center center no-repeat;
  background-size: 0.9rem auto;
  background-color: #fff;
  content: "";
  border: 1px solid #005EEA;
  border-radius: 0.4rem;
  transition: all .3s ease;
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto 0;
}
.function-link__item:hover:after{
  background-color: #EEF5FC;
  border: 1px solid #EEF5FC;
}
.function-items{
  display: flex;
  flex-wrap: wrap;
}
.function-item{
  display: flex;
}
.function-item__in{
  width: 100%;
  background-color: #EEF5FC;
  border: 1px #EEF5FC solid;
  border-radius: 0.4rem;
  color: #1a1a1a;
  display: block;
  position: relative;
  display: flex;
  flex-direction: column;
}
.function-item__in:hover{
  border: 1px #005EEA solid;
  color: #005EEA;
  text-decoration: none;
  box-shadow: 0px 26px 40px -28px rgba(0, 23, 62, 0.2);
}
.function-item__in:after{
  width: 0.4rem;
  height: 0.4rem;
  content: "";
  background-color: #005EEA;
  border-radius: 50%;
  position: absolute;
  right: 0.8rem;
  bottom: 0.8rem;
  display: block;
  transition: all .3s ease;
  transform: scale(1);
  transform-origin: left top;
}
.function-item__text{
  font-weight: 500;
  text-align: center;
}
.function-item__image{
  background-color: #fff;
  border-radius: 0.4rem;
  text-align: center;
  margin-top: auto;
}
.function-item__image img{
  margin: 0 auto;
}

/* PC */
@media print,only screen and (min-width: 768px){   
  .function-content{
    margin-bottom: 14.4rem;
  }
  .function-title{
    font-size: 3.6rem;
    margin-bottom: 2.4rem;
  }
  .function-textLink{
    display: flex;
    justify-content: space-between;
    margin-bottom: 2.4rem;
  }
  .function-text{
    font-size: 1.6rem;
  }
  .function-link__item{
    font-size: 1.6rem;
    padding-right: 7.2rem;
  }
  .function-link__item:after{
    background-size: 0.9rem auto;
    width: 5.6rem;
    height: 3.2rem;
    transition: all .3s ease;
  }
  .function-link__item:hover{
    text-decoration: none;
  }
  .function-link__item:hover:after{
    background-color: #EEF5FC;
    border: 1px solid #EEF5FC;
  }
  .function-items{
    gap:1.6rem;
  }
  .function-item{
    width: calc( 20% - 1.28rem );
  }
  .function-item__in{
    padding: 2.1rem 2.1rem 2rem 2.1rem;
    transition: all .3s ease;
    overflow: hidden;
  }
  .function-item__in:hover{
    border: 1px #005EEA solid;
    color: #005EEA;
    text-decoration: none;
    box-shadow: 0px 26px 40px -28px rgba(0, 23, 62, 0.2);
  }
  .function-item__in:before{
    width: 0.7rem;
    height: 0.7rem;
    content: "";
    background: url("../images/function/arrow.svg") center center no-repeat;
    background-size: 100% auto;
    position: absolute;
    right: 0.7rem;
    bottom: 0.7rem;
    display: block;
    transition: opacity .3s ease;
    z-index: 3;
    opacity: 0;
  }
  .function-item__in:hover:before{
    opacity: 1;
  }
  .function-item__in:hover:after{
    width: 5.6rem;
    height: 5.6rem;
    right: -2.8rem;
    bottom: -2.8rem;
  }
  .function-item__text{
    font-size: 1.6rem;
    margin-bottom: 1.2rem;
  }
  .function-item__image{
    padding: 1.6rem;
  }
  .function-item__image img{
    width: 8rem;
  }
}

/* SP */
@media screen and (max-width: 767px){	  
  .function-content{
    margin-bottom: 8rem;
  }
  .function-title{
    font-size: 2.8rem;
    margin-bottom: 1rem;
  }
  .function-textLink{
    margin-bottom: 2rem;
  }
  .function-text{
    font-size: 1.4rem;
    margin-bottom: 1rem;
  }
  .function-link{
    text-align: right;
  }
  .function-link__item{
    font-size: 1.4rem;
    padding-right: 5.5rem;
  }
  .function-link__item:after{
    background-size: 0.7rem auto;
    width: 4.5rem;
    height: 2.3rem;
  }
  .function-items{
    gap:1.2rem;
  }
  .function-item{
    width: calc( 50% - 0.6rem );
  }
  .function-item__in{
    padding: 1rem;
    overflow: hidden;
  }
  .function-item__in:after{
    width: 0.3rem;
    height: 0.3rem;
    right: 0.5rem;
    bottom: 0.5rem;
  }
  .function-item__text{
    font-size: 1.3rem;
    line-height: 1.4;
    margin-bottom: 1rem;
  }
  .function-item__image{
    padding: 1.4rem;
  }
  .function-item__image img{
    width: 7rem;
  }
}

/* モーダル
--------------------------------------------------*/
body.modal-open{
  overflow: hidden;
}
.function-modal img{
  width: 100%;
}
.function-modal{
  background-color: rgba(0,0,0,0.5);
  position: fixed;
  inset:0;
  z-index: 100;
  display:none;
}
.function-modal__inner{
  height: fit-content;
  background-color: #fff;
  border-radius: 0.8rem;
  position: absolute;
  inset:0;
  margin: auto;
  border: 1px #333 solid;
  z-index: 50;
}
.function-modal__close{
  position: absolute;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
}
.function-modal__title{
  color: #1a1a1a;
  font-weight: bold;
  text-align: center;
}
.function-modal__text{
  text-align: center;
}
.function-slideItem{
  overflow: hidden;
  border: 10px #333 solid;
}
.function-slide .slick-prev{
  background: url("../images/shared/prev.svg") center center no-repeat;
}
.function-slide .slick-next{
  background: url("../images/shared/next.svg") center center no-repeat;
}
.function-slide .slick-arrow{
  background-color: #fff;
  border: 1px #005EEA solid;
  text-indent: -9999px;
  transition: all .3s ease;
  cursor: pointer;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
}
.function-slide .slick-dots{
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  display: flex;
  justify-content: center;
}
.function-slide .slick-dots li{
  background-color: #CBDEF4;
  border-radius: 50%;
  text-indent: -9999px;
  cursor: pointer;
}
.function-slide .slick-dots li.slick-active{
  background-color: #005EEA;
}
.function-modal__button{
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 5;
}
.function-modal__buttonItem{
  background: linear-gradient(90deg, #005EEA 0%, #00C2C5 100%);
  color: #fff;
  font-weight: 500;
  border-radius: 0.4rem;
  position: relative;
  display: block;
}

/* PC */
@media print,only screen and (min-width: 768px){
  .function-modal__inner{
    width: 85%;
    max-width: 100rem;
    padding: 4.8rem;
  }
  .function-modal__close{
    width: 9.6rem;
    height: 6.3rem;
    top: 1.2rem;
    right: 1.2rem;
  }
  .function-modal__close img{
    width: 5.6rem;
  }
  .function-modal__title{
    font-size: 2.2rem;
    margin-bottom: 1.2rem;
  }
  .function-modal__text{
    font-size: 1.4rem;
    line-height: 1.714;
    margin-bottom: 2.4rem;
  }
  .function-slide{
    max-width: 52.4rem;
    margin: 0 auto 4rem auto;
  }
  .function-slideItem{
    width: 73%;
    margin: 0 1rem;
    border: 3px #1a1a1a solid;
    border-radius: 1.2rem;
  }
  .function-slide .slick-prev{
    left: -9.5rem;
  }
  .function-slide .slick-next{
    right: -9.5rem;
  }
  .function-slide .slick-arrow{
    width: 4rem;
    height: 4rem;
    background-size: 0.9rem auto;
  }
  .function-slide .slick-arrow:hover{
    background-color: #EEF5FC;
    border: 1px #EEF5FC solid;
  }
  .function-slide .slick-dots{
    bottom: -2.5rem;
    gap: 0 1.5rem;
  }
  .function-slide .slick-dots li{
    width: 0.8rem;
    height: 0.8rem;
  }
  .function-modal__button{
    max-width: 36rem;
  }
  .function-modal__buttonItem{
    font-size: 1.6rem;
    padding: 1.5rem 1rem;
    transition: all .3s ease;
  }
  .function-modal__buttonItemIn{
    position: relative;
  }
  .function-modal__buttonItem:before{
    content: "";
    background: #D0E7FF;
    position: absolute;
    inset:0;
    display: block;
    opacity: 0;
    transition: opacity .3s ease;  
  }
  .function-modal__buttonItem:hover{
    color: #005EEA;
    text-decoration: none;
  }
  .function-modal__buttonItem:hover:before{
    opacity: 1;
  }
}

/* SP */
@media screen and (max-width: 767px){	
  .function-modal__inner{
    width: 85%;
    padding: 2rem;
  }
  .function-modal__close{
    width: 6rem;
    height: 4rem;
    top: 0.5rem;
    right: 0.5rem;
  }
  .function-modal__close img{
    width: 4rem;
  }
  .function-modal__title{
    font-size: 1.7rem;
    margin-bottom: 1rem;
  }
  .function-modal__text{
    font-size: 1.2rem;
    line-height: 1.6;
    margin-bottom: 1.5rem;
  }
  .function-slide{
    width: 21rem;
    margin: 0 auto 5rem auto;
  }
  .function-slideItem{
    border: 2px #1a1a1a solid;
    border-radius: 1.2rem;
    margin: 0 0.5rem;
  }
  .function-slide .slick-prev{
    left: -4rem;
  }
  .function-slide .slick-next{
    right: -4rem;
  }
  .function-slide .slick-arrow{
    width: 3rem;
    height: 3rem;
    background-size: 0.7rem auto;
  }
  .function-slide .slick-dots{
    bottom: -2.5rem;
    gap: 0 1.5rem;
  }
  .function-slide .slick-dots li{
    width: 0.8rem;
    height: 0.8rem;
  }
  .function-modal__buttonItem{
    font-size: 1.4rem;
    padding: 1rem 1rem;
  }
}

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

デモ依頼・お問い合わせ

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

/* intro
--------------------------------------------------*/
.contact-list__item{
  position: relative;
}
.contact-list__item:before{
  content: "";
  position: absolute;
  left: 0;
  display: block;
  background: url("../images/shared/list-arrow.svg") center center no-repeat;
  background-size: 100% auto;
}
.contact-note{
  text-align: center;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .contact-intro{
    max-width: 79.2rem;
    margin: -7.2rem auto 7.2rem auto;
  }
  .contact-introtext{
    font-size: 1.6rem;
    line-height: 1.875;
    margin-bottom: 2.4rem;
  }
  .contact-list{
    margin-bottom: 7.2rem;
  }
  .contact-list__item{
    font-size: 1.6rem;
    margin-bottom: 0.7rem;
    padding-left: 3.2rem;
  }
  .contact-list__item:before{
    width: 2.4rem;
    height: 2.4rem;
    top: 0.2em;
  }
  .contact-note{
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

/* SP */
@media screen and (max-width: 767px){	
  .contact-intro{
  }
  .contact-introtext{
    font-size: 1.4rem;
    line-height: 1.8;
    margin-bottom: 2rem;
  }
  .contact-list{
    margin-bottom: 5rem;
  }
  .contact-list__item{
    font-size: 1.4rem;
    margin-bottom: 0.5rem;
    padding-left: 2rem;
  }
  .contact-list__item:before{
    width: 1.6rem;
    height: 1.6rem;
    top: 0.2em;
  }
  .contact-note{
    font-size: 1.4rem;
    line-height: 1.8;
  }
}

/* form
--------------------------------------------------*/
.contact-form{
  box-shadow: 0px 26px 40px -12px rgba(0, 23, 62, 0.1);
  border-radius: 0.8rem;
  overflow: hidden;
}

/* PC */
@media print,only screen and (min-width: 768px){ 
  .contact-form{
    margin-bottom: 7.2rem;
  }
}

/* SP */
@media screen and (max-width: 767px){	
  .contact-form{
    margin-bottom: 7.2rem;
  }
}

/* finish
--------------------------------------------------*/
.finish-text01{
  color: #1a1a1a;
  font-weight: 500;
  text-align: center;
}
.finish-box{
  background-color: #EEF5FC;
  text-align: center;
}
.finish-box__text02{
  color: #005EEA;
  font-family: "Inter", sans-serif;
  font-weight: 600;
  line-height: 1;
}
.finish-content .m-button{
  text-align: center;
} 
.l-content.-finish{
  position: relative;
}

/* PC */
@media print,only screen and (min-width: 768px){
  .l-content.-finish:before{
    content: "";
    display: block;
    position: absolute;
    width: 178.6rem;
    height: 41.3rem;
    background: url("../images/contact/bg.svg") center center no-repeat;
    background-size: 100% auto;
    left: 56%;
    transform: translateX(-50%);
    top: -7.5rem;
    margin: 0 auto;
  }
  .finish-image{
    width: 24.4rem;
    margin: 14.4rem auto 5.6rem auto;
  }
  .finish-text01{
    font-size: 2rem;
    margin-bottom: 3.2rem;
  }
  .finish-text02{
    font-size: 1.6rem;
    line-height: 1.875;
    margin-bottom: 3.2rem;
  }
  .finish-box{
    padding: 3.2rem;
    margin-bottom: 5.6rem;
  }
  .finish-box__text01{
    font-size: 1.4rem;
    margin-bottom: 1rem;
  }
  .finish-box__text02{
    font-size: 2.6rem;
    margin-bottom: 0.4rem;
  }
  .finish-box__text03{
    font-size: 1.4rem;
  }
  .finish-content .m-button{
    width: 33.6rem;
  }
}

/* SP */
@media screen and (max-width: 767px){	
  .l-content.-finish{
    background: url("../images/contact/bg.svg") calc( 50% + 5rem ) -3rem no-repeat;
    background-size: 54rem auto;
    margin-top: -7rem;
  }
  .finish-image{
    width: 15rem;
    margin: 10rem auto 4rem auto;
  }
  .finish-text01{
    font-size: 1.8rem;
    margin-bottom: 2.5rem;
  }
  .finish-text02{
    font-size: 1.4rem;
    line-height: 1.8;
    margin-bottom: 2.8rem;
  }
  .finish-box{
    padding: 2rem;
    margin-bottom: 4rem;
  }
  .finish-box__text01{
    font-size: 1.4rem;
    margin-bottom: 1rem;
  }
  .finish-box__text02{
    font-size: 2.2rem;
    margin-bottom: 0.4rem;
  }
  .finish-box__text03{
    font-size: 1.4rem;
  }
  .finish-content .m-button{
    width: 33.6rem;
  }
}

