@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mainVisual {
	margin: 0 auto 115px;
	max-width: 1520px;
}
#main .mainVisual .txtBox {
	margin: -11px auto 0;
	width: 1280px;
}
#main .mainVisual .txtBox ul {
	margin-bottom: 14px;
	display: flex;
	justify-content: space-between;
}
#main .mainVisual .txtBox ul li {
	width: 400px;
}
#main .mainVisual .txtBox p {
	font-size: 1.4rem;
	line-height: 1.2;
}
#main .linkBox {
	margin-bottom: 113px;
	text-align: center;
}
#main .linkBox a {
	display: inline-flex;
	align-items: center;
	font-size: 2.7rem;
	color: #4C4948;
	line-height: 1.3;
	letter-spacing: -0.1em;
	border-bottom: 2px solid #0070B9;
}
#main .linkBox a img {
	margin-left: 5px;
}
#main .sec01 {
	margin: 0 auto 106px;
	position: relative;
	width: 1027px;
}
#main .sec01 .h2Ttl {
	padding: 7px 10px 22px;
	margin-left: -450px;
	position: absolute;
	bottom: 31px;
	left: 50%;
	width: 900px;
	text-align: center;
	font-size: 3rem;
	color: #4C4948;
	font-weight: 500;
	background-color: rgba(255,255,255,0.9);
	box-sizing: border-box;
}
#main .sec01 .h2Ttl span {
	display: block;
	font-size: 3.8rem;
	color: #009CE5;
}
#main .sec02 {
	margin-bottom: 121px;
	padding: 30px 0 81px;
	background: url("../img/index/sec02_bg.jpg") no-repeat center / auto 100%;
}
#main .sec02 .h2Ttl {
	margin-bottom: 33px;
	text-align: center;
	font-size: 3.8rem;
	color: #FFF;
	font-weight: 400;
	letter-spacing: 0.2px;
}
#main .sec02 .inner {
	padding: 1px 20px 5px;
	margin: 0 auto;
	width: 1280px;
	background-color: rgba(255,255,255,0.9);
	border-radius: 15px;
	box-sizing: border-box;
}
#main .sec02 .inner .photo {
	padding-right: 46px;
	margin: 0 auto 8px;
	width: 868px;
}
#main .sec02 .inner .tabUl {
	margin: 0 auto 18px;
	width: 802px;
	display: flex;
	justify-content: space-between;
}
#main .sec02 .inner .tabUl li {
	width: 67px;
	position: relative;
	z-index: 2;
	line-height: 0;
}
#main .sec02 .inner .tabUl li.on:after {
	position: absolute;
	left: -2px;
	top: -2px;
	right: -2px;
	bottom: -2px;
	border: 1px solid #0084BF;
	border-radius: 6px;
	z-index: -1;
	content: "";
}
#main .sec02 .inner .tabUl a {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	border-radius: 4px;
	width: 67px;
	height: 20px;
	font-size: 1.4rem;
	color: #231815;
	font-weight: bold;
	box-sizing: border-box;
}
#main .sec02 .inner .tabUl a span {
	position: absolute;
	top: 1px;
	left: calc(100% + 2px);
	display: block;
	width: 9px;
}
#main .sec02 .inner .tabUl a:hover {
	opacity: 0.7;
}
#main .sec02 .inner .btmTxt {
	text-align: right;
}
#main .sec03 .slideBox {
	margin: 0 auto 128px;
	max-width: 1520px;
}
#main .sec03 .slideBox .slide li {
	height: 697px;
	position: relative;
	display: flex !important;
	align-items: flex-end;
	justify-content: center;
	background: url("../img/index/sec03_photo01-1.jpg") repeat-x top center / auto 100%;
}
#main .sec03 .slideBox .slick-dots {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 146px;
	display: flex;
	justify-content: center;
	z-index: 1;
}
#main .sec03 .slideBox .slick-dots li {
	margin: 0 5px;
	display: block;
	height: auto !important;
	background: none;
}
#main .sec03 .slideBox .slick-dots button {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	padding: 0;
	color: transparent;
	overflow: hidden;
	border: 1px solid #7D7D7D;
	background-color: #7d7d7d;
	cursor: pointer;
	box-sizing: border-box;
}
#main .sec03 .slideBox .slick-dots .slick-active button {
	background-color: transparent;
}
#main .sec03 .slideBox .slick-arrow {
	padding: 0;
	position: absolute;
	bottom: 143px;
	left: 50%;
	width: 10px;
	height: 16px;
	color: transparent;
	border: none;
	background: url(../img/index/arrow01.png) no-repeat center / 10px auto;
	z-index: 2;
	cursor: pointer;
	overflow: hidden;
}
#main .sec03 .slideBox .slick-prev {
	left: calc(50% - 56px);
}
#main .sec03 .slideBox .slick-next {
	left: calc(50% + 47px);
	background-image: url(../img/index/arrow02.png);
}
#main .sec03 .slideBox li h2 {
	padding: 17px 5px 11px;
	margin-bottom: 35px;
	width: 900px;
	text-align: center;
	color: #4C4948;
	font-size: 3rem;
	font-weight: 500;
	letter-spacing: -1.5px;
	box-sizing: border-box;
	background-color: rgba(255,255,255,0.9);
}
#main .sec03 .slideBox li h2 span {
	display: block;
	font-size: 3.8rem;
	color: #009CE5;
	letter-spacing: 1px;
}
#main .sec04 {
	margin-bottom: 102px;
}
#main .sec04 .photoBox {
	position: relative;
	margin: 0 auto;
	max-width: 1520px;
}
#main .sec04 .photoBox p {
	margin-left: -600px;
	position: absolute;
	left: 50%;
	bottom: 50px;
	width: 1200px;
	font-size: 1.4rem;
	line-height: 1.34;
	color: #FFF;
}
#main .sec04 .photoBox p.black {
	bottom: 67px;
	color: #231815;
}
#main .sec05 {
	margin: 0 auto 84px;
	overflow: hidden;
	position: relative;
	max-width: 1520px;
}
#main .sec05:after,
#main .sec05:before {
	position: absolute;
	left: calc(50% + 640px);
	top: 0;
	height: 100%;
	width: 120px;
	background-color: rgba(0,0,0,0.8);
	content: "";
}
#main .sec05:after {
	left: auto;
	right: calc(50% + 640px);
}
#main .sec05 .top {
	padding: 28px 0 6px;
	background-color: #FFF;
}
#main .sec05 h2 {
	margin-bottom: 10px;
	text-align: center;
	font-size: 2.3rem;
	color: #5C5C5C;
	line-height: 1.3;
}
#main .sec05 h2 span {
	font-size: 6rem;
	display: block;
	color: #0084BF;
}
#main .sec05 .photo {
	margin: 0 auto;
	width: 892px;
}
#main .sec05 .btmBox {
	padding: 18px 0 45px;
	background-color: #0084BF;
}
#main .sec05 .btmBox .innerBox {
	margin: 0 auto;
	width: 1170px;
}
#main .sec05 .btmBox h3 {
	margin: 0 5px 8px;
	font-size: 2.5rem;
	color: #fff;
	font-weight: 400;
}
#main .sec05 .tableBox {
	margin-bottom: 24px;
	display: flex;
	justify-content: space-between;
}
#main .sec05 .tableBox table {
	width: 365px;
	border-collapse: collapse;
}
#main .sec05 .tableBox th,
#main .sec05 .tableBox td {
	padding: 2px 5px;
	border: 1px solid #FFF;
	color: #FFF;
	font-size: 1.6rem;
	font-weight: 400;
	box-sizing: border-box;
	letter-spacing: -1px;
}
#main .sec05 .tableBox tr:first-child th,
#main .sec05 .tableBox tr:first-child td {
	border-top: none;
}
#main .sec05 .tableBox tr:last-child th,
#main .sec05 .tableBox tr:last-child td {
	border-bottom: none;
}
#main .sec05 .tableBox th {
	border-left: none;
	width: 64px;
}
#main .sec05 .tableBox td:last-child {
	padding: 2px 10px;
	border-right: none;
	width: 221px;
}
#main .sec06 {
	margin-bottom: 100px;
}
#main .sec06 .btnList {
	margin: 0 auto 60px;
	width: 1280px;
	display: flex;
	justify-content: space-between;
}
#main .sec06 .btnList li {
	min-height: 117px;
}
#main .sec06 .btnList a {
	display: flex;
	height: 100%;
	width: 414px;
	justify-content: space-between;
	align-items: center;
	background-color: #0084BF;
	box-shadow: 2.83px 2.83px 1.5px rgba(0, 0, 0, 0.5);
}
#main .sec06 .btnList a .photo {
	width: 162px;
	display: block;
	height: 100%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
