@charset "utf-8";


@import url('https://fonts.googleapis.com/css?family=Ropa+Sans|Ubuntu:400,500,700');
/*
---------------------------------------------------------- */
html { overflow-y: scroll;}
@media print {
html,
html body {}
}

/* body	 -------------------------------------------------------------- */
body{
	font-family:"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HiraKakuPro-W3","メイリオ",Meiryo,"ＭＳ Ｐゴシック","MS PGothic",Arial, Helvetica,sans-serif;
	width:100%;
	-webkit-text-size-adjust: 100%;
	font-size: 15px;
	line-height: 1.5;
	color: #fff;
  background: url("../../img/common/logomark.svg") no-repeat #000;
}
@media screen and (max-width:768px){
body {
	font-size: 14px;
	background-size: 90%;
}
}

/* fonts -------------------------------------------------------------- */
a {
	color: #fff;
	text-decoration: underline;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all  0.3s ease;
}
a:visited {}
a:hover,
a:active { text-decoration: none;}

.bold{font-weight:bold !important;}
.normal{font-weight:normal !important;}

.f11 { font-size: 73.3%;} /* base 15px -> 10px */
.f12 { font-size: 80%;} /* base 15px -> 12px */
.f18 { font-size:120%; }

sup   { font-size: 78%; vertical-align: top;}
sub   { font-size: 78%; vertical-align: baseline;}

/*-- color -- */
.red {color: #e00100;}
.blue {color:#00479d;}
.yellow{color:#e39600;}

/*-- headline -- */
.ttl01{
	font-family: "ten-mincho",serif;
	font-size: 186.7%;
	font-weight: normal;
	margin-bottom: 20px;
}
.ttl02{
	font-family: "ten-mincho",serif;
	font-size: 200%;
	font-weight: normal;
	margin-bottom: 30px;
}
.ttl02 img{
	display: block;
	margin-bottom: 20px;
}
.ttl03{
	font-family: "ten-mincho",serif;
	font-size: 190%;
	font-weight: normal;
	line-height: 1.5;
	margin-bottom: 50px;
	text-align: center;
	position: relative;
}
.ttl03::after{
	content: "";
	position: absolute;
	width: 100px;
	height: 1px;
	background: #fff;
	left: 0;
	right: 0;
	margin: auto;
	bottom: -20px;
}
.ttl04{
	font-size: 110%;
	line-height: 1;
	margin-bottom: 15px;
}
.ttl04 span{
	border:1px solid #fff;
	padding: 12px 20px;
	display: inline-block;
}
@media screen and (max-width:768px){
  .ttl02{
    font-size: 190%;
    margin-bottom: 22px;
    margin-bottom: 40px;
  }
  .ttl03{
     font-size: 180%;
  }
  .ttl03::after{
    bottom: -15px;
  }
}




/* inline align ------------------------------------------------------------ */
.taL {text-align: left   !important;}
.taC {text-align: center !important;}
.taR {text-align: right  !important;}
.vaT {vertical-align: top    !important;}
.vaM {vertical-align: middle !important;}
.vaB {vertical-align: bottom !important;}


/* float ------------------------------------------------------------------ */
.flL    { display: inline; float: left;}
.flR    { display: inline; float: right;}
.flImgL { display: inline; float: left; margin-right: 20px;}
.flImgR { display: inline; float: right; margin-left: 20px;}


/* Tools ------------------------------------------------------------------- */
.clear {clear: both;}
.block {display: block;}
.hide  {display: none;}
.bgN   {background: none !important;}
.tdU   {text-decoration: underline;}
.tdN   {text-decoration: none;}

/* Link ------------------------------------------------------------------- */
.btn01{
	border:1px solid #fff;
	display: inline-block;
	color: #fff;
	text-decoration: none;
	line-height: 1;
	padding: 12px 10px;
}
.btn01 i{
	padding-left: 5px;
}
.btn01:hover{opacity: 0.6;}



/* Img ------------------------------------------------------------------- */
img {
  max-width: 100%;
  height: auto;
  border: 0;
}
.img-rp {
  display: block;
  width: 100%;
  height: auto;
}
/* img hover */
a:hover img{
	filter: alpha(opacity=70);
	-moz-opacity:0.7;
	opacity:0.7;
}


/* wrapper
---------------------------------------------------------- */
#wrapper {
}
@media screen and (max-width:768px){
#wrapper {
}
}


/* header
---------------------------------------------------------- */
.header {
	width: 90%;
  margin: auto;
	padding: 20px 0;
	position: relative;
}
.header h1 a{
	display: flex;
	align-items: center;
  font-family: Arial;
  font-size: 153.3%;
	letter-spacing: 0.1em;
  text-decoration: none;
}
.header h1 a img{
	width: 60px;
	height: 60px;
	margin-right: 15px;
}
.header #logomark .cls-1 {
  fill: #1c1c1c;
  fill-rule: evenodd;
}


