@charset "utf-8";
/* -------------------------------
FONT
------------------------------- */
html { font-size: 62.5%; }
body {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.8;
	font-size: 16px;
	color: #3B4043;
}
/* -------------------------------
LAYOUT
------------------------------- */
* {
	word-break: break-all;
	word-wrap: break-word;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
html,
body {
	height: 100%;
}
html { -webkit-text-size-adjust: 1; }
#container {
	width: 100%;
	min-height: 100%;
	height: auto !important;
	height: 100%;
	position: relative;
	margin: 0 auto;
	overflow-anchor: none;
}
@media screen and (max-width: 810px){
	#container {
		overflow-x: hidden;
	}
}
.sp {
	display: none;
}
@media screen and (max-width: 810px){
	.sp {
		display: inline;
	}
}
#adminBox, .acms-admin-box {
/*    position: fixed;*/
    bottom: 0;
    width: 100%;
    z-index: 100;
	margin-bottom: 0;
}
/* -------------------------------
FONT
------------------------------- */
.font_arial{font-family: Arial !important;}
.font_arial_n{font-family: Arial Narrow !important;}
/* -------------------------------
COLOR
------------------------------- */
.red { color: #ff0000; }
.yellow { color: #FFF01F; }
.orange { color: #fe6600; }
/* -------------------------------
COMMON PARTS
------------------------------- */
/* font-size */
.fs10 { font-size: 10px !important; }
.fs11 { font-size: 11px !important; }
.fs12 { font-size: 12px !important; }
.fs13 { font-size: 13px !important; }
.fs14 { font-size: 14px !important; }
.fs15 { font-size: 15px !important; }
.fs16 { font-size: 16px !important; }
.fs17 { font-size: 17px !important; }
.fs18 { font-size: 18px !important; }
.fs19 { font-size: 19px !important; }
.fs20 { font-size: 20px !important; }
.fs21 { font-size: 21px !important; }
.fs22 { font-size: 22px !important; }
.fs23 { font-size: 23px !important; }
.fs24 { font-size: 24px !important; }
.fs25 { font-size: 25px !important; }
.fs26 { font-size: 26px !important; }
/* link */
a {
	color: #3e3a39;
	outline: none !important;
	text-decoration: none;
}
a:visited {
	color: #3e3a39;	
	text-decoration: none;
}
a:hover {
	color: #3e3a39;
	text-decoration: underline;
}
a:active { }

/* bold */
.bold { font-weight: bold; }
/* img */
img { vertical-align: bottom; }
img[usemap] {
    max-width: 100%;
    height: auto;
}
/* margin */
.mb0 { margin-bottom: 0px !important; }
.mb1 { margin-bottom: 1px !important; }
.mb2 { margin-bottom: 2px !important; }
.mb3 { margin-bottom: 3px !important; }
.mb4 { margin-bottom: 4px !important; }
.mb5 { margin-bottom: 5px !important; }
.mb6 { margin-bottom: 6px !important; }
.mb7 { margin-bottom: 7px !important; }
.mb8 { margin-bottom: 8px !important; }
.mb9 { margin-bottom: 9px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb11 { margin-bottom: 11px !important; }
.mb12 { margin-bottom: 12px !important; }
.mb13 { margin-bottom: 13px !important; }
.mb14 { margin-bottom: 14px !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; }
.mt0 { margin-top: 0px !important; }
.mt1 { margin-top: 1px !important; }
.mt2 { margin-top: 2px !important; }
.mt3 { margin-top: 3px !important; }
.mt4 { margin-top: 4px !important; }
.mt5 { margin-top: 5px !important; }
.mt6 { margin-top: 6px !important; }
.mt7 { margin-top: 7px !important; }
.mt8 { margin-top: 8px !important; }
.mt9 { margin-top: 9px !important; }
.mt10 { margin-top: 10px !important; }
.mt11 { margin-top: 11px !important; }
.mt12 { margin-top: 12px !important; }
.mt13 { margin-top: 13px !important; }
.mt14 { margin-top: 14px !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; }
.ml5 { margin-left: 5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.mr5 { margin-right: 5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr30 { margin-right: 30px !important; }
/* padding */
.p1 { padding: 1px !important; }
.p2 { padding: 2px !important; }
.p3 { padding: 3px !important; }
.p4 { padding: 4px !important; }
.p5 { padding: 5px !important; }
.p6 { padding: 6px !important; }
.p7 { padding: 7px !important; }
.p8 { padding: 8px !important; }
.p9 { padding: 9px !important; }
.p10 { padding: 10px !important; }
.p15 { padding: 15px !important; }
.p20 { padding: 20px !important; }
.pb0 { padding-bottom: 0px !important; }
.pb1 { padding-bottom: 1px !important; }
.pb2 { padding-bottom: 2px !important; }
.pb3 { padding-bottom: 3px !important; }
.pb4 { padding-bottom: 4px !important; }
.pb5 { padding-bottom: 5px !important; }
.pb6 { padding-bottom: 6px !important; }
.pb7 { padding-bottom: 7px !important; }
.pb8 { padding-bottom: 8px !important; }
.pb9 { padding-bottom: 9px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb11 { padding-bottom: 11px !important; }
.pb12 { padding-bottom: 12px !important; }
.pb13 { padding-bottom: 13px !important; }
.pb14 { padding-bottom: 14px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pt0 { padding-top: 0px !important; }
.pt1 { padding-top: 1px !important; }
.pt2 { padding-top: 2px !important; }
.pt3 { padding-top: 3px !important; }
.pt4 { padding-top: 4px !important; }
.pt5 { padding-top: 5px !important; }
.pt6 { padding-top: 6px !important; }
.pt7 { padding-top: 7px !important; }
.pt8 { padding-top: 8px !important; }
.pt9 { padding-top: 9px !important; }
.pt10 { padding-top: 10px !important; }
.pt11 { padding-top: 11px !important; }
.pt12 { padding-top: 12px !important; }
.pt13 { padding-top: 13px !important; }
.pt14 { padding-top: 14px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pl5 { padding-left: 5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !important; }
.pl25 { padding-left: 25px !important; }
.pl30 { padding-left: 30px !important; }
.pr5 { padding-right: 5px !important; }
.pr10 { padding-right: 10px !important; }
.pr15 { padding-right: 15px !important; }
.pr20 { padding-right: 20px !important; }
.pr25 { padding-right: 25px !important; }
.pr30 { padding-right: 30px !important; }
/* text-align */
.alignCenter { text-align: center !important; }
.alignLeft { text-align: left !important; }
.alignRight { text-align: right !important; }
/* float */
.floatLeft { float: left; }
.floatRight { float: right; }
/* display */
.dispInlineBlock { display: inline-block; }
.dispInline { display: inline; }
.dispBlock { display: block; }
.dispNone { display: none; }
/* hr */
hr {
	display: block;
	margin: 0;
	padding: 0;
	border: none;
}
/* clear */
.clear { clear: both;}
/* clearfix */
.clearfix { min-height: 1%; }
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
.linkBox { cursor: pointer; }

::-webkit-input-placeholder {
 color: #b2b2b2;
}
:-ms-input-placeholder {
 color: #b2b2b2;
}
::-moz-placeholder {
 color: #b2b2b2;
}

ul.disc {
	margin-left: 1em;
}
ul.disc li {
    list-style-position: outside;
    list-style-type: disc;
}

@media screen and (max-width: 991px){
html {
	min-width: 100%;
}
body {
	min-width: 100%;
	overflow-x: hidden;
	width: 100%;
}
}
@media screen and (max-width: 810px){
	body.open {
		position: fixed;		
	}
	img { max-width: 100%;}
}
/* -------------------------------
HEADER
------------------------------- */
header{
	width: 100%;
	height: 120px;
	background: #fff;
	z-index: 100;
	position: fixed;
	top: 0;
}
header > .inn {
	width: 100%;
	max-width: 1200px;
	height: 100%;
	padding: 22px 20px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
}
header .logo {
	display: flex;
	align-items: center;
}
header #navBtn {
	display: none;
}
@media screen and (max-width: 810px){
	header{
		height: 60px;
	}
	header > .inn {
		padding: 10px;
		max-width: 100%;
	}
	header .logo img {
		width: 200px;
	}
	header #navBtn {
		cursor: pointer;
		display: block;
		padding: 20px;
		position: absolute;
		bottom: 0;
		right: 0;
		top: 0;
		width: 60px;
		background: rgba(149,141,189,0.90);
		text-decoration:none;
	}
 	header #navBtn span {
		display: block;
		height: 2px;
		width: 100%;
		background: #fff;
		border-radius: 2px;
		transition: all 0.5s ease;
	}
	header #navBtn span:nth-of-type(2),
	header #navBtn span:nth-of-type(3) {
		margin-top: 4px;
	}
	header #navBtn span:nth-of-type(3) {
		width: 60%;
	}
	header #navBtn span:nth-of-type(4) {
		margin-top: 8px;
		background: transparent;
		color: #fff;
		font-size: 7px;
		display: flex;
		flex-wrap: nowrap;
		white-space: nowrap;
		justify-content: center;
		align-items: center;
	}
	.open header #navBtn span:nth-of-type(1) {
		-webkit-transform: translateY(9px) translateX(0) rotate(45deg);
		transform: translateY(9px) translateX(0) rotate(45deg);
	}
	.open header #navBtn span:nth-of-type(2) {
		-webkit-transform: translateY(3px) translateX(0) rotate(-45deg);
		transform: translateY(3px) translateX(0) rotate(-45deg);
	}
	.open header #navBtn span:nth-of-type(3) {
		margin-top: 5px;
		opacity: 0;
		-webkit-transform: translateY(9px);
		transform: translateY(9px);
	}
	.open header #navBtn span:nth-of-type(4) {
		opacity: 0;
	}
	#bgModal {
		display: none;
		background: rgba(255, 255, 255, 0.6);
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 10;
	}
}
/* -------------------------------
NAVIGATION
------------------------------- */
#navigation {
	flex: 1;
	display: flex;
	flex-direction: column-reverse;
	align-items: flex-end;
	margin-left: 15px;
	justify-content: space-between;
}
@media screen and (max-width: 810px){
	#navigation {
		display: block;
		position: fixed;
		width: 100%;
		top: 60px;
		bottom: 0;
		left: 100%;
		transition: all 0.4s ease;
		margin-left: 0;
		background: rgba(149,141,189,0.90);
		overflow-y: auto;
	}
	.open header #navigation {
		left:0;
	}
	
}
/* -------------------------------
SNAV
------------------------------- */
#snav {
	display: flex;
	justify-content: flex-end;
}
#snav > ul {
	display: flex;
	justify-content: flex-end;
	line-height: 1;
}
#snav > ul.other {
	padding-left: 5px;
	margin-left: 15px;
}
#snav > ul > li {
	margin-left: 10px;
	display: flex;
	align-items: center;
	font-size: 12px;
	font-weight: bold;
}
#snav > ul > li i {
	font-size: 20px;
	margin-right: 5px;
}
#snav > ul.other li,
#snav > ul.other li a {
	color: #8564A9;
}
#snav > ul > li > .dropPc {
	display: flex;
    align-items: center;
}
#snav > ul > li > .dropPc > label {
	display: flex;
    align-items: center;
}
#snav > ul > li > .dropPc > input {
	display: none;
}
#snav > ul > li > .dropPc .snavModal {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background: rgba(255,255,255,0.95);
	height: 0;
	opacity: 0;
	visibility: hidden;
	overflow: hidden;
	max-height: 0;
	transition: all 0.6s ease;
	z-index: 100;	
}
#snav > ul > li > .dropPc > input:checked + .snavModal {
	height: 100vh;
	max-height: 100vh;
	width: 100vw;
	opacity: 1;
	transition: all 0.6s ease;
	visibility: visible;
}
#snav > ul > li > .dropPc .snavModal > .inn {
	width: 0;
	padding: 0;
	position: relative;
}
#snav > ul > li > .dropPc > input:checked + .snavModal > .inn {
	max-width: 760px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	padding: 70px 0;
}
#snav > ul > li > .dropPc > .snavModal > .inn > label {
	display: block;
	width: 28px;
	height: 28px;
	position: relative;
	align-self: flex-end;
}
#snav > ul > li > .dropPc > .snavModal > .inn > label::before,
#snav > ul > li > .dropPc > .snavModal > .inn > label::after {
	content: "";
	display: block;
	position: absolute;
	height: 2px;
	width: 100%;
	top: 50%;
	margin-top: -1px;
	background: #3e3a39;
	border-radius: 1px;
}
#snav > ul > li > .dropPc > .snavModal > .inn > label::before {
	-webkit-transform: translateY(0) translateX(0) rotate(45deg);
	transform: translateY(0) translateX(0) rotate(45deg);
}
#snav > ul > li > .dropPc > .snavModal > .inn > label::after {
	-webkit-transform: translateY(0) translateX(0) rotate(-45deg);
	transform: translateY(0) translateX(0) rotate(-45deg);
}
#snav > ul > li > .dropPc > .snavModal dl {
	margin-top: 50px;
	color: #3e3a39;
}
#snav > ul > li > .dropPc > .snavModal dl > dt {
	font-size: 22px;
	text-align: center;
	border-bottom: 1.5px solid #3e3a39;
	padding-bottom: 20px;
}
#snav > ul > li > .dropPc > .snavModal dl > dd {
	margin-top: 100px;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form {
	display: flex;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form input[type="search"] {
	-webkit-appearance: textfield;
	box-sizing: border-box;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form input[type="search"]:focus {
	outline-offset: -2px;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form input[type="search"]::-webkit-search-decoration {
	display: none;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form input {
	height: 60px;
	padding: 15px;
	font-size: 16px;
	background: #dbdddb;
	border-radius: 6px 0 0 6px;
	border: none;
	flex: 1;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form button {
	width: 60px;
	height: 60px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	background: #606060;
	border-radius: 0 6px 6px 0;	
	margin-left: 2px;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form button i {
	color: #fff;
	font-size: 20px;
}

#snav > ul > li > .dropPc > .snavModal dl > .dropSp > a{
	display: flex;
	align-items:center;
	position: relative;
	justify-content: center;
	flex-direction: column;
	font-size: 15px;
	text-decoration: none;
	font-weight: bold;	
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp > a::after {
	content: "";
	display: block;
	height: 3px;
	width: 100%;
	bottom: 0;
	left: 0;
	right: 0;
	position: absolute;
	background: #8564A9;
	transform: scaleX(0);
	transition: all 0.2s ease;
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp > a:hover::after {
	transform: scaleX(1);
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp input {
	display: none;
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp label {
	display: none;
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp  dd > ul {
	margin-top: 3.50px;	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li {
	width: calc( ( 100% - 60px ) / 3);
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li > label {
	background: #e7e8e6;
	height: 36px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	font-size: 14px;
	margin-bottom: 14px;
	color: #3e3a39;
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li a {
	color: #3e3a39;
	border-bottom: 1px solid #dddddd;
	height: 50px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	font-size: 14px;
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li a::after {
	content: "";
    display: inline-block;
    height: 9px;
    width: 9px;
    border-top: 2px solid #c1c1c1;
    border-right: 2px solid #c1c1c1;
    transform: rotate(45deg);
    margin-right: 5px;
    vertical-align: middle;
    margin-top: -2px;
}
@media screen and (max-width: 810px){
	#snav {
		flex-direction: column;
		justify-content: flex-start;
		flex-wrap:wrap;
	}
	#snav > ul {
		display: flex;
		justify-content: flex-start;
		flex-direction:column;
		flex-wrap: wrap;
		margin-top: 0px;
		width: 100%;
	}
	#snav > ul.other {
		padding: 30px;
		margin-left: 0;
		border-left: none;
	}
	#snav > ul > li {
		width: 100%;
		position: relative;
		padding: 0;
		border-bottom: 1px solid #fff; 
		margin-left: 0;
	}
	#snav > ul > li i {
		color: #fff;
	}
	#snav > ul > li > a {
		height: 40px;
		color: #fff;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: center;
		font-size: 15px;
	}
	#snav > ul.other li, #snav > ul.other li a {
		color: #fff;
	}
	#snav > ul:first-child {
		display: block;
	}
	#snav > ul:first-child > li:first-child {
		border-top: 1px solid #fff;
		border-bottom: 1px solid #fff;
		padding: 20px 30px;
	}
	#snav > ul:first-child > li:first-child > a {
	}
	#snav > ul.other > li:last-child {
		position: fixed;
		top: 0;
		right: 60px;
		height: 60px;
		width: 60px;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	#snav > ul.other > li:last-child .dropPc > label i {
		font-size: 24px;
		margin-right: 0;
		color: #606060;
	}
	#snav > ul.other > li:last-child .dropPc > label i + span {
		display: none;
	}
	#snav > ul > li .dropPc > label {
		height: 40px;
		color: #fff;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: center;
		font-size: 15px;	
	}
}

/* -------------------------------
GNAV
------------------------------- */
#gnav {
}
#gnav > ul {
	display: flex;
	justify-content: flex-end;
	align-items: stretch;
	width:100%;
}
#gnav > ul > li {
	display: flex;
	align-items: stretch;
	margin-left: 20px;
}
#gnav > ul > li > .dropSp > a{
	display: flex;
	align-items:center;
	position: relative;
	justify-content: center;
	flex-direction: column;
	font-size: 15px;
	text-decoration: none;
	font-weight: bold;	
}
#gnav > ul > li > .dropSp > a::after {
	content: "";
	display: block;
	height: 3px;
	width: 100%;
	bottom: 0;
	left: 0;
	right: 0;
	position: absolute;
	background: #8564A9;
	transform: scaleX(0);
	transition: all 0.2s ease;
}
#gnav > ul > li > .dropSp > a:hover::after {
	transform: scaleX(1);
}
#gnav > ul > li > .dropSp input {
	display: none;
}
#gnav > ul > li > .dropSp label {
	display: none;
}
#gnav > ul > li > .dropSp .dropPc {
	position: fixed;
	top: 120px;
	left: 0;
	right: 0;
	padding: 30px 30px 0;
	background: rgba(255,255,255,0.95);
	opacity: 0;
	visibility: hidden;
	overflow: hidden;
	max-height: 0;
	transition: all 0.6s ease;
	z-index: 5;	
}
#gnav > ul > li > .dropSp:hover .dropPc {
	height: auto;
	max-height: 100vh;
	opacity: 1;
	visibility: visible;
}
#gnav > ul > li > .dropSp .dropPc > ul {
	width: 100%;
	max-width: 1200px;
	height: 100%;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
}
#gnav > ul > li > .dropSp .dropPc > ul > li {
	padding: 0 20px;
	border-left: 1px solid #cccaca;
	width: calc( 100% / 3);
	margin-bottom: 30px;
}
#gnav > ul > li > .dropSp .dropPc > ul > li:nth-child(3n),
#gnav > ul > li > .dropSp .dropPc > ul > li:last-child{
	border-right: 1px solid #cccaca;
}