#main .sec06 .btnList a .txt {
	margin-right: 10px;
	width: 230px;
	font-size: 2.1rem;
	font-weight: bold;
	color: #FFF;
	line-height: 1.2;
	letter-spacing: -2px;
}
#main .sec06 .btnList a .txt .link {
	margin-top: 7px;
	display: block;
	font-size: 3.2rem;
	background: url("../img/common/icon03.png") no-repeat right center / 24px auto;
}
#main .sec06 .comBtn a {
	padding-right: 15px;
	background-color: #0084BF;
	color: #FFF;
	letter-spacing: -2px;
	box-sizing: border-box;
	background-image: url("../img/common/icon03.png");
}
@media all and (max-width: 1520px) and (min-width: 1280px) {
	#main .sec04 {
		overflow: hidden;
	}
	#main .sec04 .photoBox {
		margin-left: -760px;
		width: 1520px;
		position: relative;
		left: 50vw;
	}
}
@media all and (max-width: 1279px) and (min-width: 897px) {
	#main .sec04 {
		overflow: hidden;
	}
	#main .sec04 .photoBox {
		margin-left: -120px;
		left: auto;
		width: 1520px;
	}
}
@media all and (max-width: 896px) {
	#main .mainVisual {
		margin: 0 auto 60px;
	}
	#main .mainVisual .txtBox {
		margin: 0 15px;
		width: auto;
	}
	#main .mainVisual .txtBox ul {
		margin-bottom: 0;
		display: block;
	}
	#main .mainVisual .txtBox ul li {
		margin: 0 10px 10px;
		width: auto;
		text-align: center;
	}
	#main .mainVisual .txtBox p {
		margin: 0 10px;
		font-size: 1.2rem;
	}
	#main .linkBox {
		margin: 0 15px 60px;
	}
	#main .linkBox a {
		font-size: 2rem;
	}
	#main .sec01 {
		margin: 0 15px 50px;
		width: auto;
	}
	#main .sec01 .h2Ttl {
		padding: 5px 10px;
		margin-left: 0;
		bottom: 5%;
		left: 10%;
		width: 80%;
		font-size: 2.4rem;
	}
	#main .sec01 .h2Ttl span {
		font-size: 2.8rem;
	}
	#main .sec02 {
		margin-bottom: 60px;
		padding: 20px 0;
	}
	#main .sec02 .h2Ttl {
		margin-bottom: 20px;
		font-size: 3rem;
	}
	#main .sec02 .inner {
		padding: 5px 10px;
		margin: 0 15px;
		width: auto;
	}
	#main .sec02 .inner .photo {
		padding-right: 20px;
		margin: 0 auto 8px;
		width: auto;
		text-align: center;
	}
	#main .sec02 .inner .tabUl {
		margin: 0;
		width: auto;
		flex-wrap: wrap;
		justify-content: center;
	}
	#main .sec02 .inner .tabUl li {
		margin: 5px;
		width: 50px;
	}
	#main .sec02 .inner .tabUl a {
		width: 100%;
	}
	#main .sec02 .inner .tabUl a span {
		width: 5px;
	}
	#main .sec02 .inner .btmTxt {
		font-size: 1.2rem;
	}
	#main .sec03 .slideBox {
		margin: 0 0 60px;
	}
	#main .sec03 .slideBox .slide li {
		height: 300px;
	}
	#main .sec03 .slideBox .slick-dots {
		bottom: calc(22vw - 10px);
	}
	#main .sec03 .slideBox .slick-arrow {
		bottom: calc(22vw - 13px);
	}
	#main .sec03 .slideBox li h2 {
		padding: 5vw 3vw 3vw;
		margin-bottom: 25px;
		width: 80%;
		font-size: 4vw;
	}
	#main .sec03 .slideBox li h2 span {
		font-size: 4.5vw;
	}
	#main .sec04 {
		margin-bottom: 50px;
		overflow: hidden;
	}
	#main .sec04 .photoBox {
		margin: 0 -9.5%;
	}
	#main .sec04 .photoBox p {
		margin-left: 0;
		position: absolute;
		left: 10%;
		bottom: 0;
		width: 80%;
		font-size: 1.5vw;
	}
	#main .sec04 .photoBox p.black {
		bottom: 0;
	}
	#main .sec05 {
		margin: 0 auto 84px;
		overflow: hidden;
		position: relative;
		max-width: 1520px;
	}
	#main .sec05 .top {
		padding: 5px 15px;
		background-color: #FFF;
	}
	#main .sec05 h2 {
		font-size: 2rem;
	}
	#main .sec05 h2 span {
		font-size: 3rem;
	}
	#main .sec05 .photo {
		margin: 0 auto;
		width: auto;
	}
	#main .sec05 .btmBox .innerBox {
		padding:  15px;
		margin: 0 auto;
		width: auto;
	}
	#main .sec05 .btmBox h3 {
		font-size: 2rem;
	}
	#main .sec05 .tableBox {
		margin-bottom: 0;
		display: block;
	}
	#main .sec05 .tableBox table {
		margin-bottom: 30px;
		width: 100%;
	}
	#main .sec05 .tableBox th,
	#main .sec05 .tableBox td {
		font-size: 1.2rem;
	}
	#main .sec05 .tableBox th {
		border-left: none;
		width: 25%;
	}
	#main .sec05 .tableBox td:last-child {
		padding: 2px 10px;
		border-right: none;
		width: 50%;
	}
	#main .sec06 {
		margin-bottom: 50px;
	}
	#main .sec06 .btnList {
		margin: 0 15px 0;
		width: auto;
		display: block;
	}
	#main .sec06 .btnList li {
		min-height: inherit;
		margin: 0 auto 15px;
		width: 100%;
		max-width: 400px;
	}
	#main .sec06 .btnList a {
		position: relative;
		width: auto;
		min-height: 117px;
		padding-left: 35%;
	}
	#main .sec06 .btnList a .photo {
		position: absolute;
		left: 0;
		top: 0;
		width: 30%;
		display: block;
		height: 100%;
	}
	#main .sec06 .btnList a .txt {
		margin-right: 5px;
		font-size: 1.4rem;
	}
	#main .sec06 .btnList a .txt .link {
		margin-top: 7px;
		font-size: 1.8rem;
		background-size: 20px auto;
	}
}
@media all and (max-width: 530px) {
	#main .sec03 .slideBox .slick-dots {
		bottom: calc(25vw - 10px);
	}
	#main .sec03 .slideBox .slick-arrow {
		bottom: calc(25vw - 13px);
	}
}
