@charset "utf-8";
/* CSS Document */
/*
============================================================
*	common.css
============================================================
*/
/* 初期化
==========================================================*/
@import url("./reset.css");
@import url("./animation.css");
@import url('https://fonts.googleapis.com/css?family=Roboto%20Condensed:400,700');


/*
==========================================================*/
html,body{
	height:100%;
}
body{
	font-family: 'Helvetica Neue', Helvetica, Arial, 'ヒラギノ角ゴ Pro W3' ,'Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic', sans‒serif;
	font-size:14px;
	line-height:1.8;
	color:#fff;
/* background:black; */
background: #03002b;
}

a,a:link{
	color:#fff;
	text-decoration: none;
	transition: 0.2s ease-in-out;
}
/*a:visited{text-decoration:none;}*/
a:hover{text-decoration: none;}
/*a:active{text-decoration:none;}*/
.pc_only{display: block;}
.sp_only{display: none;}

.container{
	width: 1000px;
	margin: 0 auto;
	box-sizing: border-box;
	min-width: 1000px;
	position: relative;
}


/* ヘッダー
==========================================================*/
header{
	width: 100%;
	position: fixed;
	z-index: 10;
}
.header_logo{
	float: left;
}
.logo{
	margin: 30px 0 0 35px;
}
.logo img{
	width: 133px;
}
header a:hover{
	opacity: .6;
}
.header_insta{
	position: absolute;
	top: 0;
	right: 0;
	z-index: 10;
}
.header_insta img{
	width: 84px;
}


@media screen and (max-width: 768px){
	header{
		width: 100%;
		position: fixed;
		z-index: 2;
	}
	.header_logo{
		float: left;
	}
	.logo{
		margin: 20px 0 0 20px;
	}
	.logo img{
		width: 100px;
		position: fixed;
    z-index: 11;
	}
	header a:hover{
		opacity: .6;
	}
	.header_insta{
		display: none;
	}
}







#menu {/*親要素*/
	width: 120px;
	height: 120px;
	position: absolute;
	right: -55px;
	top: -32px;
	list-style: none;
	font-size: 200%;
	text-align: center;
}

.menu-button {/*メニュー展開のトリガー要素*/
	opacity: 0;
	z-index: -1;
}

.menu-button {/*スタイル*/
	width: 120px;
	height: 120px;
	position: absolute;
	left: 50%;
	top: 50%;
	margin: -75px 0 0 -75px;
	border-radius: 50%;
	background: url(../images/icon_insta_header_bg.png) 0 0 / 120px 120px no-repeat;
	overflow: hidden;
	text-decoration: none;
}

#menu:not(:target) > a:first-of-type,
#menu:target > a:last-of-type {/*開閉用*/
	opacity: 1;
	z-index: 1;
}

#menu:not(:target) > .icon-plus:before,
#menu:target > .icon-minus:before {/*開閉用*/
	opacity: 1;
}
#menu span.fa-comments{
	position: relative;
	z-index: 2;
	font-size: 1.2em;
	margin: 80px 40px 0 0;
}

.menu-item {/*メニューのスタイル*/
	width: 30px;
	height: 30px;
	position: absolute;
	font-size: 0.55em;
	left: 55%;
	line-height: 1;
	top: 50%;
	margin: -50px 0 0 -50px;
	border-radius: 50%;
	background-color: #000;
	transform: translate(0px, 0px);
	transition: transform 500ms;
	z-index: -2;
	transition: 0.5s;
}

.menu-item a:hover {
	opacity: 0.5;
}

.menu-item a {
	color: #fff;
	position: relative;
	display: inline-block;
	width: 100%;
	height: 100%;
	z-index: 4;
	text-decoration: none;
	padding-top: 8px;
	box-sizing: border-box;
}

/*位置調整*/
#menu:target > .menu-item:nth-child(6) {
	transform: rotate(-6deg) translateY(114px) rotate(6deg);
	transition-delay: 0.4s;
}

