@charset "UTF-8";
/* CSS Document */

@font-face {
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}

/*フォントサイズを変更しやすくするための設定*/
html{
	font-size: 62.5%; /*16px x 62.5% =10px*/
}

/*フォント種類・フォントカラー・フォントサイズの指定*/
body{
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	color: #111111;
	font-size: 1.6rem;
	line-height: 1.7;
	font-feature-settings: "palt";
	letter-spacing: 1.5px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	background-image: url("../img/common/img_bg.jpg");
	background-size: cover;
	background-repeat: no-repeat;
	background-attachment: fixed;
}

/*画像のレスポンシブ対応*/
img{
  max-width: 100%;
  height: auto; 
}
a{
	color: #111111;
}
a:hover{
	text-decoration: none;
}
li{
	list-style: none;
}
.inner{
	max-width: 1140px;
	margin: 0 auto;
}
.text-center{
	text-align: center;
}
.pcOnly{
	display: block;
}
.spOnly{
	display: none;
}
.flexWrapper{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
h2{
	font-size: 3.5rem;
	font-weight: 500;
	letter-spacing: 3px;
	line-height: 1.5;
	text-align: center;
}
h3{
	font-size: 2.5rem;
	font-weight: 500;
	letter-spacing: 3px;
	text-align: center;
}
main{
	overflow: hidden;
}

/*section start*/
.section{
	padding: 120px 0;
}
/*section end*/

/* secTitle start */
.secTitle{
	display: inline-block;
	text-align: left;
}
.secTitle p{
	font-size: 2.5rem;
	font-weight: 500;
	line-height: 1;
	margin-bottom: 15px;
}
.secTitle h2{
	color: #1A6096;
	text-align: left;
	line-height: 1;
}
.secTitle div{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	margin-top: 25px;
}
.secTitle div span:first-of-type{
	display: inline-block;
	width: 30px;
	height: 3px;
	background-color: #65E0B7;
}
.secTitle div span:last-of-type{
	display: inline-block;
	width: 30px;
	height: 3px;
	background-color: #3A99E3;
}
/* secTitle end */

/* btn start */
.btn{
	display: inline-block;
	color: white;
	font-weight: 500;
	background: linear-gradient(to right, #65e0b7, #3a99e3);
	padding: 15px 70px 15px 30px;
	border-radius: 50px;
	position: relative;
	letter-spacing: 3px;
}
.btn::before{
	content: url("../img/common/svg_btn_arrow.svg");
	display: inline-block;
	width: 29px;
	height: 29px;
	position: absolute;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
	transition: 0.3s;
}
.btn:hover::before{
	right: 15px;
}
/* btn end */

/* pcHeader start */
.pcHeader{
	box-sizing: border-box;
	width: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
	padding: 15px;
	transition: 0.5s;
	background: linear-gradient(to right, #65e0b7, #3a99e3);
}
body.front .pcHeader{
	background: transparent;
}
body.front .pcHeader.action{
	background: linear-gradient(to right, #65e0b7, #3a99e3);
	padding: 10px 15px;
}
.pcHeader .inner{
	max-width: none;
	width: 100%;
}
.pcHeader .wrapper{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.pcHeader .left h1,
.pcHeader .left p{
	font-size: 1.5rem;
	font-weight: bold;
	color: white;
	padding-left: 5px;
	margin-bottom: 5px;
}
.pcHeader .right{
	text-align: right;
}
.pcHeader .right a{
	transition: 0.3s;
}
.pcHeader .right a span{
	transition: 0.3s;
}
.pcHeader .right a:hover{
	color: #1A6096;
}
.pcHeader .right a:hover span{
	color: #1A6096;
}
.pcHeader .right-upper{
	display: flex;
	justify-content: flex-end;
	align-items: center;
	margin-bottom: 15px;
}
.pcHeader.action .right-upper{
	margin-bottom: 10px;
}
.pcHeader .right-upper .tokyoikukikan{
	color: white;
	font-weight: bold;
}
body.front .pcHeader .right-upper .tokyoikukikan{
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
}
body.front .pcHeader.action .right-upper .tokyoikukikan{
	text-shadow: none;
}
.pcHeader .right-upper .sns{
	display: flex;
	justify-content: flex-end;
	align-items: center;
	margin-left: 5px;
}
.pcHeader .right-upper .sns a{
	display: block;
	margin-left: 10px;
	transition: 0.3s;
}
.pcHeader .right-upper .sns a:hover{
	opacity: 0.8;
}
.pcHeader .right-bottom{
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
.pcHeader .right-bottom nav ul{
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
.pcHeader .right-bottom nav ul li{
	text-align: center;
	margin-left: 15px;
}
.pcHeader .right-bottom nav ul li:first-of-type{
	margin-left: 0;
}
.pcHeader .right-bottom nav ul li a{
	display: block;
	font-weight: bold;
	color: white;
	text-align: center;
}
body.front .pcHeader .right-bottom nav ul li a{
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
}
body.front .pcHeader.action .right-bottom nav ul li a{
	text-shadow: none;
}
.pcHeader .right-bottom nav ul li a span{
	display: block;
	font-size: 1.4rem;
	font-weight: bold;
	color: white;
	text-align: center;
}
body.front .pcHeader .right-bottom nav ul li a span{
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.7);
}
body.front .pcHeader.action .right-bottom nav ul li a span{
	text-shadow: none;
}
.pcHeader .right-bottom .btnWrapper{
	display: flex;
	justify-content: flex-end;
	align-items: center;
	margin-left: 15px;
}
.pcHeader .right-bottom .btnWrapper a{
	display: inline-block;
	width: 150px;
	border-radius: 50px;
	color: white;
	font-weight: bold;
	line-height: 1;
	text-align: center;
	margin-left: 15px;
	transition: 0.3s;
}
.pcHeader .right-bottom .btnWrapper a:first-of-type{
	background-color: #65E0B7;
	padding: 20px 0;
	margin-left: 0;
	font-size: 1.8rem;
}
.pcHeader .right-bottom .btnWrapper a:first-of-type{
	padding: 16px 0;
}
.pcHeader .right-bottom .btnWrapper a:first-of-type:hover{
	background-color: #17AD7C;
}
.pcHeader .right-bottom .btnWrapper a:last-of-type{
	background-color: #3A99E3;
	padding: 10px 0;
}
.pcHeader.action .right-bottom .btnWrapper a:last-of-type{
	padding: 8px 0;
}
.pcHeader .right-bottom .btnWrapper a:last-of-type:hover{
	background-color: #1A6096;
}
.pcHeader .right-bottom .btnWrapper a span{
	display: block;
	font-size: 1.4rem;
	color: white;
	line-height: 1;
	margin-top: 5px;
}
/* pcHeader end */

/* pageHeader start */
.pageHeader{
	margin-top: 130px;
	padding: 0 70px;
	position: relative;
}
.pageHeader::before {
	content: "";
	display: inline-block;
	width: 700px;
	height: 700px;
	border-radius: 50%;
	background-color: rgba(58, 153, 227, 0.1);
	position: absolute;
	top: 68%;
	right: -400px;
	transform: translateY(-32%);
	z-index: -1;
}
.pageHeader .inner{
	max-width: 100%;
	border-bottom: solid 1px #3A99E3;
	padding: 140px 0 270px;
	position: relative;
}
.pageHeader .inner .bigText{
	width: 50vw;
	position: absolute;
	bottom: 0;
	left: 0;
}
.pageHeader h1{
	font-size: 5rem;
	font-weight: 500;
	line-height: 1;
	text-align: center;
}
/* pageHeader end */

/* areaContact start */
.areaContact{
	background: linear-gradient(to right, #65e0b7, #3a99e3);
	padding: 30px;
}
.areaContact .inner{
	max-width: 100%;
	background-color: #fff;
	border-radius: 80px;
}
.areaContact .wrapper{
	max-width: 1140px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 80px 0;
}
.areaContact .left{
	box-sizing: border-box;
	width: 40%;
}
.areaContact .left .secTitle{
	margin-bottom: 30px;
}
.areaContact .left .message p:first-of-type{
	margin-bottom: 20px;
}
.areaContact .right{
	box-sizing: border-box;
	width: 50%;
	text-align: right;
}
.areaContact .right p{
	font-size: 5.3rem;
	font-weight: 500;
	margin-bottom: 40px;
	line-height: 1;
}
.areaContact .right p span{
	font-size: 2.5rem;
	font-weight: 500;
	text-transform: uppercase;
	margin-right: 10px;
}
.areaContact .btn{
	font-size: 2.3rem;
	text-transform: uppercase;
	padding: 25px 220px 25px 180px;
}
.areaContact .btn:first-of-type{
	margin-bottom: 30px;
}
.areaContact .btn::before{
	content: url("../img/common/svg_btn_areaContact_arrow.svg");
	width: 49px;
	height: 50px;
}
@media screen and (max-width:1500px){
	.areaContact .wrapper{
		max-width: 950px;
	}
}
/* areaContact end */

/*footer start*/
.footer{
	padding: 0;
}
.footer .inner{
	padding: 50px 0;
}
.footer .wrapper{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.footer .left .logo{
	margin-bottom: 20px;
}
.footer .left .info p{
	font-weight: 500;
	line-height: 2;
}
.footer .right{
	width: 400px;
}
.footer .right nav ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
}
.footer .right nav ul li{
	width: 200px;
	margin-bottom: 25px;
}
.footer .right nav ul li:nth-of-type(5),
.footer .right nav ul li:last-of-type{
	margin-bottom: 0;
}
.footer .right nav ul li a{
	font-size: 1.8rem;
	font-weight: 500;
	transition: 0.3s;
}
.footer .right nav ul li a:hover{
	color: #1A6096;
}
.footer .copyright{
	border-top: solid 1px #dedede;
	padding: 20px 0;
	text-align: center;
}
/*footer end*/

/* スクロールでフェードイン start */
.fadein {
	opacity: 0;
	transform : translate(0, 50px);
	transition : 1000ms;
}
.fadein.scrollin{
	opacity: 1;
	transform: translate(0, 0);
}
.fadein200 {
	opacity: 0;
	transform : translate(0, 50px);
	transition : 1000ms;
	transition-delay: 0.3s;
}
.fadein200.scrollin{
	opacity: 1;
	transform: translate(0, 0);
}
.fadein300 {
	opacity: 0;
	transform : translate(0, 50px);
	transition : 1000ms;
	transition-delay: 0.6s;
}
.fadein300.scrollin{
	opacity: 1;
	transform: translate(0, 0);
}
.fadein400 {
	opacity: 0;
	transform : translate(0, 50px);
	transition : 1000ms;
	transition-delay: 0.9s;
}
.fadein400.scrollin{
	opacity: 1;
	transform: translate(0, 0);
}
/* スクロールでフェードイン end */

/* 読み込みでフェードイン start */
.fadein-ready {
	opacity: 0;
	transform : translate(0, 50px);
	transition : 1000ms;
}
.fadein-ready.scrollin{
	opacity: 1;
	transform: translate(0, 0);
}
/* 読み込みでフェードイン end */

/* 読み込みで横からフェードイン start */
.fadein-ready-side {
	opacity: 0;
	transform : translate(50px, 0);
	transition : 1500ms;
}
.fadein-ready-side.scrollin{
	opacity: 1;
	transform: translate(0, 0);
}
/* 読み込みで横からフェードイン end */

/*archive-pager start*/
.archive-pager{
	margin-top: 100px;
}
#archive-blog .archive-pager{
	margin-top: 30px;
}
.archive-pager .inner{
	text-align: center;
}
.archive-pager .nav-links a,
.archive-pager .nav-links span{
	display: inline-block;
	width: 40px;
	height: 40px;
	border-radius: 40px;
	line-height: 40px;
	transition: 0.3s;
	background-color: #E2F2FF;
}
.archive-pager .nav-links .current{
	background-color: #1A6096;
	color: white;
}
.archive-pager .nav-links a:hover{
	background-color: #1A6096;
	color: white;
}
/*archive-pager end*/

/*page404 start*/
.page404{
	margin-top: 120px;
	padding: 100px 0 100px;
	background-color: #E2F2FF;
}
.page404 .upper{
	padding-bottom: 90px;
	margin-bottom: 90px;
	border-bottom: solid 1px #fff;
}
.page404 .title{
	font-size: 100px;
	font-weight: 500;
	line-height: 1;
	text-align: center;
	margin-bottom: 30px;
}
.page404 .upper p{
	font-size: 3rem;
	font-weight: 500;
	line-height: 1;
	text-align: center;
}
.page404 .bottom{
	display: flex;
	justify-content: center;
	align-items: center;
}
.page404 .bottom .left{
	margin-right: 70px;
}
.page404 .bottom .right p{
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 2px;
}
.page404-btn{
	display: inline-block;
	background-color: #3A99E3;
	color: white;
	font-weight: 500;
	padding: 20px 40px;
	margin-top: 35px;
	line-height: 1;
	border-radius: 10px;
	transition: 0.3s;
}
.page404-btn:hover{
	opacity: 0.8;
}
/*page404 end*/

.noPost{
	width: 100%;
	text-align: center;
}



@media screen and (max-width:767px){
	
	body{
      font-size: 1.4rem;
  }
  .inner{
		box-sizing: border-box;
		max-width: 100%;
		padding: 0 20px;
  }
  img{
      width: 100%;
      height: auto;
  }
  .pcOnly{
		display: none;
  }
  .spOnly{
		display: block;
  }
	h2{
		font-size: 2.5rem;
		font-weight: 500;
		letter-spacing: 2px;
		text-align: center;
	}
	h3{
		font-size: 1.8rem;
		font-weight: 500;
		letter-spacing: 2px;
		text-align: center;
	}
	
	/*section start*/
	.section{
		padding: 50px 0;
	}
	/*section end*/

	/* secTitle start */
	.secTitle p{
		font-size: 1.8rem;
	}
	.secTitle div span:first-of-type{
		height: 2px;
	}
	.secTitle div span:last-of-type{
		height: 2px;
	}
	.secTitle div{
		margin-top: 17px;
	}
	/* secTitle start */
	
	/* page-secTitle start */
	
	/* page-secTitle end */

	/* btn start */
	.btn{
		box-sizing: border-box;
		min-width: 200px;
		letter-spacing: 2px;
		padding: 10px 60px 10px 30px;
	}
	.btn::before{
		right: 13px;
	}
	.btn:hover::before{
		right: 13px;
	}
	/* btn end */

	/* spHeader start*/
	.spHeader{
		box-sizing: border-box;
		width: 100%;
		background: white;
		position: fixed;
		top: 0;
		z-index: 10;
	}
	.spHeader .inner{
		padding: 8px 15px 8px 10px;
	}
	.spHeader .wrapper{
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.spHeader .logo{
		width: 38%;
	}
	.triggerBtn-wrapper{
		background: linear-gradient(to right, #65e0b7, #3a99e3);
		display: flex;
		justify-content: center;
		align-items: center;
		padding: 1px;
		border-radius: 50px;
		overflow: hidden;
	}
	.triggerBtn-line {
		display: inline-block;
		width:30px;
		height:30px;
		margin: 0 auto;
		position: relative;
		background-color: white;
		border-radius: 50px;
	}
	.triggerBtn-line span {
		display: block;
		width: 15px;
		height: 1px;
		position: absolute;
		transition: all 0.5s;
	}    
	.triggerBtn-line span:first-of-type{
		background-color: #3A99E3;
		top: 12px;
		left: 50%;
		transform: translateX(-50%);
	}
	.triggerBtn-line span:last-of-type{
		background-color: #65E0B7;
		top: 17px;
		left: 50%;
		transform: translateX(-50%);
	}
	.triggerBtn-line.active span:first-of-type{
		top: 15px;
		transform: translateX(-50%) rotate(45deg);
	}
	.triggerBtn-line.active span:last-of-type{
		top: 15px;
		transform: translateX(-50%) rotate(-45deg);
	}
	/* spHeader end*/

	/*drawer start*/
	.drawer{
		opacity: 0;
		box-sizing: border-box;
		width: 100%;
		height: 100vh;
		padding-top: 50px;
		background: linear-gradient(to top, #65e0b7, #3a99e3);
		position: fixed;
		top: 0;
		left: 0;
		transition: 0.1s;
		z-index: -15;
	}
	.drawer.open{
		opacity: 1;
		z-index: 9;
	}
	.drawer .inner{
		box-sizing: border-box;
		max-width: 100%;
		padding: 15px 20px 0;
		position: relative;
	}
	.drawer h3{
		font-size: 1.4rem;
		color: #f2f2f2;
		text-align: left;
	}
	.drawer .logo{
		width: 45%;
		margin-bottom: 40px;
	}
	.drawer .menu ul li{
		border-bottom: solid 1px rgba(255, 255, 255, 0.2);
	}
	.drawer .menu ul li a{
		display: block;
		color: white;
		padding: 15px 0;
	}
	.drawer .menu ul li a span{
		margin-left: 10px;
	}
	.drawer .sns{
		padding: 15px 0;
		position: absolute;
		top: 0;
		right: 20px;
	}
	.drawer .sns .wrapper{
		display: flex;
    justify-content: center;
    align-items: center;
	}
	.drawer .sns a:first-of-type{
		margin-right: 10px;
	}
	.drawer .btnWrapper{
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 35px 0 30px;
	}
	.drawer .btnWrapper a{
		display: inline-block;
    width: calc(50% - 10px);
    border-radius: 50px;
    color: white;
    font-weight: bold;
    line-height: 1;
    text-align: center;
		border: solid 1px white;
    transition: 0.3s;
	}
	.drawer .btnWrapper a:first-of-type{
		background-color: #65E0B7;
    padding: 20px 0;
    margin-left: 0;
    font-size: 1.6rem;
	}
	.drawer .btnWrapper a:last-of-type{
		background-color: #3A99E3;
    padding: 10px 0;
	}
	.drawer .btnWrapper a span{
		display: inline-block;
		margin-top: 5px;
	}
	.drawer .tokyoikukikan{
		text-align: center;
	}
	.drawer .tokyoikukikan a{
		color: white;
		border-bottom: solid 1px white;
		letter-spacing: 1px;
	}
	/*drawer end*/

	/*pageTitle start*/

	/*pageTitle end*/
	
	/* pageHeader start */
	.pageHeader{
		margin-top: 50px;
		padding: 0 20px;
	}
	.pageHeader::before {
		width: 300px;
		height: 300px;
		top: 68%;
		right: -150px;
		transform: translateY(-32%);
	}
	.pageHeader .inner{
		padding: 50px 0 110px;
	}
	.pageHeader .inner .bigText{
		box-sizing: border-box;
		width: 100vw;
		left: 50%;
		transform: translateX(-50%);
		padding: 0 20px;
	}
	.pageHeader h1{
		font-size: 3rem;
	}
	/* pageHeader end */

	/*areaContact start*/
	.areaContact{
		padding: 15px;
	}
	.areaContact .inner{
		border-radius: 20px;
	}
	.areaContact .wrapper{
		display: block;
		padding: 40px 0 35px;
	}
	.areaContact .left{
		width: 100%;
		text-align: center;
	}
	.areaContact .left .secTitle{
		margin-bottom: 30px;
	}
	.areaContact .secTitle p{
		text-align: center;
	}
	.areaContact .secTitle div{
		justify-content: center;
	}
	.areaContact .left .message p{
		text-align: left;
	}
	.areaContact .left .message p:first-of-type{
		margin-bottom: 15px;
	}
	.areaContact .right{
		width: 100%;
		text-align: center;
		margin-top: 30px;
	}
	.areaContact .right p{
		font-size: 3rem;
		letter-spacing: 1px;
		text-align: center;
		margin-bottom: 30px;
	}
	.areaContact .right p span{
		font-size: 2rem;
	}
	.areaContact .btn{
		max-width: 250px;
		font-size: 1.8rem;
		padding: 12px 130px 12px 100px;
		margin: 0 auto;
	}
	.areaContact .btn::before{
		content: url(../img/common/svg_btn_areaContact_arrow_sp.svg);
		width: 37px;
    height: 37px;
	}
	.areaContact .btn:first-of-type{
		margin-bottom: 20px;
	}
	/*areaContact end*/

	/*footer start*/
	.footer .inner{
		padding: 30px 20px;
	}
	.footer .wrapper {
    display: block;
    justify-content: space-between;
    align-items: center;
	}
	.footer .left .logo{
		width: 50%;
		margin-bottom: 15px;
	}
	.footer .left .info p{
		font-weight: normal;
		line-height: 2;
	}
	.footer .right{
		width: 100%;
		margin-top: 20px;
	}
	.footer .right nav ul li {
    width: 140px;
    margin-bottom: 15px;
	}
	.footer .right nav ul li a{
		font-size: 1.5rem;
	}
	.footer .copyright{
		font-size: 1.2rem;
		letter-spacing: 1px;
	}
	/*footer end*/

	/* スクロールでフェードイン start */
	.fadein {
		opacity: 0;
		transform : translate(0, 50px);
		transition : 1000ms;
	}
	.fadein.scrollin{
		opacity: 1;
		transform: translate(0, 0);
	}
	.fadein200 {
		opacity: 0;
		transform : translate(0, 50px);
		transition : 1000ms;
		transition-delay: 0.3s;
	}
	.fadein200.scrollin{
		opacity: 1;
		transform: translate(0, 0);
	}
	.fadein300 {
		opacity: 0;
		transform : translate(0, 50px);
		transition : 1000ms;
		transition-delay: 0.6s;
	}
	.fadein300.scrollin{
		opacity: 1;
		transform: translate(0, 0);
	}
	.fadein400 {
		opacity: 0;
		transform : translate(0, 50px);
		transition : 1000ms;
		transition-delay: 0.9s;
	}
	.fadein400.scrollin{
		opacity: 1;
		transform: translate(0, 0);
	}
	/* スクロールでフェードイン end */
	
	/*archive-pager start*/
	.archive-pager{
		margin-top: 50px;
	}
	#archive-blog .archive-pager{
		margin-top: 10px;
	}
	.archive-pager .nav-links a,
	.archive-pager .nav-links span{
		width: 30px;
		height: 30px;
		border-radius: 30px;
		line-height: 30px;
	}
	/*archive-pager end*/
	
	/*page404 start*/
	.page404{
		margin-top: 50px;
		padding: 50px 0;
	}
	.page404 .upper{
		padding-bottom: 50px;
		margin-bottom: 50px;
	}
	.page404 .title{
		font-size: 30px;
		margin-bottom: 20px;
	}
	.page404 .upper p{
		font-size: 1.8rem;
	}
	.page404 .bottom .left{
		display: none;
	}
	.page404 .bottom .right{
		text-align: center;
	}
	.page404 .bottom .right p{
		font-size: 1.6rem;
		text-align: center;
	}
	.page404-btn{
		padding: 17px 30px;
	}
	.page404-btn:hover{
		opacity: 1;
	}
	/*page404 end*/
  
	
	
}