@media screen and (max-width:768px){
	.header h1{font-size: 130%;}
  .header h1 a{
    line-height: 1.2;
    font-size: 132%;
  }
}


/* gNavi
---------------------------------------------------------- */
#gNav{
	position: absolute;
	top: 25px;
	right: 0;
}
#gNav a{
  color: #fff;
	text-decoration: none;
	position: relative;
  font-size: 106%;
}
#gNav #sub_gNav{
	display: flex;
	justify-content: flex-end;
	font-size: 80%;
	margin-bottom: 13px;
}
#gNav #sub_gNav li a{
	padding: 0 15px;
  border-right: 1px solid #fff;
}
#gNav #sub_gNav li a:hover{
	color: #666;
}
#gNav #sub_gNav li:last-child a{
	border-right: none;
}
#gNav #sub_gNav li:nth-child(3) a,
#gNav #sub_gNav li:last-child a{
	padding: 0 5px 0 15px;
}
#gNav #sub_gNav li:last-child a{padding-right: 0;}
#gNav #sub_gNav i{font-size: 183.3%;}
#gNav #main_gNav{
	display: flex;
}
#gNav #main_gNav li{
	margin-left: 2em;
}
#gNav #main_gNav li a{padding-bottom: 5px;}
#gNav #main_gNav li a::after {
	position: absolute;
	bottom: -4px;
	left: 0;
	content: '';
	width: 100%;
	height: 2px;
	background: #fff;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: transform .3s;
}
#gNav #main_gNav li a:hover::after {
	transform: scale(1, 1);
}
@media screen and (max-width:768px){
/*menu-trigger*/
	.menu-trigger,
	.menu-trigger span {
		-webkit-transition: 0.4s all;
		transition: 0.4s all;
	}
	.menu-trigger {
		position: absolute;
		right: 0;
		top:20px;
		cursor: pointer;
		width: 60px;
		height: 60px;
		background: #fff;
		z-index: 999;
		display: block;
	}
	.menu-trigger span {
		position: absolute;
		left: 50%;
		margin-left: -15%;
		width: 30%;
		height: 2px;
		background: #000;
		border-radius: 4px;
	}
	.menu-trigger span:nth-of-type(1) {
		top: 40%;
	}
	.menu-trigger span:nth-of-type(2) {
		top: 50%;
		margin-top: -1px;
	}
	.menu-trigger span:nth-of-type(3) {
		bottom: 40%;
	}
	.menu-trigger.active {
		background: #fff;
	}
	.menu-trigger.active span {
		background: #000;
	}
	.menu-trigger.active span:nth-of-type(1) {
		-webkit-transform: translateY(5px) rotate(-45deg);
		-ms-transform: translateY(5px) rotate(-45deg);
		transform: translateY(5px) rotate(-45deg);
	}
	.menu-trigger.active span:nth-of-type(2) {
		opacity: 0;
	}
	.menu-trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(-5px) rotate(45deg);
		-ms-transform: translateY(-5px) rotate(45deg);
		transform: translateY(-5px) rotate(45deg);
	}
	.overlay {
		display: block;
		position: fixed;
		z-index: 1;
		content: "";
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: transparent;
		-webkit-transition: all 0.5s ease;
		transition: all 0.5s ease;
		visibility: hidden;
		background-color: rgba(0,0,0,0.75);
	}