#menu:target > .menu-item:nth-child(5) {
	transform: rotate(70deg) translateY(90px) rotate(-70deg);
	transition-delay: 0.1s;
}
#menu:target > .menu-item:nth-child(4) {
	transform: rotate(18deg) translateY(105px) rotate(-18deg);
	transition-delay: 0.3s;
}
#menu:target > .menu-item:nth-child(3) {
	transform: rotate(45deg) translateY(98px) rotate(-45deg);
	transition-delay: 0.2s;
}

.content {
	position: absolute;
	text-align: center;
	margin: -10px 0 0 -30px;
	top: 70%;
	left: 50%;
	font-size: 20px;
}


@media screen and (max-width: 768px){
	#menu{
		display: none;
	}
}



/* グローバルナビ
----------------------------------------------------------*/
.gnavi{
	float: right;
	margin: 40px 100px 0 0;
}
.gnavi a{
	color: #2dbce9;
	font-size: 18px;
}
.gnavi ul{
	display: flex;

  gap: 3rem;
}
.gnavi ul li{
	margin: 0;


	font-family: 'Roboto Condensed';
  font-weight: bold;
  letter-spacing: .1em;
  font-size: 1.3rem;
}
.sns_sp{
	display: none;
}

@media screen and (max-width: 1200px){
.gnavi{
	float: right;
	margin: 40px 40px 0 0;
}

}
@media screen and (max-width: 768px){


	.gnavi{
		float: none;
		border-top: none;
		border-bottom: none;
		margin: 0;
		line-height: 2;
	    padding: 20px 20px 20px;
	    position: relative;
	    height: 100%;
		font-family: 'Roboto Condensed';
		font-weight: bold;
	}
	.gnavi ul{
		display: block;
		float: none;
		width: auto;
		margin: 50px 0 0;
	}
	.gnavi ul li{
		display: block;
		padding: 4px 0;
		float: none;
		text-align: center;
		margin-right: 20px;
	}
	.gnavi ul li.pc_only{display: none;}
	.gnavi ul li.sp_only{display: block;}
	.gnavi ul li a{
		display: block;
		padding: 10px 0;
		font-size: 20px;
		letter-spacing: .2em;
	}
	.gnavi a:hover{
		opacity:0.6;
	}
	.gnavi ul li a{
		color: #2DBCE9;
		text-decoration: none;
	}

	.sp_menu{
		background: rgba(0,0,0,.9);
		width: 100%;
		overflow: hidden;
		height: 100vh;
		position: fixed;
	    display: none;
	    box-sizing: border-box;
	    margin: 0;
	    text-align: left;
	    top: 0;
	    bottom: 0;
	    left: 100%;
	    z-index: 10;
	}
	#menuButton {
	    display: block;
	    width: 42px;
	    height:42px;
	    position: fixed;
	    top: 5px;
	    right: 5px;
	    z-index: 10;
	}
	#menuButton span {
	    display: block;
	    background: #2DBCE9;
	    width: 24px;
	    height: 2px;
	    position: absolute;
	    left: 9px;
	    transition: all 0.4s;
	    -webkit-transition: all 0.4s;
	    -moz-transition: all 0.4s;
	}
	#menuButton span:first-child {
	    top: 12px;
	}
	#menuButton span:nth-child(2) {
	    margin-top: -1px;
	    top: 50%;
	}
	#menuButton span:last-child {
	    bottom: 12px;
	}
	#menuButton.active span:first-child {
	    -webkit-transform: translateY(8px) rotate(45deg);
	    -moz-transform: translateY(8px) rotate(45deg);
	    -ms-transform: translateY(8px) rotate(45deg);
	    transform: translateY(8px) rotate(45deg);
	}
	#menuButton.active span:nth-child(2) {
	    opacity: 0;
	}
	#menuButton.active span:last-child {
	    -webkit-transform: translateY(-8px) rotate(-45deg);
	    -moz-transform: translateY(-8px) rotate(-45deg);
	    -ms-transform: translateY(-8px) rotate(-45deg);
	    transform: translateY(-8px) rotate(-45deg);
	}
	.sns_sp{
		display: block;
		padding: 0 20px;
	}
	.sns_sp ul{
		display: flex;
		justify-content: space-around;
		text-align: center;
	}
}