#gnav > ul > li > .dropSp .dropPc > ul > li > a {
	font-weight: bold;
	font-size: 16px;
}
#gnav > ul > li > .dropSp .dropPc > ul > li > a + .dropSp {
	margin-left: 15px;
}
#gnav > ul > li > .dropSp .dropPc > ul > li > a + .dropSp > ul > li > a {
	font-size: 14px;
}
@media screen and (max-width: 810px){
	#gnav {
		padding: 30px;
	}
	#gnav > ul {
		display: flex;
		justify-content: flex-start;
		flex-direction:column;
		flex-wrap: wrap;
		margin-top: 0px;
		width: 100%;
	}
	#gnav > ul > li {
		width: 100%;
		position: relative;
		margin-left: 0;
		border-top: 1px solid #fff;
	}
	#gnav > ul > li:last-child {
		border-bottom: 1px solid #fff;		
	}
	#gnav > ul > li:first-child {
		border-top: none;
	}
	#gnav > ul > li > .dropSp {
		display: flex;
		justify-content: flex-start;
		flex-direction:column;
		flex-wrap: wrap;
		width: 100%;		
	}
	#gnav > ul > li > .dropSp > a {
		height: 40px;
		color: #fff;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: flex-start;
		font-size: 15px;
	}
	#gnav > ul > li > .dropSp > a::after {
		display: none;
	}
	#gnav > ul > li > .dropSp label {
		display: block;
		width: 12px;
		height: 12px;
		position: absolute;
		top: 14px;
		right:10px;
	}
 	#gnav > ul > li > .dropSp label::before,
	#gnav > ul > li > .dropSp label::after {
		content: "";
		display: block;
		position: absolute;
		height: 2px;
		width: 100%;
		top: 50%;
		margin-top: -1px;
		background: #fff;
		border-radius: 1px;
		transition: all 0.5s ease;
	}
	#gnav > ul > li > .dropSp label::after {
		-webkit-transform: translateY(0) translateX(0) rotate(90deg) scaleX(1);
		transform: translateY(0) translateX(0) rotate(90deg)  scaleX(1);
	}
	#gnav > ul > li > .dropSp input:checked + label::after {
		-webkit-transform: translateY(0) translateX(0) rotate(90deg) scaleX(0);
		transform: translateY(0) translateX(0) rotate(90deg) scaleX(0);
	}
	#gnav > ul > li > .dropSp ul {
		position: relative;
		min-width: 0px;
		width: 100%;
		padding: 0;
		top: 0;
		display: block;
		overflow: hidden;
		height: 0;
		max-height: 0vh;
		transition: all 0.6s ease;
	}
	#gnav > ul > li > .dropSp:hover ul {
		height: 0;
		max-height: 0;
	}
	#gnav > ul > li > .dropSp .dropPc {
		position: static;
		top: auto;
		left: auto;
		right: auto;
		padding: 0;
		background: transparent;
		opacity: 1;
		visibility: visible;
		overflow: visible;
		max-height: none;
		transition: none;
		z-index: 1;	
	}
	#gnav > ul > li > .dropSp:hover .dropPc {
		max-height: none;
	}
	#gnav > ul > li > .dropSp input:checked + label + .dropPc > ul {
		height: auto;
		max-height: none;
	}
	#gnav > ul > li > .dropSp .dropPc > ul {
		display: flex;
		justify-content: flex-start;
		flex-direction:column;
		flex-wrap: nowrap;
		margin-top: 0px;
		width: 100%;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li {
		width: 100%;
		position: relative;
		margin-bottom: 0;
		border-left: none;
		border-top: 1px solid #fff;
		padding: 0 0 0 15px;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li > a {
		height: 40px;
		color: #fff;
		font-size: 13px;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: center;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li > .dropSp label {
		display: block;
		width: 12px;
		height: 12px;
		position: absolute;
		top: 14px;
		right:10px;
	}
 	#gnav > ul > li > .dropSp .dropPc > ul > li > .dropSp label::before,
	#gnav > ul > li > .dropSp .dropPc > ul > li > .dropSp label::after {
		content: "";
		display: block;
		position: absolute;
		height: 2px;
		width: 100%;
		top: 50%;
		margin-top: -1px;
		background: #fff;
		border-radius: 1px;
		transition: all 0.5s ease;
	}
	#gnav > ul > li > .dropSp input#drop06 + label + .dropPc,
	#gnav > ul > li > .dropSp input#drop06 + label{
		display: none !important;;
	}

	#gnav > ul > li > .dropSp .dropPc > ul > li > .dropSp input:checked + label + ul {
		height: auto;
		max-height: none;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li > .dropSp ul {
		display: flex;
		justify-content: flex-start;
		flex-direction:column;
		flex-wrap: nowrap;
		margin-top: 0px;
		width: 100%;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li > .dropSp ul > li {
		width: 100%;
		position: relative;
		margin-bottom: 0;
		border-left: none;
		border-top: 1px solid #fff;
		padding: 0 0 0 15px;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li > .dropSp ul > li > a {
		height: 40px;
		color: #fff;
		font-size: 13px;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: center;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li:nth-child(3n),
	#gnav > ul > li > .dropSp .dropPc > ul > li:last-child {
		border-right: none;
	}
	
}
aside {
	padding: 30px 0 50px;
	margin-top: 80px;
}
aside .inn {
	width: 1200px;
	max-width: 100%;
	margin: 0 auto;
}
aside h2 {
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 30px;
}
aside ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
aside ul li {
	margin: 0 30px;
}
footer {
	background: #F0F3F5;
}
footer .inn {
	width: 1200px;
	max-width: 100%;
	padding: 30px;
	display: flex;
	margin: 0 auto;	
	justify-content: center;
	align-items: center;
}
footer .inn .right {
	margin-left: 30px;
}
footer .inn address {
	font-size: 16px;
	color: #3B4043;
}
footer ul.link {
	display: flex;
	justify-content: center;
	margin-bottom: 30px;
}
footer ul.link li {
	padding: 0 30px;
	border-right: 1px solid #3B4043;
}
footer ul.link li:last-child {
	border-right: none;
}
footer .copyright {
	background: #9F98C4;
	text-align: center;
	color: #fff;
	font-size: 14px;
	height: 66px;
	line-height: 66px;
}
@media screen and (max-width: 810px){
	aside ul li {
		margin-bottom: 30px;
	}
	footer .inn {
		flex-direction: column;
		justify-content: flex-start;
	}
	footer .inn .right {
		text-align: center;
		margin-top: 15px;
	}
	footer .copyright {
		font-size: 12px;
		margin-top: 15px;
	}
}
#contents {
	padding-top: 120px;
}
#contents .txt .btn {
	align-self: stretch;
	text-align: center;
	margin-top: auto;
	margin-top: 30px;
}
#contents .txt .btn a {
	display: inline-flex;
	width: 240px;
	height: 50px;
	color: #fff;
	font-size: 20px;
	line-height: 40px;
	background: #5FADB8;
	border-radius: 5px;
	text-decoration: none;
	text-align: center;
	transition: all 0.2s ease;
	align-items: center;
	justify-content: center;
}
#contents .txt .btn a:hover {
	background: #CA92D1;
}
#contents .txt .btn a::after {
	content:"\f31c";
    font: normal normal normal 1em/1 "Phosphor";
    color: #fff;
    flex-shrink: 0;
    speak: none;
    text-transform: none;
    text-decoration: inherit;
    text-align: center;
    -webkit-font-smoothing: antialiased;	
	display: inline-block;
	margin-left: 10px;
	transition: all 0.2s ease;
}
#contents .txt .btn a:hover::after {
	transform: translateX(3px)
}
@media screen and (max-width: 810px){
/*--------------------------------------
SP
---------------------------------------*/
	#contents {
		padding-top: 60px;
	}

}