/* gNav */
	#gNav{
		display: none;
	}
	.side-open .overlay {
		visibility: visible;
		cursor: pointer;
		background: rgba(0, 0, 0, 0.7);
	}
	.side-open .overlay::after {
		background: rgba(0, 0, 0, 0.8);
	}
	.side-open .side-menu {
		-webkit-transform: translate3d(-90vw, 0, 0);
		transform: translate3d(-90vw, 0, 0);
	}
	.side-menu {
		position: fixed;
		top: 0;
		right: -90vw;
		padding-top: 100px;
		width: 90vw;
		height: 100%;
		background: rgba(0, 0, 0, 0.9);
		z-index: 900;
		-webkit-transition: all 0.5s ease;
		transition: all 0.5s ease;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
	}
	.side-menu .side-menu_scroll {
		height: 100vh;
		padding-top: 75px;
		padding-bottom: 100px;
	}
	.side-menu #gNav{
		position: static;
		display: flex;
    flex-wrap: wrap;
    flex-direction: column-reverse;
		padding: 30px;
    overflow: auto;
	}
	.side-menu #gNav #sub_gNav{
		justify-content: center;
		font-size: 107%;
		margin-top: 25px;
		flex-wrap: wrap;
	}
	.side-menu #gNav #sub_gNav li{
		margin-bottom: 15px;
	}
	.side-menu #gNav #sub_gNav li:first-child,.side-menu #gNav #sub_gNav li:nth-child(2){
		width: 100%;
	}
	.side-menu #gNav #sub_gNav li a{
		display: block;
		text-align: center;
		border:none;
	}
	.side-menu #gNav #main_gNav{
		display: flex;
		flex-wrap: wrap;
	}
	.side-menu #gNav #main_gNav li{
		width: 100%;
		margin-left: 0;
		margin-bottom: 3%;
	}
	.side-menu #gNav #main_gNav li a{
		display: block;
		text-align: center;
		background: #fff;
		padding: 5px;
		font-size: 107%;
		color: #000;
	}
 /*メニュー開時背景固定*/
 .scroll-prevent {
    position: fixed;
    z-index: -1;
    width: 100%;
    height: 100%;
  }
}



/* mainimg
---------------------------------------------------------- */
#mainimg {
	position: relative;
}


/* contents
---------------------------------------------------------- */
#contents {
	margin: 0 auto;
	text-align: left;
	position: relative;
}
#contents #mainTtl{
  text-align: center;
  padding: 80px 0;
  font-family: 'Ubuntu', sans-serif;
  font-size: 236%;
}
#contents #mainTtl::after{
  content: "\f103";
  font-family: fontawesome;
  font-weight: 500;
  display: block;
}
#contents #mainTtlsub{
  text-align: center;
  padding: 80px 0;
  font-size: 210%;
	line-height: 1;
	letter-spacing: 0.1em;
}
#contents #mainTtlsub span{
	display: block;
	font-weight: 400;
	font-size: 50%;
	margin-top: 20px;
	letter-spacing:0;
  font-family: 'Ubuntu', sans-serif;
}
#contents #mainTtlsub::after{
  content: "\f103";
  font-family: fontawesome;
  font-weight: normal;
  display: block;
	margin-top: 15px;
}
@media screen and (max-width:768px){
  #contents {
    padding: 0;
  }
  #contents #mainTtl{
    padding: 30px 0;
    font-size: 190%;
  }
  #contents #mainTtlsub{
    padding: 50px 0 30px;
    font-size: 200%;
  }
  #contents #mainTtlsub span{
    margin-top:10px;
  }
  #contents #mainTtlsub::after{
    margin-top: 10px;
  }
}


/* layout
---------------------------------------------------------- */
.inner{
	width:1140px;
	margin:auto;
	position:relative;
}
@media screen and (max-width:1139px){
	.inner{
		width:90%;
	}
}
@media screen and (max-width:768px){
}

/* pageTop
---------------------------------------------------------- */
.pageTop {
	position:fixed;
	right:10%;
	bottom:10%;
}
@media screen and (max-width:768px){
.pageTop {
}
}


/* footer
---------------------------------------------------------- */
.footer {
	margin-top: 140px;
  padding: 50px 0;
	width: 100%;
  background: #181818;
}
.footer nav ul{
	text-align: center;
	font-size: 92.9%;
}
.footer nav ul li{
	display: inline-block;
}
.footer nav ul li a{
	color: #fff;
	text-decoration: none;
	padding: 0 10px;
}
.footer nav ul li:not(:last-child) a{
	border-right: 1px solid #fff;
}
.footer .brandLink{
	text-align: center;
	margin: 25px 0 80px;
}
.footer .brandLink li{
  display: inline-block;
  margin: 0 15px;
}
.footer .brandLink a{
	color: #fff;
	text-decoration: none;
	font-size: 92.9%;
}
.footer .brandLink a i{
	padding-left: 3px;
}
.footer a:hover{color: #333;}
#copyright {
	font-size: 86%;
	text-align: center;
}
@media screen and (max-width:768px){
	.footer {
		margin-top: 40px;
		padding: 25px 0;
		width: 100%;
		background: #181818;
	}
	.footer nav ul{
		display: none;
	}
	.footer .brandLink{
		margin:0 0 20px;
		display: flex;
		justify-content: space-between;
		align-items: center;
		flex-wrap: wrap;
		padding: 0 10px;
	}
	.footer .brandLink li{
		width: 49%;
		margin: 0 0 10px;
	}
	.footer .brandLink a{
		display: block;
		width: 100%;
		height: 100%;
		border:1px solid #fff;
		border-radius: 4px;
		padding: 10px 0;
		font-size: 11px;
}
}