/* フッター
==========================================================*/
footer{
	margin: 180px 0 0;
	/* background: url(../images/footer_bg.jpg) 50% 0 no-repeat; */
	text-align: center;
	padding: 50px 0 50px;
}
.footer_contents h2 img{
	width: 396px;
}
.footer_contents p{
	font-size: 12px;
  text-align: center;
  margin-top: 20px;

  margin-bottom: 100px;
}
.copyright{
	width: 100%;
	height: 55px;
	line-height: 55px;
	text-align: center;
	font-size: 12px;
	letter-spacing: .05em;
	/* background: url(../images/copyright_bg.jpg) 50% 50% / cover no-repeat; */
	background:#2dbce9;
}
.sns{
	text-align: center;
	width: 300px;
	margin: 0 auto 60px;
	box-sizing: border-box;
}
.sns ul{
	display: flex;
	justify-content: space-between;
}
.sns a{
	display: inline-block;
	width: 60px;
	height: 60px;
	line-height: 60px;
	border: 1px solid #fff;
	border-radius: 50%;
	vertical-align: bottom;
	font-size: 2.3em;
	color: #fff;
}
.sns a:hover{
	background: #fff;
	color: #000;
	transform: scale(1.2,1.2);
}


@media screen and (max-width: 1000px){
	.footer_contents p{
		font-size: 12px;
    text-align: center;
    margin-top: 20px;
    margin-left: 0;
	}
}
@media screen and (max-width: 700px){
	footer{
		margin: 100px 0 0;
		padding: 30px 0 30px;
	}
	.footer_contents h2 img{
		width: 50%;
	}
	.footer_contents p{
		font-size: 12px;
		text-align: center;
		margin-top: 40px;
		margin-left: 0;
		margin-bottom: 30px;
	}
	.copyright{
		width: 100%;
		height: 35px;
		line-height: 35px;
		text-align: center;
		font-size: 10px;
		letter-spacing: 1;
	/*	background: url(../images/copyright_bg.jpg) 50% 50% no-repeat; */
	background: #2dbce9;
	}
	.sns{
		text-align: center;
		width: 80%;
		margin: 0 auto 60px;
	}


}


/* 汎用コンテンツ
==========================================================*/
/* タイトル
----------------------------------------------------------*/


/* 下層ヘッダータイトル
----------------------------------------------------------*/


/* パンくず
----------------------------------------------------------*/
.breadcrumbs{
	position: relative;
	width: 1000px;
	min-width: 1000px;
	margin: 0 auto;
	color: #626262;
}
.breadcrumbs ul{
	display: flex;
}
.breadcrumbs ul li{
	font-size: 13px;
	height: 80px;
	line-height: 80px;
	letter-spacing: .1em;
	padding: 0 15px 0 20px;
	position: relative;
}
.breadcrumbs ul li:first-child{
	padding-left: 0;
}
.breadcrumbs ul li a{
	color: #626262;
	text-decoration: underline;
}
.breadcrumbs ul li::before{
	content: ">";
	padding: 0;
	position: absolute;
	left: 0px;
}
.breadcrumbs ul li:first-child::before{
	display: none;
}
.breadcrumbs ul li a:hover{
	opacity: .6;
}

@media screen and (max-width: 1000px){
	.breadcrumbs{
		width: 100%;
		min-width: 100%;
		padding: 0 20px;
	}
	.breadcrumbs ul li{
		height: auto;
		padding-top: 25px;
		padding-bottom: 20px;
		padding-right: 15px;
		line-height: 1.4;
	}
}






/* テキスト ＆　背景
----------------------------------------------------------*/



/* イメージ
----------------------------------------------------------*/




/* テーブル
----------------------------------------------------------*/




