@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#container {
	padding-top: 80px;
}
.mainVisual {
	min-height: 680px;
	position: relative;
}
.mainVisual .infoBox {
	padding: 14px 22px 0 0;
	position: relative;
	width: 1280px;
	margin: 0 auto;
	text-align: center;
}
.mainVisual .infoBox .pho {
	position: absolute;
}
.mainVisual .infoBox .pho01 {
	top: 83px;
	left: 72px;
}
.mainVisual .infoBox .pho02 {
	top: 35px;
	right: 180px;
}
.mainVisual .infoBox .pho03 {
	top: 286px;
	right: 115px;
}
.mainVisual .btn {
	position: absolute;
	left: 151px;
	bottom: 43px;
	-webkit-animation: floatV 2s ease-in-out infinite alternate;
	animation: floatV 2s ease-in-out infinite alternate;
	z-index: 10;
}
@-webkit-keyframes floatV {
  0% {
    -webkit-transform: translate3d(0, -1em, 0);
            transform: translate3d(0, -1em, 0);
  }
  50% {
    -webkit-transform: translate3d(0, 1em, 0);
            transform: translate3d(0, 1em, 0);
  }
  100% {
    -webkit-transform: translate3d(0, -1em, 0);
            transform: translate3d(0, -1em, 0);
  }
}
@keyframes floatV {
  0% {
    -webkit-transform: translate3d(0, -1em, 0);
            transform: translate3d(0, -1em, 0);
  }
  50% {
    -webkit-transform: translate3d(0, 1em, 0);
            transform: translate3d(0, 1em, 0);
  }
  100% {
    -webkit-transform: translate3d(0, -1em, 0);
            transform: translate3d(0, -1em, 0);
  }
}
.mainVisual .btn a:hover {
	opacity: 0.7;
}
#main .solution {
	padding-bottom: 90px;
	background: #E9F4F4;
}
#main .solution h2 {
	margin-bottom: 134px;
	position: relative;
	top: -37px;
	text-align: center;
}
#main .solution h2:before {
	position: absolute;
	left: 50%;
	bottom: 106px;
	background: #4AA199;
	width: 1px;
	height: 81px;
	content: "";
	animation: pathmove 1.4s ease-in-out infinite;
	opacity:0;
}
@keyframes pathmove{
	0%{
		height:0;
		top: 100%;
		opacity: 0;
	}
	30%{
		height: 81px;
		opacity: 1;
	}
	100%{
		height: 0;
		top: calc(100% + 130px);
		opacity: 0;
	}
}
#main .solution .topBox {
	margin: 0 -5px 60px 0;
}
#main .solution .topBox .subBox {
	margin-left: -5px;
	width: 420px;
}
#main .solution .topBox .title {
	margin: -20px 0 16px;
	padding-bottom: 7px;
	align-items: center;
	line-height: 90px;
	background: url("../img/index/line01.png") no-repeat left bottom;
	background-size: 80px auto; 
}
#main .solution .topBox .txt {
	font-size: 1.8rem;
	line-height: 1.8;
	letter-spacing: 0.05em;
}
#main .solution .topBox .txt .btm {
	margin-top: 3px;
	display: block;
	font-size: 2.4rem;
	font-weight: 900;
}
#main .solution .topBox .title .lTxt {
	margin: 27px 3px 0 0;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.35;
	letter-spacing: 0.2em;
}
#main .solution .topBox .title .en {
	font-size: 8rem;
	letter-spacing: 0.05em;
}
#main .solution .topBox .title .small {
	margin-left: 3px;
	font-size: 4rem;
	font-weight: 700;
	letter-spacing: 0.15em;
}
#main .solution .topBox .title .infoSpan {
	margin-top: -22px;
	display: block;
	color: #4AA199;
	font-size: 4.8rem;
	font-weight: 700;
	letter-spacing: 0.15em;
}
#main .solution .topBox .ulBox {
	width: 492px;
}
#main .solution .topBox .ulBox li {
	margin-bottom: 20px;
}
#main .solution .topBox .ulBox li a {
	width: 100%;
	font-size: 2.4rem;
	letter-spacing: 0.15em;
	border-radius: 8px;
	background: #fff url("../img/common/icon10.png") no-repeat right 34px center;
	background-size: 17px auto; 
}
#main .solution .whiteBox {
	margin: 0 -5px 60px;
	padding: 38px 58px 39px;
	box-sizing: border-box;
	background: #fff;
	border-radius: 8px;
	box-shadow: 0px 3px 6px rgba(21, 107, 114, 0.1);
}
#main .solution .whiteBox:last-child {
	margin-bottom: 0;
}
#main .solution h3 {
	margin-bottom: 40px;
	color: #4AA199;
	font-size: 3.2rem;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.2em;
}
#main .solution .listUl li {
	margin-right: 17px;
	padding-bottom: 31px;
	width: 266px;
	border: 2px solid #4AA199;
	border-radius: 8px;
}
#main .solution .listUl li:nth-child(3n) {
	margin-right: 0;
}
#main .solution .listUl li .top {
	margin-bottom: 18px;
	padding: 8px 10px 11px; 
	color: #fff;
	position: relative;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.05em;
	background: #4AA199;
}
#main .solution .listUl li .top:before {
	margin-right: -18px;
	position: absolute;
	right: 50%;
	bottom: -8px;
	width: 36px;
	height: 11px;
	background: url("../img/common/icon11.png") no-repeat right center;
	background-size: 36px auto;
	content: "";
}
#main .solution .listUl li .infoBox {
	padding: 0 22px;
}
#main .solution .listUl li .ttl {
	margin-bottom: 19px;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: center;
}
#main .solution .listUl li .imgBox {
	margin: 0 0 8px;
}
#main .solution .listUl li .txtP {
	margin-bottom: 30px;
	line-height: 1.75;
	letter-spacing: 0.05em;
}
#main .solution .listUl li .comLink a {
	width: 160px;
	height: 48px;
	font-size: 1.6rem;
	background-position: right 17px center;
	background-size: 8px auto
}
#main .solution .listUl li .notes {
	margin: 5px 0 -4px;
	padding-left: 1em;
	display: block;
	line-height: 1.7;
	font-size: 1.4rem;
	text-indent: -1em;
}
#main .solution .listUl li .notes:last-child {
	margin-bottom: 0;
}
#main .introduction {
	padding: 60px 0 102px;
	background: #E9F4F4;
}
#main .introduction .content {
	width: 960px;
}
#main .introduction .headLine04 {
	text-align: center;
}
#main .introduction .title {
	margin-bottom: 9px;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.15em;
	text-align: center;
}
#main .introduction .title .blue {
	color: #4AA199;
	font-size: 4rem;
}
#main .introduction .title .num {
	font-size: 6.8rem;
}
#main .introduction .ttl {
	margin-bottom: 74px;
	padding: 7px 10px;
	color: #fff;
	font-size: 1.8rem;
	text-align: center;
	background: #4AA199;
	border-radius: 8px;
	box-sizing: border-box;
	letter-spacing: 0.1em;
}
#main .introduction .stepList {
	margin: 0 -4px 0 0;
}
#main .introduction .stepList > li {
	margin: 0 25px 0 0;
	position: relative;
	padding: 26px 33px 20px;
	width: 304px;
	box-sizing: border-box;
	background: #fff;
	border-radius: 8px;
	box-shadow: 0px 3px 6px rgba(21, 107, 114, 0.1);
}
#main .introduction .stepList > li:nth-child(3n) {
	margin-right: 0;
}
#main .introduction .stepList > li:before {
	margin-top: -29px;
	position: absolute;
	right: -18px;
	top: 50%;
	width: 18px;
	height: 58px;
	background: url("../img/common/icon13.png") no-repeat left top;
	background-size: 18px auto;
	content: "";
}
#main .introduction .stepList > li:last-child:before {
	display: none;
}
#main .introduction .stepList li .step {
	position: absolute;
	top: -32px;
	left: 20px;
}
#main .introduction .stepList li .top {
	margin: 0 -10px 20px;
	font-size: 2.4rem;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.05em;
}
#main .introduction .stepList li .top .small {
	display: block;
	font-size: 1.6rem;
	font-weight: 400;
	margin-top: 5px;
}
#main .introduction .stepList li .pho {
	text-align: center;
	margin-bottom: 18px;
}
#main .introduction .stepList li .tit {
	margin: 0 0 7px;
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
#main .introduction .stepList li .txt {
	margin-bottom: 53px;
	line-height: 1.7;
	letter-spacing: 0.05em;
}
#main .introduction .stepList li .checkList li {
	padding: 0 0 4px 25px;
	letter-spacing: 0.05em;
	background: url("../img/common/icon12.png") no-repeat left top 5px;
	background-size: 15px auto; 
}
#main .introduction .listUl {
	padding-top: 5px;
	margin: 0 -15px 20px 0;
}
#main .introduction .listUl li {
	padding: 0 0 7px 26px;
	position: relative;
	line-height: 1.8;
	letter-spacing: 0.05em;
}
#main .introduction .listUl li .num {
	position: absolute;
	left: -7px;
	top: 8px;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 700;
	width: 22px;
	height: 22px;
	line-height: 21px;
	text-align: center;
	border-radius: 50%;
	background: #4AA199;
}
#main .introduction .listUl li .small {
	display: block;
	font-size: 1.4rem;
	font-weight: 400;
}
#main .introduction .notesList {
	margin: 0 -7px;
}
#main .introduction .notesList li {
	padding-left: 1em;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	text-indent: -1em;
	line-height: 1.7;
}
#main .introduction .topBox {
	margin-bottom: 30px;
	padding-bottom: 56px;
	border-bottom: 1px solid #fff;
}
#main .introduction .topTxt {
	margin-bottom: 39px;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-align: center;
}
#main .introduction .blue {
	color: #4AA199;
	font-weight: 700;
}
#main .introduction .stepUl {
	margin: 0 -7px 40px 0;
}
#main .introduction .stepUl li {
	margin-right: 10px;
	width: 318px;
	cursor: pointer;
	min-height: 80px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-radius: 8px;
	background: url("../img/index/bg01.png") no-repeat center center;
	background-size: 100% auto; 
}
#main .introduction .stepUl li:last-child {
	margin-right: 0;
	width: 304px;
	background: #fff;
}
#main .introduction .stepUl li .stepImg {
	width: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	background: #4AA199;
	border-radius: 8px 0 0 8px;
}
#main .introduction .stepUl li .infoTtl {
	width: calc(100% - 75px);
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
#main .introduction .sliderBox {
	position: relative;
	box-shadow: 0px 3px 6px rgba(21, 107, 114, 0.1);
	background: #fff;
	border-radius: 8px;
}
#main .introduction .sliderBox .slick-arrow {
	margin-top: -33px;
	position: absolute;
	top: 50%;
	left: -20px;
	width: 66px;
	height: 66px;
    cursor: pointer;
	background: url(../img/index/prev.png) no-repeat center / cover;
	border: none;
	font-size: 0;
	z-index: 10;
}
#main .introduction .sliderBox .slick-arrow.slick-disabled {
	display: none !important;
}
#main .introduction .sliderBox .slick-next {
	left: auto;
	right: -34px;
	background-image: url(../img/index/next.png);
}
#main .introduction .infoBox {
	box-sizing: border-box;
	padding: 42px 58px 42px 58px;
}
#main .introduction .infoBox .photoBox {
	float: left;
	width: 340px;
	text-align: center;
}
#main .introduction .infoBox .photoBox03 {
	padding-top: 58px;
}
#main .introduction .infoBox .textBox {
	width: 492px;
	float: right;
}
#main .introduction .infoBox .topStep {
	margin-bottom: 40px;
	padding: 0 0 26px 8px;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	border-bottom: 1px solid #D3D3D3;
}
#main .introduction .infoBox .topStep img {
	display: inline-block;
	vertical-align: middle;
	margin-right: 26px;
}
#main .introduction .infoBox .ttl01 {
	margin-bottom: 8px;
	padding-left: 30px;
	font-weight: 700;
	font-size: 1.8rem;
	letter-spacing: 0.05em;
	background: url("../img/common/icon14.png") no-repeat left top 7px;
	background-size: 20px auto; 
}
#main .introduction .infoBox .txtP,
#main .introduction .infoBox .txtList {
	margin-bottom: 40px;
}
#main .introduction .infoBox .txtP:last-child {
	margin-bottom: 0;
}
#main .introduction .infoBox .txtList:last-child {
	margin-bottom: 0;
}
#main .introduction .infoBox .txtList li {
	padding: 0 0 4px 1em;
	text-indent: -1em;
	letter-spacing: 0.05em;
}
#main .introduction .infoBox .txtList li:last-child {
	padding-bottom: 0;
}
#main .plan {
	padding: 70px 0 77px;
	background: #FAFAFA;
}
#main .plan .content {
	width: 960px;
}
#main .plan .headLine04 {
	margin-bottom: 45px;
}
#main .plan .imgList {
	margin: 0 -56px 56px;
}
#main .plan .imgList li {
	padding: 0 56px;
}
#main .plan .tabUl {
	padding: 0 0 9px 6px;
	border-bottom: 2px solid #959595;
}
#main .plan .tabUl li {
	margin-right: 18px;
}
#main .plan .tabUl li:last-child {
	margin-right: 0;
}
#main .plan .tabUl li a {
	color: #fff;
	font-size: 2rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	width: 304px;
	height: 60px;
	text-align: center;
	justify-content: center;
	background: #959595;
	letter-spacing: 0.15em;
}
#main .plan .tabUl .li02.on a {
	background: #2AB4F2;
}
#main .plan .tabUl .li03.on a {
	background: #FFA91F;
}
#main .plan .tabUl li a:hover {
	opacity: 0.7;
}
#main .plan .tabUl .on a {
	margin-bottom: -10px;
	height: 70px;
	font-size: 2.8rem;
	background: #4AA199;
}
#main .plan .tabBox .listUl > li {
	padding: 20px 18px 40px;
	width: 33%;
	box-sizing: border-box;
    background: #fff;
	border-right: 2px solid #D3D3D3;
}
#main .plan .tabBox03 .listUl > li {
	padding-bottom: 20px;
}
#main .plan .tabBox .listUl > li:nth-child(2) {
	width: 34.2%;
}
#main .plan .tabBox .listUl > li:last-child {
	width: 32.8%;
	border: none;
}
#main .plan .tabBox .listUl li .topEn {
	margin-bottom: 27px;
	color: #4AA199;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.15em;
	text-align: center;
}
#main .plan .tabBox02 .listUl li .topEn {
	color: #2AB4F2;
}
#main .plan .tabBox03 .listUl li .topEn {
	color: #FFA91F;
}
#main .plan .tabBox .listUl li .price {
	margin-bottom: 22px;
	font-size: 2.2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: center;
}
#main .plan .tabBox .listUl li .price01 {
	margin-top: -12px;
}
#main .plan .tabBox .listUl li .price .num {
	font-size: 5.4rem;
	font-weight: 900;
}
#main .plan .tabBox .listUl li .price .num01 {
	font-size: 7.8rem;
}
#main .plan .tabBox .listUl li .price img {
	display: inline-block;
	vertical-align: middle;
	margin: -49px 20px 0 0;
}
#main .plan .tabBox .listUl li .txtP {
	letter-spacing: 0.05em;
	line-height: 1.75;
}
#main .plan .tabBox .listUl li .txtList {
	padding-top: 5px;
}
#main .plan .tabBox .listUl li .txtList01 {
	margin: 0 26px;
}
#main .plan .tabBox .listUl li .txtList li {
	font-size: 1.4rem;
	padding-left: 1em;
	text-indent: -1em;
	line-height: 1.7;
	letter-spacing: 0.05em;
}
#main .plan .tabBox .listUl li .txtP02 {
	margin: 0 26px;
}
#main .plan .tabBox .listUl li .txtP02 .notes {
	display: block;
	margin: 4px -20px 0 1em;
	text-indent: -1em;
}
#main .plan .tabBox .listUl li .txtP .fw {
	font-weight: 700;
}
#main .plan .tabBox .listUl li .comLink a {
	width: 260px;
	height: 60px;
	color: #fff;
	font-size: 2rem;
	letter-spacing: 0.2em;
	background: #4AA199 url("../img/common/icon07_over.png") no-repeat right 26px center;
	background-size: 8px auto;
}
#main .plan .tabBox02 .listUl li .comLink a {
	border-color: #2AB4F2;
	background: #2AB4F2 url("../img/common/icon07_over.png") no-repeat right 26px center;
	background-size: 8px auto;
}
#main .plan .tabBox03 .listUl li .comLink a {
	border-color: #FFA91F;
	background: #FFA91F url("../img/common/icon07_over.png") no-repeat right 26px center;
	background-size: 8px auto;
}
#main .plan .tabBox .listUl02 > li {
	padding-bottom: 20px;
	width: 50% !important;
}
#main .plan .tabBox .comLinkBox {
	padding-bottom: 0;
}
#main .plan .tabBox .comLinkBox a {
	letter-spacing: 0.2em;
}
#main .plan .tabBox02 .comLinkBox a {
	color: #2AB4F2;
	border-color: #2AB4F2;
	background: #fff url("../img/common/icon16.png") no-repeat right 26px center;
	background-size: 8px auto;
}
#main .plan .tabBox03 .comLinkBox a {
	color: #FFA91F;
	border-color: #FFA91F;
	background: #fff url("../img/common/icon17.png") no-repeat right 26px center;
	background-size: 8px auto;
}
#main li.list-harf {
    width: 50% !important;
}
#main li.list-harf .txtP {
    margin: 0 26px !important;
}
#main .support {
	padding: 88px 0 80px;
}
#main .support .content {
	width: 964px;
}
#main .support .headLine04 {
	margin-bottom: 40px;
}
#main .support .checkBox {
	margin-bottom: 40px;
	padding: 37px 85px 34px;
	background: #E9F4F4;
	border-radius: 8px;
}
#main .support .checkBox .checkList > li {
	width: 47%;
}
#main .support .checkBox .checkList > li:nth-child(2) {
	width: 45.3%;
}
#main .support .checkBox .checkList li ul li {
	padding: 0 0 14px 40px;
	width: 100%;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	background: url("../img/common/icon15.png") no-repeat left top 6px;
	background-size: 21px auto; 
	box-sizing: border-box;
}
#main .support .checkBox .checkList li ul li:last-child {
	padding-bottom: 0;
}
#main .support .comLink a {
	width: 260px;
	height: 59px;
	letter-spacing: 0.2em;
}
#main {
	margin-bottom: 58px;
}
@media all and (min-width: 901px) {
	#main .solution .topBox .ulBox li a:hover {
		background-color: #4AA199;
		background-image: url("../img/common/icon10_over.png");
	}
	#main .plan .tabBox .listUl li .comLink a:hover {
		color: #4AA199;
		background-color: #fff;
		background-image: url("../img/common/icon07.png");
	}
	#main .plan .tabBox02 .listUl li .comLink a:hover {
		color: #2AB4F2;
		background: #fff url("../img/common/icon16.png") no-repeat right 26px center;
		background-size: 8px auto;
	}
	#main .plan .tabBox03 .listUl li .comLink a:hover {
		color: #FFA91F;
		background: #fff url("../img/common/icon17.png") no-repeat right 26px center;
		background-size: 8px auto;
	}
	#main .plan .tabBox02 .comLinkBox a:hover {
		color: #fff;
		background: #2AB4F2 url("../img/common/icon07_over.png") no-repeat right 26px center;
		background-size: 8px auto;
	}
	#main .plan .tabBox03 .comLinkBox a:hover {
		color: #fff;
		background: #FFA91F url("../img/common/icon07_over.png") no-repeat right 26px center;
		background-size: 8px auto;
	}
}
@media all and (max-width: 900px) {
	#container {
		padding-top: 64px;
	}
	.mainVisual {
		min-height: inherit;
	}
	.mainVisual .infoBox {
		padding: 35.8% 0 70.1%;
		width: auto;
	}
	.mainVisual .infoBox .img01 {
		width: 84.6%;
	}
	.mainVisual .infoBox .pho01 {
		top: 12px;
		left: 17px;
		width: 43.6%;
	}
	.mainVisual .infoBox .pho02 {
		top: 13px;
		right: 23px;
		width: 35.8%;
	}
	.mainVisual .infoBox .pho03 {
		top: auto;
		right: auto;
		left: 40px;
		bottom: 11.8%;
		width: 43.1%;
	}
	.mainVisual .btn {
		left: auto;
		right: 6px;
		bottom: 62px;
		width: 42.2%;
	}
	#main .solution {
		padding-bottom: 50px;
	}
	#main .solution h2 {
		margin-bottom: 77px;
		top: -34px;
	}
	#main .solution h2:before {
		height: 58px;
	}
	@keyframes pathmove{
		0%{
			height:0;
			top: 100%;
			opacity: 0;
		}
		30%{
			height: 58px;
			opacity: 1;
		}
		100%{
			height: 0;
			top: calc(100% + 84px);
			opacity: 0;
		}
	}
	#main .solution .topBox {
		margin: 0 0 81px 0;
		display: block;
	}
	#main .solution .topBox .subBox {
		margin: 0 auto 33px auto;
		width: auto;
		max-width: 450px;
	}
	#main .solution .topBox .title {
		margin: -20px 0 12px;
		padding-bottom: 0;
		line-height: 90px;
		background: url("../img/index/sp_line01.png") no-repeat left bottom;
		background-size: 66px auto; 
	}
	#main .solution .topBox .txt {
		font-size: 1.45rem;
		line-height: 1.8;
	}
	#main .solution .topBox .txt .btm {
		margin-top: 3px;
		font-size: 1.95rem;
	}
	#main .solution .topBox .title .lTxt {
		margin: 27px 10px 0 0;
		font-size: 1.3rem;
		line-height: 1.8;
	}
	#main .solution .topBox .title .en {
		font-size: 6.1rem;
		letter-spacing: 0.15em;
	}
	#main .solution .topBox .title .small {
		margin-left: 3px;
		font-size: 3.25rem;
	}
	#main .solution .topBox .title .infoSpan {
		margin-top: -32px;
		font-size: 3.85rem;
	}
	#main .solution .topBox .ulBox {
		width: auto;
	}
	#main .solution .topBox .ulBox li {
		margin-bottom: 20px;
	}
	#main .solution .topBox .ulBox li a {
		padding-right: 30px;
		font-size: 1.8rem;
		background: #fff url("../img/common/icon10.png") no-repeat right 16px center;
		background-size: 17px auto; 
	}
	#main .solution .whiteBox {
		margin: 0 1px 35px;
		padding: 32px 15px 30px;
	}
	#main .solution .whiteBox:last-child {
		margin-bottom: 0;
	}
	#main .solution h3 {
		margin-bottom: 33px;
		font-size: 2.8rem;
	}
	#main .solution .listUl {
		display: block;
	}
	#main .solution .listUl li {
		margin: 0 0 30px;
		padding-bottom: 28px;
		width: 100%;
		box-sizing: border-box;
	}
	#main .solution .listUl li:last-child {
		margin-bottom: 0;
	}
	#main .solution .listUl li .infoBox {
		padding: 0 28px;
	}
	#main .solution .listUl li .top {
		margin-bottom: 16px;
	}
	#main .solution .listUl li .ttl {
		margin-bottom: 19px;
		font-size: 1.95rem;
	}
	#main .solution .listUl li .imgBox {
		margin: 0 0 15px;
		text-align: center;
	}
	#main .solution .listUl li .txtP {
		margin-bottom: 28px;
	}
	#main .solution .listUl li .comLink a {
		height: 48px;
	}
	#main .solution .listUl li .notes {
		margin: 6px 0 -4px;
		line-height: 1.65;
		font-size: 1.35rem;
	}
	#main .solution .listUl li .notes:last-child {
		margin-bottom: 0;
	}
	#main .introduction {
		padding: 49px 0 102px;
	}
	#main .introduction .content {
		width: auto;
	}
	#main .introduction .headLine04 {
		margin-bottom: 40px;
	}
	#main .introduction .title {
		margin-bottom: 9px;
		font-size: 2.1rem;
	}
	#main .introduction .title .blue {
		margin-top: -12px;
		display: block;
		font-size: 3.6rem;
		letter-spacing: 0.15em;
	}
	#main .introduction .title .num {
		font-size: 6.1rem;
	}
	#main .introduction .ttl {
		margin-bottom: 67px;
		padding: 5px 10px 8px;
		border-radius: 5px;
		letter-spacing: 0.05em;
	}
	#main .introduction .stepList {
		margin: 0 1px;
		display: block;
	}
	#main .introduction .stepList > li {
		margin: 0 0 76px;
		padding: 28px 37px 26px;
		width: 100%;
		border-radius: 8px;
	}
	#main .introduction .stepList > li:last-child {
		margin: 0;
	}
	#main .introduction .stepList > li:before {
		margin: 0 -29px 0 0;
		right: 50%;
		top: auto;
		bottom: -18px;
		width: 58px;
		height: 18px;
		background: url("../img/common/sp_icon02.png") no-repeat left top;
		background-size: 58px auto;
	}
	#main .introduction .stepList > li:last-child:before {
		display: none;
	}
	#main .introduction .stepList li .step {
		left: 25px;
	}
	#main .introduction .stepList li .top {
		margin: 0 -10px 22px;
		font-size: 2.2rem;
	}
	#main .introduction .stepList li .txt {
		margin-bottom: 27px;
	}
	#main .introduction .stepList li .checkList li {
		padding: 0 0 4px 25px;
		background: url("../img/common/sp_icon01.png") no-repeat left top 10px;
		background-size: 14px auto; 
	}
	#main .introduction .listUl {
		padding-top: 5px;
		margin: 0 -15px 27px 0;
	}
	#main .introduction .listUl li {
		padding: 0 0 4px 26px;
	}
	#main .introduction .listUl li .num {
		font-size: 1.35rem;
	}
	#main .introduction .listUl li .small {
		font-size: 1.35rem;
	}
	#main .introduction .notesList {
		margin: 0 -7px;
	}
	#main .introduction .notesList li {
		padding-left: 1em;
		font-size: 1.4rem;
		letter-spacing: 0.05em;
		text-indent: -1em;
		line-height: 1.7;
	}
	#main .introduction .topBox {
		margin-bottom: 50px;
		padding-bottom: 47px;
		border-bottom: 1px solid #fff;
	}
	#main .introduction .topTxt {
		margin: -6px 0 39px;
		font-size: 1.8rem;
		text-align: left;
	}
	#main .introduction .stepUl {
		margin: 0 0 40px 0;
	}
	#main .introduction .stepUl li {
		margin: 0 0 28px;
		width: 100%;
		position: relative;
		background: #fff; 
	}
	#main .introduction .stepUl li:before {
		position: absolute;
		left: 50%;
		bottom: -18px;
		width: 56px;
		height: 18px;
		background: url("../img/common/sp_icon03.png") no-repeat left top;
		background-size: 56px auto;
		content: "";
	}
	#main .introduction .stepUl li:last-child {
		margin-right: 0;
		width: 100%;
	}
	#main .introduction .stepUl li:last-child:before {
		display: none;
	}
	#main .introduction .infoBox {
		width: 316px;
		background: #fff;
		box-shadow: 0 0 0;
		padding: 28px 20px 20px;
		box-sizing: border-box;
		border-radius: 8px;
	}
	#main .introduction .infoBox .photoBox {
		width: 100%;
		float: none;
		text-align: center;
		margin-bottom: 43px;
	}
	#main .introduction .infoBox .photoBox img {
		display: block;
		margin: 0 auto;
	}
	#main .introduction .infoBox .textBox {
		width: auto;
		float: none;
	}
	#main .introduction .infoBox .topStep {
		margin-bottom: 30px;
		padding: 0 0 26px 0;
		font-size: 2.2rem;
	}
	#main .introduction .infoBox .topStep img {
		display: block;
		margin: 0 0 14px 6px;
	}
	#main .introduction .infoBox .ttl01 {
		margin-bottom: 12px;
		line-height: 1.7;
	}
	#main .introduction .infoBox .txtList {
		margin-bottom: 24px;
	}
	#main .introduction .infoBox .txtList:last-child {
		margin-bottom: 0;
	}
	#main .introduction .infoBox .txtList li {
		padding: 0 0 0 1em;
		text-indent: -1em;
		line-height: 1.75;
	}
	#main .introduction .infoBox .txtList li:last-child {
		padding-bottom: 0;
	}
	#main .introduction .sliderBox .slick-arrow {
		margin-top: 0;
		top: auto;
		right: 0;
		bottom: -65px;
		width: 41px;
		height: 41px;
	}
	#main .introduction .sliderBox .slick-prev {
		left: 0;
		background: url("../img/index/sp_prev.png") no-repeat left center;
		background-size: 41px auto; 
	}
	#main .introduction .sliderBox .slick-next {
		background: url("../img/index/sp_next.png") no-repeat left center;
		background-size: 41px auto; 
	}
	#main .introduction .sliderBox .slick-dots {
		position: absolute;
		left: 0;
		bottom: -57px;
		right: 0;
		text-align: center;
	}
	#main .introduction .sliderBox .slick-dots li {
		margin: 0 12px;
		display: inline-block;
		width: 9px;
		height: 9px;
		border-radius: 50%;
		background-color: rgba(149,149,149,0.4);
	}
	#main .introduction .sliderBox .slick-dots li button {
		display: none;
	}
	#main .introduction .sliderBox .slick-dots li.slick-active {
		background-color: rgba(149,149,149,1);
	}
	#main .plan {
		margin-bottom: 35px;
		padding: 60px 0 0;
	}
	#main .plan .content {
		width: auto;
	}
	#main .plan .headLine04 {
		margin-bottom: 49px;
	}
	#main .plan .imgList {
		margin: 0 0 38px;
		align-items: center;
		justify-content: space-between;
	}
	#main .plan .imgList li {
		padding: 0;
		width: 29%;
		text-align: center;
	}
	#main .plan .tabPanel {
		margin: 0 -30px;
	}
	#main .plan .ulBox {
		padding: 0 0 6px 32px;
		overflow: hidden;
		overflow-x: scroll;
		border-bottom: 1px solid #959595;
	}
	#main .plan .ulBox .tabUl {
		padding: 0;
		width: 1000px;
		border: none;
	}
	#main .plan .tabUl li {
		margin-right: 13px;
	}
	#main .plan .tabUl li:last-child {
		margin-right: 0;
	}
	#main .plan .tabUl li a {
		font-size: 1.6rem;
		width: 217px;
		height: 43px;
	}
	#main .plan .tabUl .on a {
		margin-bottom: -6px;
		height: 49px;
		font-size: 2rem;
	}
	#main .plan .tabBox .listUl {
		display: block;
	}
	#main .plan .tabBox .listUl > li {
		padding: 30px 18px 36px;
		width: 100%;
		position: relative;
		border-right: none;
	}
	#main .plan .tabBox .listUl02 > li {
		width: 100% !important;
	}
	#main .plan .tabBox .listUl > li:before {
		position: absolute;
		left: 32px;
		right: 32px;
		bottom: 0;
		height: 1px;
		background: #959595;
		content: "";
	}
	#main .plan .tabBox .listUl > li:nth-child(2) {
		width: 100%;
	}
	#main .plan .tabBox .listUl > li:last-child {
		padding-bottom: 35px;
		width: 100%;
		border: none;
	}
	#main .plan .tabBox .listUl > li:last-child:before {
		display: none;
	}
	#main .plan .tabBox .listUl li .topEn {
		margin-bottom: -3px;
		font-size: 2.75rem;
	}
	#main .plan .tabBox .listUl li .price {
		margin-bottom: 2px;
	}
	#main .plan .tabBox .listUl li .price01 {
		margin: 15px 0 45px;
	}
	#main .plan .tabBox .listUl li .price .num {
		font-size: 5.35rem;
		font-weight: 900;
	}
	#main .plan .tabBox .listUl li .price .num01 {
		font-size: 7.75rem;
	}
	#main .plan .tabBox .listUl li .price img {
		display: inline-block;
		vertical-align: middle;
		margin: -49px 20px 0 0;
	}
	#main .plan .tabBox .listUl li .txtP {
		margin: 0 36px 0 40px;
		line-height: 1.7;
	}
	#main .plan .tabBox .listUl li .txtList {
		margin: 0 40px;
	}
	#main .plan .tabBox .listUl li .txtList01 {
		margin: 0 40px;
	}
	#main .plan .tabBox .listUl li .txtP02 .notes {
		margin-right: 0;
	}
	#main .plan .tabBox .listUl li .comLink a {
		width: 260px;
		height: 60px;
		color: #fff;
		font-size: 2rem;
		letter-spacing: 0.2em;
		background-image: url("../img/common/icon07_over.png");
		background-position: right 26px center;
		background-size: 8px auto;
	}
	#main .plan .tabBox .comLinkBox {
		padding: 50px 30px;
	}
	#main .support {
		padding: 10px 0 59px;
	}
	#main .support .content {
		width: auto;
	}
	#main .support .headLine04 {
		margin-bottom: 40px;
	}
	#main .support .checkBox {
		margin-bottom: 40px;
		padding: 24px 30px 16px;
	}
	#main .support .checkBox .checkList {
		display: block;
	}
	#main .support .checkBox .checkList > li {
		width: 100%;
		margin-bottom: 13px;
	}
	#main .support .checkBox .checkList > li:nth-child(2) {
		width: 100%;
	}
	#main .support .checkBox .checkList li ul li {
		background: url("../img/common/sp_icon04.png") no-repeat left top 10px;
		background-size: 20px auto; 
	}
	#main .support .checkBox .checkList li ul li:last-child {
		padding-bottom: 0;
	}
	#main .support .comLink a {
		width: 230px;
	}
	#main {
		margin-bottom: 90px;
	}
	#main li.list-harf {
		width: 100% !important;
	}
}
.mainVisual .btn,
.mainVisual .infoBox .pho {
	opacity: 0;
	transition: opacity .5s linear;
}
body.loaded .mainVisual .btn,
body.loaded .mainVisual .infoBox .pho {
	opacity: 1;
}
.mainVisual .infoBox .pho02 {
	transition-delay: .3s;
}
.mainVisual .infoBox .pho03 {
	transition-delay: .6s;
}
.mainVisual .btn {
	transition-delay: .9s;
}
@media all and (max-width: 374px) {
	#main .solution .topBox .title .infoSpan {
		font-size: 3.2rem;
	}
	#main .solution .listUl li .infoBox {
		padding: 0 20px;
	}
	#main .solution .listUl li .ttl {
		font-size: 1.8rem;
	}
	#main .introduction .title .blue {
		font-size: 3.2rem;
	}
	#main .introduction .title .num {
		font-size: 5.7rem;
	}
	#main .introduction .ttl {
		font-size: 1.6rem;
	}
	#main .introduction .stepList > li {
		padding: 28px 26px 26px;
	}
	#main .plan .tabBox .comLinkBox a {
		background-position: right 15px center;
	}
}


ul.listUl.flex.listUL2 {
    border-top: 2px solid #D3D3D3;
}