/* table
---------------------------------------------------------- */
.type01 {
	width: 100%;
	border-collapse: separate;
	border-top: 1px solid #666666;
}
.type01 th,
.type01 td{
	border-bottom: 1px solid #666666;
	padding: 10px;
	box-sizing: border-box;
}
.type01 th {
	font-weight: normal;
}
.type01 td span{
	display: block;
	padding: 10px 35px;
	border-left: 1px solid #fde9a6;
}
.type01 td span ul li{
	display: flex;
	width: 100%;
  border-bottom: 1px solid #666666;
}
.type01 td span ul li:last-child {
	border-bottom: none;
}
.type01 td span ul li p {
	border-right: 1px solid #666666;
	padding: 5px 0 5px 15px;
}
.type01 td span ul li p:first-child {
	padding-left: 0;
}
.type01 td span ul li p:last-child {
	border-right: none;
}
.type01 td span .ul3 li p{
	width: calc(100%/3);
}
.type01 td span .ul2 li p{
	width: 50%;
}
.type02 {
	width: 100%;
	border-collapse: separate;
	border-top: 1px solid #666666;
}
.type02 th,
.type02 td{
	border-bottom: 1px solid #666666;
	padding: 20px;
  font-weight: normal;
}
.type02 th{
	color: #fde9a6;
}
@media screen and (min-width: 1025px) {
	.type01 td span .ul2 li p:first-child{
		width:calc((100% / 3) * 1);
	}
	.type01 td span .ul2 li p:last-child{
		width:calc((100% / 3) * 2);
	}
}
@media screen and (max-width:768px){
.type01 th{color: #fde9a6; font-size: 107%; font-weight: bold;}
.type01 td span{
	padding: 0;
	border-left:none;
}
.type02 th{
	padding: 15px 0;
}
.type02 td{
	padding: 15px 10px;
}
.table_basic01 {
	width: 100%;
}
.table_basic01,
.table_basic01 thead,
.table_basic01 tbody,
.table_basic01 tr,
.table_basic01 th,
.table_basic01 td {
	width: 100%;
	display: block;
}
.table_basic01 th,
.table_basic01 td {
	border-top: none;
	border-left: none;
}
.table_basic01 th {
}
.table_basic01 td {
}
}

/* フォーム部品
---------------------------------------------------------- */
.check_layout input{
    display:none;
}
.check_layout label{
    display:inline-block;
    position:relative;
    padding-left:25px;

}
.check_layout label:before,.check_layout label:after{
    content:'';
    display:block;
    position:absolute;
    top:0;
    left:0;
    width:15px;
    height:15px;
}
.check_layout label:before{
    background:#fafafa;
    border:1px solid #666666;
}
.check_layout input:checked + label:after{
	left:1px;
	top:-1px;
	content:"\f00c";
	color:#004ea2;
	height:15px;
	margin:auto;
	font-size:108%;
	font-family: FontAwesome;
}


/* clearfix ------------------------------------------------------------------- */
.cf:after{
    content: ".";
    display: block;
    height: 0;
    font-size:0;
    clear: both;
	visibility:hidden;
}
.cf{
	display: inline-block;
}
/* Hides from IE Mac */
* html .cf{
	height: 1%;
}
.cf{
	display:block;
}


/* margin ------------------------------------------------------------------ */
.mt00 { margin-top: 0   !important;}
.mt05 { margin-top: 5px !important;}
.mt10 { margin-top:10px !important;}
.mt12 { margin-top:12px !important;}
.mt15 { margin-top:15px !important;}
.mt20 { margin-top:20px !important;}
.mt25 { margin-top:25px !important;}
.mt30 { margin-top:30px !important;}
.mt35 { margin-top:35px !important;}
.mt40 { margin-top:40px !important;}
.mt45 { margin-top:45px !important;}
.mt50 { margin-top:50px !important;}
.mt-20 { margin-top:-20px !important;}
.mr00 { margin-right: 0   !important;}
.mr05 { margin-right: 5px !important;}
.mr10 { margin-right:10px !important;}
.mr12 { margin-right:12px !important;}
.mr15 { margin-right:15px !important;}
.mr20 { margin-right:20px !important;}
.mr25 { margin-right:25px !important;}
.mr30 { margin-right:30px !important;}
.mr35 { margin-right:35px !important;}
.mr40 { margin-right:40px !important;}
.mr45 { margin-right:45px !important;}
.mr50 { margin-right:50px !important;}
.mb00 { margin-bottom: 0   !important;}
.mb05 { margin-bottom: 5px !important;}
.mb10 { margin-bottom:10px !important;}
.mb12 { margin-bottom:12px !important;}
.mb15 { margin-bottom:15px !important;}
.mb20 { margin-bottom:20px !important;}
.mb25 { margin-bottom:25px !important;}
.mb30 { margin-bottom:30px !important;}
.mb35 { margin-bottom:35px !important;}
.mb40 { margin-bottom:40px !important;}
.mb45 { margin-bottom:45px !important;}
.mb50 { margin-bottom:50px !important;}
.mb80 { margin-bottom:80px !important;}
.ml00 { margin-left: 0   !important;}
.ml05 { margin-left: 5px !important;}
.ml10 { margin-left:10px !important;}
.ml12 { margin-left:12px !important;}
.ml15 { margin-left:15px !important;}
.ml20 { margin-left:20px !important;}
.ml25 { margin-left:25px !important;}
.ml30 { margin-left:30px !important;}
.ml35 { margin-left:35px !important;}
.ml40 { margin-left:40px !important;}
.ml45 { margin-left:45px !important;}
.ml50 { margin-left:50px !important;}

/* padding  ---------------------------------------------------------------- */
.pt00 { padding-top: 0   !important;}
.pt05 { padding-top: 5px !important;}
.pt10 { padding-top:10px !important;}
.pt12 { padding-top:12px !important;}
.pt15 { padding-top:15px !important;}
.pt20 { padding-top:20px !important;}
.pt25 { padding-top:25px !important;}
.pt30 { padding-top:30px !important;}
.pt35 { padding-top:35px !important;}
.pt40 { padding-top:40px !important;}
.pt45 { padding-top:45px !important;}
.pt50 { padding-top:50px !important;}
.pt60 { padding-top:60px !important;}
.pt65 { padding-top:65px !important;}
.pr00 { padding-right: 0   !important;}
.pr05 { padding-right: 5px !important;}
.pr10 { padding-right:10px !important;}
.pr12 { padding-right:12px !important;}
.pr15 { padding-right:15px !important;}
.pr20 { padding-right:20px !important;}
.pr25 { padding-right:25px !important;}
.pr30 { padding-right:30px !important;}
.pr35 { padding-right:35px !important;}
.pr40 { padding-right:40px !important;}
.pr45 { padding-right:45px !important;}
.pr50 { padding-right:50px !important;}
.pb00 { padding-bottom: 0   !important;}
.pb05 { padding-bottom: 5px !important;}
.pb10 { padding-bottom:10px !important;}
.pb12 { padding-bottom:12px !important;}
.pb15 { padding-bottom:15px !important;}
.pb20 { padding-bottom:20px !important;}
.pb25 { padding-bottom:25px !important;}
.pb30 { padding-bottom:30px !important;}
.pb35 { padding-bottom:35px !important;}
.pb40 { padding-bottom:40px !important;}
.pb45 { padding-bottom:45px !important;}
.pb50 { padding-bottom:50px !important;}
.pb60 { padding-bottom:60px !important;}
.pb100 { padding-bottom:100px !important;}
.pb110 { padding-bottom:110px !important;}
.pb130 { padding-bottom:130px !important;}
.pl00 { padding-left: 0   !important;}
.pl03 { padding-left: 3px !important;}
.pl05 { padding-left: 5px !important;}
.pl10 { padding-left:10px !important;}
.pl12 { padding-left:12px !important;}
.pl15 { padding-left:15px !important;}
.pl20 { padding-left:20px !important;}
.pl25 { padding-left:25px !important;}
.pl30 { padding-left:30px !important;}
.pl35 { padding-left:35px !important;}
.pl40 { padding-left:40px !important;}
.pl45 { padding-left:45px !important;}
.pl50 { padding-left:50px !important;}


.txtC{
	text-align: center !important;
}