/* フォーム
----------------------------------------------------------*/
.formWrap{
	width: 700px;
	margin: 0 auto;
}
.formWrap fieldset{
	border: none;
	padding: 0 0 180px;
}
.formWrap label{
	display: block;
	margin: 20px 0;
	font-size: 14px;
	letter-spacing: .1em;
}
.formWrap label input,.formWrap label select,.formWrap label textarea{
	display: block;
	font-size: 16px;
	margin: 5px 0;
	padding: 10px;
	border: none;
	outline: none;
	width: 100%;
	box-sizing: border-box;
	box-shadow: 0 2px 3px rgba(0,0,0,.15);
	transition: 0.3s all;
}
.formWrap label div{
	display:flex;
	justify-content: space-between;
}
.formWrap label div > div{
	width:32%;
}
.formWrap label select.short{
	height:58px;
}
.formWrap label select.short:last-child{
	margin: 0px;
}
.formWrap label input{
	height: 50px;
}
.formWrap label select{
	height: 50px;
	border: 1px solid #ccc;
}
.formWrap label input:focus,.formWrap label select:focus,.formWrap label textarea:focus{
	border: 4px solid #ce1c85;
	box-shadow: 0 5px 10px rgba(0,0,0,.15);
	background: #eee;
}
.formWrap .submit{
	background: #333;
	color: #fff;
	border: none;
	width: 100%;
	font-size: 20px;
	height: 80px;
	line-height: 80px;
	cursor: pointer;
	margin: 20px 0 0;
	letter-spacing: .2em;
	box-shadow: 0 5px 8px rgba(0,0,0,.35);
	transition: 0.3s ease-in-out;
	position: relative;
	display: inline-block;
	z-index:1;
	text-align: center;
}
.formWrap .submit:hover{
	letter-spacing: .5em;
}
.formWrap .submit::after {
	content:"";
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	transform: scale(.7);
	position: absolute;
	display: block;
	transition: 0.3s ease-in-out;
}
.formWrap .submit:hover::after {
	background: #ce1c85;
	-webkit-transform: scale(1);
	transform: scale(1);
}
.formWrap label.error{
	margin: 10px 0;
	letter-spacing: 0em;
	font-size: 13px;
	color: #f00;
}

@media screen and (max-width: 800px){
	.formWrap{
		max-width: 100%;
		padding: 0 15px;
		margin: 0 auto 20px;
	}
	.formWrap fieldset{
		border: none;
		padding: 0 0 60px;
	}
}



a , button {
	outline: 0;
}
#cboxOverlay {
	background: #000;
}
#cboxLoadedContent {
	background: #0d0d0d;
	box-shadow: 10px 10px 0 rgba(34,34,34,1) !important;
}
#inline-content {
	margin: 20px;
}
#ajax-wrap {
	margin: 40px;
}
#cboxLoadedContent {
	padding: 0;
	overflow: auto;
-moz-box-shadow: 0px 1px 10px #000000;
-webkit-box-shadow: 0px 1px 10px #000000;
box-shadow: 0px 1px 10px #000000;
}
#cboxPrevious, #cboxNext, #cboxSlideshow, #cboxClose , #cboxTitle {
	top: -30px;
}
#colorbox, #cboxOverlay, #cboxWrapper {
	overflow: visible ;
}
#cboxTitle {
	color: #fff;
}






/* その他
----------------------------------------------------------*/
.bold{font-weight: bold;}
.floatL{
	float: left;
	margin: 0 40px 40px 0;
}
.floatR{
	float: right;
	margin: 0 0 40px 40px;
}


/* clearfix
----------------------------------------------------------*/
.cf:after{
	display:block;
	height:0;
	content:"";
	visibility:hidden;
	clear:both;
}
.cf{
	zoom:1;
}



/* Media Queries
==========================================================*/
@media screen and (max-width: 1000px){
	*{box-sizing: border-box;}
	body{
		-webkit-text-size-adjust: 100%;
		box-sizing: border-box;
		width: 100%;
		font-size: 13px;
	}
	img{
	    max-width:100%;
	    height:auto;
	}
	.container{
		width: 100%;
		min-width: 0;
		margin-left:auto;
		margin-right:auto;
		box-sizing: border-box;
	}
}

@media screen and (max-width: 767px){
	.container{
		width: 100%;
		padding: 0 10px;
		margin-left:auto;
		margin-right:auto;
		box-sizing: border-box;
	}
	.floatL{
		float: none;
		margin: 0;
	}
	.floatR{
		float: none;
		margin: 0;
	}
	.pc_only{display: none;}
	.sp_only{display: block;}

}

