@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.75;
	font-size: 16px;
	font-size: 1.6rem;
	color: #000;
}
/* -------------------------------
LAYOUT
------------------------------- */
* {
/*	word-break: break-all;*/
	word-wrap: break-word;
	overflow-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;
	background: #fff;
	overflow-anchor: none;
	overflow: hidden;
	padding-top: 9rem;
}
.pc {
	display: block !important;
}
.sp {
	display: none !important;
}

@media screen and (max-width: 810px){
	#container {
		overflow-x: hidden;
		padding-top: 6rem;
		padding-bottom: 3.5rem;
	}
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
	#chatplusview { z-index: 1000003 !important;}
}
/* -------------------------------
FONT
------------------------------- */
sup {font-size: 0.6em;}

/* -------------------------------
COLOR
------------------------------- */
.red { color: #ff0000 !important; }
.yellow { color: #FFF01F !important; }
.orange { color: #fe6600 !important; }
.pink { color: #fca2ad !important;}
.magenta {color: #fc4f64 !important;}
.black {color: #000000 !important;}
/* -------------------------------
COMMON PARTS
------------------------------- */
/* font-size */
.fs10 { font-size: 1.0rem !important; }
.fs11 { font-size: 1.1rem !important; }
.fs12 { font-size: 1.2rem !important; }
.fs13 { font-size: 1.3rem !important; }
.fs14 { font-size: 1.4rem !important; }
.fs15 { font-size: 1.5rem !important; }
.fs16 { font-size: 1.6rem !important; }
.fs17 { font-size: 1.7rem !important; }
.fs18 { font-size: 1.8rem !important; }
.fs19 { font-size: 1.9rem !important; }
.fs20 { font-size: 2.0rem !important; }
.fs21 { font-size: 2.1rem !important; }
.fs22 { font-size: 2.2rem !important; }
.fs23 { font-size: 2.3rem !important; }
.fs24 { font-size: 2.4rem !important; }
.fs25 { font-size: 2.5rem !important; }
.fs26 { font-size: 2.6rem !important; }
/* link */
a {
	color: #3d3d3d;
	outline: none !important;
	text-decoration: none;
}
a:hover {
	color: #3d3d3d;
	text-decoration: underline;
}
em { font-style: italic !important;}
#mainCol a {
	text-decoration: underline;
}
#mainCol a:hover {
	text-decoration: none;
}
#mainCol .links li a {text-decoration: none;}
#mainCol .links li a:hover {text-decoration: underline;}
#mainCol .tab li a {text-decoration: none;}
#mainCol .tab li a:hover {text-decoration: underline;}
label { cursor: pointer;}

#mainCol .pdfLink li {
	width: calc(50% - 0.5rem);
	margin-top: 3rem;
	margin-bottom: 3rem;
	margin-left: auto;
	margin-right: auto;
}
#mainCol .pdfLink li a {
	width: 100%;
	display: flex;
	border: 1px solid #ccc;
	border-radius: 3px;
	width: 100%;
	height: 5rem;
	position: relative;
	align-items: center;
	justify-content: space-between;
}
#mainCol .pdfLink li a p {
	flex: 1 0 auto;
	text-align: center;
	line-height: 1.2;
	margin:0;
}
#mainCol .pdfLink li a.pdf::before {
	content: "";
	display: inline-block;
	background: url(../images/ico_pdf01.png) no-repeat center center / contain;
	width: 2.4rem;
	height: 2.8rem;
	margin-left: 1rem;
}

@media screen and (max-width: 810px){
	#mainCol a {
		text-decoration: underline;
	}
}
/* bold */
.bold { font-weight: bold; }
/* img */
img { vertical-align: bottom; min-height: 0%;}
img[usemap] {
    max-width: 100%;
    height: auto;
}
/* margin */
.mb0 { margin-bottom: 0rem !important; }
.mb1 { margin-bottom: 0.1rem !important; }
.mb2 { margin-bottom: 0.2rem !important; }
.mb3 { margin-bottom: 0.3rem !important; }
.mb4 { margin-bottom: 0.4rem !important; }
.mb5 { margin-bottom: 0.5rem !important; }
.mb6 { margin-bottom: 0.6rem !important; }
.mb7 { margin-bottom: 0.7rem !important; }
.mb8 { margin-bottom: 0.8rem !important; }
.mb9 { margin-bottom: 0.9rem !important; }
.mb10 { margin-bottom: 1.0rem !important; }
.mb11 { margin-bottom: 1.1rem !important; }
.mb12 { margin-bottom: 1.2rem !important; }
.mb13 { margin-bottom: 1.3rem !important; }
.mb14 { margin-bottom: 1.4rem !important; }
.mb15 { margin-bottom: 1.5rem !important; }
.mb20 { margin-bottom: 2.0rem !important; }
.mb25 { margin-bottom: 2.5rem !important; }
.mb30 { margin-bottom: 3.0rem !important; }
.mb35 { margin-bottom: 3.5rem !important; }
.mb40 { margin-bottom: 4.0rem !important; }
.mb45 { margin-bottom: 4.5rem !important; }
.mb50 { margin-bottom: 5.0rem !important; }
.mt0 { margin-top: 0rem !important; }
.mt1 { margin-top: 0.1rem !important; }
.mt2 { margin-top: 0.2rem !important; }
.mt3 { margin-top: 0.3rem !important; }
.mt4 { margin-top: 0.4rem !important; }
.mt5 { margin-top: 0.5rem !important; }
.mt6 { margin-top: 0.6rem !important; }
.mt7 { margin-top: 0.7rem !important; }
.mt8 { margin-top: 0.8rem !important; }
.mt9 { margin-top: 0.9rem !important; }
.mt10 { margin-top: 1.0rem !important; }
.mt11 { margin-top: 1.1rem !important; }
.mt12 { margin-top: 1.2rem !important; }
.mt13 { margin-top: 1.3rem !important; }
.mt14 { margin-top: 1.4rem !important; }
.mt15 { margin-top: 1.5rem !important; }
.mt20 { margin-top: 2.0rem !important; }
.mt25 { margin-top: 2.5rem !important; }
.mt30 { margin-top: 3.0rem !important; }
.mt35 { margin-top: 3.5rem !important; }
.mt40 { margin-top: 4.0rem !important; }
.mt45 { margin-top: 4.5rem !important; }
.mt50 { margin-top: 5.0rem !important; }
.ml5 { margin-left: 0.5rem !important; }
.ml10 { margin-left: 1.0rem !important; }
.ml15 { margin-left: 1.5rem !important; }
.ml20 { margin-left: 2.0rem !important; }
.ml25 { margin-left: 2.5rem !important; }
.ml30 { margin-left: 3.0rem !important; }
.mr5 { margin-right: 0.5rem !important; }
.mr10 { margin-right: 1.0rem !important; }
.mr15 { margin-right: 1.5rem !important; }
.mr20 { margin-right: 2.0rem !important; }
.mr25 { margin-right: 2.5rem !important; }
.mr30 { margin-right: 3.0rem !important; }
/* padding */
.p0 { padding: 0 !important; }
.p1 { padding: 0.1rem !important; }
.p2 { padding: 0.2rem !important; }
.p3 { padding: 0.3rem !important; }
.p4 { padding: 0.4rem !important; }
.p5 { padding: 0.5rem !important; }
.p6 { padding: 0.6rem !important; }
.p7 { padding: 0.7rem !important; }
.p8 { padding: 0.8rem !important; }
.p9 { padding: 0.9rem !important; }
.p10 { padding: 1.0rem !important; }
.p15 { padding: 1.5rem !important; }
.p20 { padding: 2.0rem !important; }
.pb0 { padding-bottom: 0rem !important; }
.pb1 { padding-bottom: 0.1rem !important; }
.pb2 { padding-bottom: 0.2rem !important; }
.pb3 { padding-bottom: 0.3rem !important; }
.pb4 { padding-bottom: 0.4rem !important; }
.pb5 { padding-bottom: 0.5rem !important; }
.pb6 { padding-bottom: 0.6rem !important; }
.pb7 { padding-bottom: 0.7rem !important; }
.pb8 { padding-bottom: 0.8rem !important; }
.pb9 { padding-bottom: 0.9rem !important; }
.pb10 { padding-bottom: 1.0rem !important; }
.pb11 { padding-bottom: 1.1rem !important; }
.pb12 { padding-bottom: 1.2rem !important; }
.pb13 { padding-bottom: 1.3rem !important; }
.pb14 { padding-bottom: 1.4rem !important; }
.pb15 { padding-bottom: 1.5rem !important; }
.pb20 { padding-bottom: 2.0rem !important; }
.pb25 { padding-bottom: 2.5rem !important; }
.pb30 { padding-bottom: 3.0rem !important; }
.pt0 { padding-top: 0rem !important; }
.pt1 { padding-top: 0.1rem !important; }
.pt2 { padding-top: 0.2rem !important; }
.pt3 { padding-top: 0.3rem !important; }
.pt4 { padding-top: 0.4rem !important; }
.pt5 { padding-top: 0.5rem !important; }
.pt6 { padding-top: 0.6rem !important; }
.pt7 { padding-top: 0.7rem !important; }
.pt8 { padding-top: 0.8rem !important; }
.pt9 { padding-top: 0.9rem !important; }
.pt10 { padding-top: 1.0rem !important; }
.pt11 { padding-top: 1.1rem !important; }
.pt12 { padding-top: 1.2rem !important; }
.pt13 { padding-top: 1.3rem !important; }
.pt14 { padding-top: 1.4rem !important; }
.pt15 { padding-top: 1.5rem !important; }
.pt20 { padding-top: 2.0rem !important; }
.pt25 { padding-top: 2.5rem !important; }
.pt30 { padding-top: 3.0rem !important; }
.pl5 { padding-left: 0.5rem !important; }
.pl10 { padding-left: 1.0rem !important; }
.pl15 { padding-left: 1.5rem !important; }
.pl20 { padding-left: 2.0rem !important; }
.pl25 { padding-left: 2.5rem !important; }
.pl30 { padding-left: 3.0rem !important; }
.pr5 { padding-right: 0.5rem !important; }
.pr10 { padding-right: 1.0rem !important; }
.pr15 { padding-right: 1.5rem !important; }
.pr20 { padding-right: 2.0rem !important; }
.pr25 { padding-right: 2.5rem !important; }
.pr30 { padding-right: 3.0rem !important; }
@media screen and (max-width: 810px){
	/* margin */
	.mb0 { margin-bottom: 0rem !important; }
	.mb1 { margin-bottom: 0.05rem !important; }
	.mb2 { margin-bottom: 0.1rem !important; }
	.mb3 { margin-bottom: 0.15rem !important; }
	.mb4 { margin-bottom: 0.2rem !important; }
	.mb5 { margin-bottom: 0.25rem !important; }
	.mb6 { margin-bottom: 0.3rem !important; }
	.mb7 { margin-bottom: 0.35rem !important; }
	.mb8 { margin-bottom: 0.4rem !important; }
	.mb9 { margin-bottom: 0.45rem !important; }
	.mb10 { margin-bottom: 0.5rem !important; }
	.mb11 { margin-bottom: 0.55rem !important; }
	.mb12 { margin-bottom: 0.6rem !important; }
	.mb13 { margin-bottom: 0.65rem !important; }
	.mb14 { margin-bottom: 0.7rem !important; }
	.mb15 { margin-bottom: 0.75rem !important; }
	.mb20 { margin-bottom: 1.0rem !important; }
	.mb25 { margin-bottom: 1.25rem !important; }
	.mb30 { margin-bottom: 1.5rem !important; }
	.mb35 { margin-bottom: 1.75rem !important; }
	.mb40 { margin-bottom: 2.0rem !important; }
	.mb45 { margin-bottom: 2.25rem !important; }
	.mb50 { margin-bottom: 2.5rem !important; }
	.mt0 { margin-top: 0rem !important; }
	.mt1 { margin-top: 0.05rem !important; }
	.mt2 { margin-top: 0.1rem !important; }
	.mt3 { margin-top: 0.15rem !important; }
	.mt4 { margin-top: 0.2rem !important; }
	.mt5 { margin-top: 0.25rem !important; }
	.mt6 { margin-top: 0.3rem !important; }
	.mt7 { margin-top: 0.35rem !important; }
	.mt8 { margin-top: 0.4rem !important; }
	.mt9 { margin-top: 0.45rem !important; }
	.mt10 { margin-top: 0.5rem !important; }
	.mt11 { margin-top: 0.55rem !important; }
	.mt12 { margin-top: 0.6rem !important; }
	.mt13 { margin-top: 0.65rem !important; }
	.mt14 { margin-top: 0.7rem !important; }
	.mt15 { margin-top: 0.75rem !important; }
	.mt20 { margin-top: 1.0rem !important; }
	.mt25 { margin-top: 1.25rem !important; }
	.mt30 { margin-top: 1.5rem !important; }
	.mt35 { margin-top: 1.75rem !important; }
	.mt40 { margin-top: 2.0rem !important; }
	.mt45 { margin-top: 2.25rem !important; }
	.mt50 { margin-top: 2.5rem !important; }
	.ml5 { margin-left: 0.25rem !important; }
	.ml10 { margin-left: 0.5rem !important; }
	.ml15 { margin-left: 0.75rem !important; }
	.ml20 { margin-left: 1.0rem !important; }
	.ml25 { margin-left: 1.25rem !important; }
	.ml30 { margin-left: 1.5rem !important; }
	.mr5 { margin-right: 0.25rem !important; }
	.mr10 { margin-right: 0.5rem !important; }
	.mr15 { margin-right: 0.75rem !important; }
	.mr20 { margin-right: 1.0rem !important; }
	.mr25 { margin-right: 1.25rem !important; }
	.mr30 { margin-right: 1.5rem !important; }
	/* padding */
	.p1 { padding: 0.05rem !important; }
	.p2 { padding: 0.1rem !important; }
	.p3 { padding: 0.15rem !important; }
	.p4 { padding: 0.2rem !important; }
	.p5 { padding: 0.25rem !important; }
	.p6 { padding: 0.3rem !important; }
	.p7 { padding: 0.35rem !important; }
	.p8 { padding: 0.4rem !important; }
	.p9 { padding: 0.45rem !important; }
	.p10 { padding: 0.5rem !important; }
	.p15 { padding: 0.75rem !important; }
	.p20 { padding: 1.0rem !important; }
	.pb0 { padding-bottom: 0rem !important; }
	.pb1 { padding-bottom: 0.05rem !important; }
	.pb2 { padding-bottom: 0.1rem !important; }
	.pb3 { padding-bottom: 0.15rem !important; }
	.pb4 { padding-bottom: 0.2rem !important; }
	.pb5 { padding-bottom: 0.25rem !important; }
	.pb6 { padding-bottom: 0.3rem !important; }
	.pb7 { padding-bottom: 0.35rem !important; }
	.pb8 { padding-bottom: 0.4rem !important; }
	.pb9 { padding-bottom: 0.45rem !important; }
	.pb10 { padding-bottom: 0.5rem !important; }
	.pb11 { padding-bottom: 0.55rem !important; }
	.pb12 { padding-bottom: 0.6rem !important; }
	.pb13 { padding-bottom: 0.65rem !important; }
	.pb14 { padding-bottom: 0.7rem !important; }
	.pb15 { padding-bottom: 0.75rem !important; }
	.pb20 { padding-bottom: 1.0rem !important; }
	.pb25 { padding-bottom: 1.25rem !important; }
	.pb30 { padding-bottom: 1.5rem !important; }
	.pt0 { padding-top: 0rem !important; }
	.pt1 { padding-top: 0.05rem !important; }
	.pt2 { padding-top: 0.1rem !important; }
	.pt3 { padding-top: 0.15rem !important; }
	.pt4 { padding-top: 0.2rem !important; }
	.pt5 { padding-top: 0.25rem !important; }
	.pt6 { padding-top: 0.3rem !important; }
	.pt7 { padding-top: 0.35rem !important; }
	.pt8 { padding-top: 0.4rem !important; }
	.pt9 { padding-top: 0.45rem !important; }
	.pt10 { padding-top: 0.5rem !important; }
	.pt11 { padding-top: 0.55rem !important; }
	.pt12 { padding-top: 0.6rem !important; }
	.pt13 { padding-top: 0.65rem !important; }
	.pt14 { padding-top: 0.7rem !important; }
	.pt15 { padding-top: 0.75rem !important; }
	.pt20 { padding-top: 1.0rem !important; }
	.pt25 { padding-top: 1.25rem !important; }
	.pt30 { padding-top: 1.5rem !important; }
	.pl5 { padding-left: 0.5rem !important; }
	.pl10 { padding-left: 0.5rem !important; }
	.pl15 { padding-left: 0.75rem !important; }
	.pl20 { padding-left: 1.0rem !important; }
	.pl25 { padding-left: 1.25rem !important; }
	.pl30 { padding-left: 1.5rem !important; }
	.pr5 { padding-right: 0.25rem !important; }
	.pr10 { padding-right: 0.5rem !important; }
	.pr15 { padding-right: 0.75rem !important; }
	.pr20 { padding-right: 1.0rem !important; }
	.pr25 { padding-right: 1.25rem !important; }
	.pr30 { padding-right: 1.5rem !important; }
}
/* text-align */
.alignCenter { text-align: center !important; }
.alignLeft { text-align: left !important; }
.alignRight { text-align: right !important; }
/* float */
.floatLeft::after,
.floatRight::after { 
	content: "";
	display: block;
	clear: both;
}
.floatLeft .pic {
	float: left;
	margin-right: 2rem;
}
.floatRight .pic {
	float: right;
	margin-left: 2rem;
}
.floatLeft .txt,
.floatRight .txt {
}
@media screen and (max-width: 810px){
	.floatLeft .txt p,
	.floatRight .txt p {
		font-size: 1.4rem;
	}
}

/* display */
.dispInlineBlock { display: inline-block !important; }
.dispInline { display: inline !important; }
.dispBlock { display: block !important; }
.dispNone { display: none !important; }
/* 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; }

/* flex */
.flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.flex .pic {
}
.flex .pic img {
	max-width: 100%;
}
.flex .txt {
	flex: 1;
}
@media screen and (max-width: 810px){
	.flex {
		display: flex;
		flex-wrap: wrap;
		flex-direction: column;
		justify-content: flex-start;
		align-items: center;
	}
	.flex .txt {
		flex: auto;
	}
}

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

@media screen and (max-width: 991px){
html {
	min-width: 100%;
}
body {
	min-width: 100%;
	overflow-x: hidden;
}
}
@media screen and (max-width: 810px){
	body.open {
		position: fixed;		
	}
}
/* -------------------------------
HEADER
------------------------------- */
header{
	width: 100%;
	height: 9rem;
	background: #fff;
	z-index: 1000001;
	position: fixed;
	top: 0;
}
header > .inn {
	width: 100%;
	max-width: 120rem;
	height: 100%;
	padding: 1rem 2rem;
	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: 6rem;
	}
	header > .inn {
		padding: 1rem;
		max-width: 100%;
	}
	header .logo img {
		width: 18.2rem;
	}
	header #navBtn {
		cursor: pointer;
		display: block;
		padding: 2rem;
		position: absolute;
		bottom: 0;
		right: 0;
		top: 0;
		width: 6rem;
		background: rgba(255,170,176,0.95);
		text-decoration:none;
		z-index:10;
	}
 	header #navBtn span {
		display: block;
		height: 0.2rem;
		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: 0.4rem;
	}
	header #navBtn span:nth-of-type(3) {
		width: 60%;
	}
	header #navBtn span:nth-of-type(4) {
		margin-top: 0.8rem;
		background: transparent;
		color: #fff;
		font-size: 0.7rem;
		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(0, 0, 0, 0.6);
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 1000000;
	}
}
/* -------------------------------
NAVIGATION
------------------------------- */
#navigation {
	flex: 1;
	display: flex;
	flex-direction: column-reverse;
	align-items: flex-end;
	justify-content: space-between;
}
@media screen and (max-width: 810px){
	#navigation {
		display: block;
		position: fixed;
		width: 100%;
		top: 6rem;
		bottom: 0;
		left: 100%;
		transition: all 0.4s ease;
		margin-left: 0;
		background: rgba(255,170,176,0.95);
		z-index:11;
	}
	.open header #navigation {
		left:0;
		overflow-y: auto;
}
	
}
/* -------------------------------
SNAV
------------------------------- */
#snav {
	display: flex;
	justify-content: flex-end;
}
#snav > ul {
	display: flex;
	justify-content: flex-end;
	line-height: 1;
}
#snav > ul.other {
	padding-left: 0.5rem;
	margin-left: 1.5rem;
	border-left: 1px solid #cccaca;
}
#snav > ul > li {
	margin-left: 1rem;
	display: flex;
	align-items: center;
	font-size: 1.2rem;
	font-weight: bold;
}
#snav > ul > li i {
	font-size: 2rem;
	margin-right: 0.5rem;
}
#snav > ul > li button {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	color: #3d3d3d;
    outline: none !important;
    text-decoration: none;
	font-weight: bold;	
}
#snav > ul > li button:hover {
	text-decoration: underline;
}
#snav > ul.other li,
#snav > ul.other li a {
	color: #f27e7e;
}
#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: 1000001;	
}
#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: 76rem;
	width: 100%;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	padding: 7rem 0;
}
#snav > ul > li > .dropPc > .snavModal > .inn > label {
	display: block;
	width: 2.8rem;
	height: 2.8rem;
	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: 0.2rem;
	width: 100%;
	top: 50%;
	margin-top: -0.1rem;
	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: 5rem;
	color: #3e3a39;
}
#snav > ul > li > .dropPc > .snavModal dl > dt {
	font-size: 2.2rem;
	text-align: center;
	border-bottom: 1.5px solid #3e3a39;
	padding-bottom: 2rem;
}
#snav > ul > li > .dropPc > .snavModal dl > dd {
	margin-top: 10rem;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form 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: 6rem;
	padding: 1.5rem;
	font-size: 1.6rem;
	background: #dbdddb;
	border-radius: 6px 0 0 6px;
	border: none;
	flex: 1;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form button {
	width: 6rem;
	height: 6rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	background: #606060;
	border-radius: 0 6px 6px 0;	
	margin-left: 0.2rem;
}
#snav > ul > li > .dropPc > .snavModal dl > dd .form button i {
	color: #fff;
	font-size: 2rem;
}

#snav > ul > li > .dropPc > .snavModal dl > .dropSp > a{
	display: flex;
	align-items:center;
	position: relative;
	justify-content: center;
	flex-direction: column;
	font-size: 1.5rem;
	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: #f27e7e;
	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.5rem;	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li {
	width: calc( ( 100% - 6rem ) / 3);
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li > label {
	background: #e7e8e6;
	height: 3.6rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	font-size: 1.4rem;
	margin-bottom: 1.4rem;
	color: #3e3a39;
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li a {
	color: #3e3a39;
	border-bottom: 1px solid #dddddd;
	height: 5rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	font-size: 1.4rem;
}
#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li a::after {
	content: "";
    display: inline-block;
    height: 0.9rem;
    width: 0.9rem;
    border-top: 2px solid #c1c1c1;
    border-right: 2px solid #c1c1c1;
    transform: rotate(45deg);
    margin-right: 0.5rem;
    vertical-align: middle;
    margin-top: -0.2rem;
}
@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: 3rem;
		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: 4rem;
		color: #fff;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: center;
		font-size: 1.5rem;
	}
	#snav > ul.other li, #snav > ul.other li a {
		color: #fff;
	}
	#snav > ul:first-child {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		flex-direction: row;
		border-top: 1px solid #fff;
		border-bottom: 1px solid #fff;
		padding: 2rem 3rem;
	}
	#snav > ul:first-child > li:first-child,
	#snav > ul:first-child > li:nth-child(2),
	#snav > ul:first-child > li:nth-child(3),
	#snav > ul:first-child > li:nth-child(4){
		width: auto;
		border-bottom: none;
	}
	#snav > ul:first-child > li:last-child {
		position: fixed;
		top: 0;
		right: 6rem;
		height: 6rem;
		width: 6rem;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	#snav > ul:first-child > li:last-child .dropPc > label i {
		font-size: 2.4rem;
		margin-right: 0;
		color: #606060;
	}
	#snav > ul:first-child > li:last-child .dropPc > label i + span {
		display: none;
	}
	#snav > ul > li .dropPc > label {
		height: 4rem;
		color: #fff;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: center;
		font-size: 1.5rem;	
	}
	#snav > ul:last-child > li > .dropPc {
		display: block;
	}
	#snav > ul > li > .dropPc > input:checked + .snavModal > .inn {
		padding: 3rem;
	}
	#snav > ul:last-child > li > .dropPc .snavModal {
		position: static;
		top: auto;
		left: auto;
		transform: none;
		background: transparent;
		height: auto;
		opacity: 1;
		visibility: visible;
		overflow: visible;
		max-height: 100%;
		transition: none;
		z-index: 1;	
	}
	#snav > ul:last-child > li > .dropPc > input:checked + .snavModal {
		height: auto;
		max-height: auto;
		width: auto;
		opacity: 1;
		transition: none;
		visibility: visible;
	}
	#snav > ul:last-child > li > .dropPc .snavModal > .inn {
		width: auto;
		padding: 0;
		position: static;
	}
	#snav > ul:last-child > li > .dropPc > input:checked + .snavModal > .inn {
		max-width: auto;
		width: auto;
		margin: 0 auto;
		display: block;
		padding: 0;
	}
	
	#snav > ul:last-child > li > .dropPc > .snavModal > .inn > label {
		display: none;
	}
 	#snav > ul:last-child > li > .dropPc > .snavModal > .inn > label::before,
	#snav > ul:last-child > li > .dropPc > .snavModal > .inn > label::after {
		content: "";
		display: block;
		position: absolute;
		height: 0.2rem;
		width: 100%;
		top: 50%;
		margin-top: -0.1rem;
		background: #fff;
		border-radius: 1px;
		transition: all 0.5s ease;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal > .inn > label::after {
		-webkit-transform: translateY(0) translateX(0) rotate(90deg) scaleX(1);
		transform: translateY(0) translateX(0) rotate(90deg)  scaleX(1);
	}
	#snav > ul:last-child > li > .dropPc > .snavModal > .inn > dl > .dropSp > input:checked + label::after {
		-webkit-transform: translateY(0) translateX(0) rotate(90deg) scaleX(0);
		transform: translateY(0) translateX(0) rotate(90deg) scaleX(0);
	}
	
	#snav > ul:last-child > li > .dropPc > .snavModal dl {
		margin-top: 0;
		color: #fff;		
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dt {
		display: none;
	}
	
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul {
		display: flex;
		justify-content: flex-start;
		flex-direction:column;
		flex-wrap: wrap;
		margin-top: 0px;
		width: 100%;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li {
		width: 100%;
		position: relative;
		margin-left: 0;
		border-top: 1px solid #fff;
		padding-left: 1.5rem;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li:last-child {
		border-bottom: 1px solid #fff;		
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li:first-child {
		border-top: none;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp input + label {
		display: block;
		width: 1.2rem;
		height: 1.2rem;
		position: absolute;
		top: 1.4rem;
		right:1rem;		
	}
 	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp input + label::before,
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp input + label::after {
		content: "";
		display: block;
		position: absolute;
		height: 0.2rem;
		width: 100%;
		top: 50%;
		margin-top: -0.1rem;
		background: #fff;
		border-radius: 1px;
		transition: all 0.5s ease;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp input + label::after {
		-webkit-transform: translateY(0) translateX(0) rotate(90deg) scaleX(1);
		transform: translateY(0) translateX(0) rotate(90deg)  scaleX(1);
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp input:checked + label::after {
		-webkit-transform: translateY(0) translateX(0) rotate(90deg) scaleX(0);
		transform: translateY(0) translateX(0) rotate(90deg) scaleX(0);
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp ul {
		position: relative;
		min-width: 0rem;
		width: 100%;
		padding: 0;
		top: 0;
		display: block;
		overflow: hidden;
		height: 0;
		max-height: 0vh;
		transition: all 0.6s ease;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp ul > li {
		border-top: 1px solid #fff;
		padding-left: 1.5rem;		
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp:hover ul {
		height: 0;
		max-height: 0;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp .dropPc {
		position: static;
		top: auto;
		left: auto;
		right: auto;
		padding: 0;
		background: transparent;
		opacity: 1;
		visibility: visible;
		overflow: visible;
		max-height: 100%;
		transition: none;
		z-index: 1;	
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp input:checked + label + dd > ul,
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp input:checked + label + ul {
		height: auto;
		max-height: none;
	}
	
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li > .dropSp {
		display: flex;
		justify-content: flex-start;
		flex-direction:column;
		flex-wrap: wrap;
		width: 100%;		
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li > .dropSp > a {
		height: 4rem;
		color: #fff;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: flex-start;
		font-size: 1.5rem;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li > .dropSp > a::after {
		display: none;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li > .dropSp label {
		display: block;
		width: 1.2rem;
		height: 1.2rem;
		position: absolute;
		top: 1.4rem;
		right:1rem;
	}
 	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li > .dropSp label::before,
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li > .dropSp label::after {
		content: "";
		display: block;
		position: absolute;
		height: 0.2rem;
		width: 100%;
		top: 50%;
		margin-top: -0.1rem;
		background: #fff;
		border-radius: 1px;
		transition: all 0.5s ease;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li > .dropSp label::before {
		-webkit-transform: translateY(0) translateX(0) rotate(0deg) scaleX(1);
		transform: translateY(0) translateX(0) rotate(0deg)  scaleX(1);
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > ul > li > .dropSp label::after {
		-webkit-transform: translateY(0) translateX(0) rotate(90deg) scaleX(1);
		transform: translateY(0) translateX(0) rotate(90deg)  scaleX(1);
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl dd > 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);
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp label + dd > ul > li {
		border-top: 1px solid #fff;
		padding-left: 1.5rem;		
	}
	#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li a {
		color: #fff;
		height: 4rem;
		display: flex;
		justify-content: flex-start;
		font-size: 1.4rem;
		border-bottom: none;
	}
	#snav > ul > li > .dropPc > .snavModal dl > .dropSp dd > ul > li a::after {
		display: none;
	}
	#snav > ul:last-child > li > .dropPc > .snavModal dl > .dropSp dd > ul > li > label {
		height: 4rem;
		color: #fff;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: center;
		font-size: 1.4rem;
		margin-bottom: 0;
		background: transparent;
		justify-content: flex-start
	}
	#snav > ul:last-child > li:last-child {
		flex-direction: column;
		align-items: stretch;
		border-bottom: none;
	}
	
}

/* -------------------------------
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: 2rem;
}
#gnav > ul > li > .dropSp > a{
	display: flex;
	align-items:center;
	position: relative;
	justify-content: center;
	flex-direction: column;
	font-size: 1.5rem;
	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: #f27e7e;
	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: 9rem;
	left: 0;
	right: 0;
	padding: 3rem 3rem 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 2rem;
	border-left: 1px solid #cccaca;
	width: calc( 100% / 3);
	margin-bottom: 3rem;
}
#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: 1.6rem;
}
#gnav > ul > li > .dropSp .dropPc > ul > li > a.lock::after {
	content: "";
	display: inline-block;
	vertical-align: middle;
	margin-top: -0.4rem;
	margin-left: 0.5rem;
	width: 1.9rem;
	height: 2.1rem;
	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 192 192"><path fill="%233f3236" d="M90 125.12V138a6 6 0 0 0 12 0v-12.88a21 21 0 1 0-12 0ZM96 96a9 9 0 1 1-9 9 9 9 0 0 1 9-9Zm60-36h-27V39a33 33 0 0 0-66 0v21H36a12 12 0 0 0-12 12v84a12 12 0 0 0 12 12h120a12 12 0 0 0 12-12V72a12 12 0 0 0-12-12ZM75 39a21 21 0 0 1 42 0v21H75Zm81 117H36V72h120Z" /></svg>') no-repeat center center / contain;
}

#gnav > ul > li > .dropSp .dropPc > ul > li > a + .dropSp {
	margin-left: 1.5rem;
}
#gnav > ul > li > .dropSp .dropPc > ul > li > a + .dropSp > ul > li > a {
	font-size: 1.4rem;
}
@media screen and (max-width: 810px){
	#gnav {
		padding: 3rem;
	}
	#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: 4rem;
		color: #fff;
		display: flex;
		position: relative;
		padding: 0;
		text-decoration: none;
		width: 100%;
		align-items: flex-start;
		font-size: 1.5rem;
	}
	#gnav > ul > li > .dropSp > a::after {
		display: none;
	}
	#gnav > ul > li > .dropSp label {
		display: block;
		width: 1.2rem;
		height: 1.2rem;
		position: absolute;
		top: 1.4rem;
		right:1rem;
	}
 	#gnav > ul > li > .dropSp label::before,
	#gnav > ul > li > .dropSp label::after {
		content: "";
		display: block;
		position: absolute;
		height: 0.2rem;
		width: 100%;
		top: 50%;
		margin-top: -0.1rem;
		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: 0rem;
		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 1.5rem;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li > a {
		height: auto;
		color: #fff;
		font-size: 1.3rem;
		line-height: 1.5;
		padding: 1rem 0;
		display: flex;
		position: relative;
		text-decoration: none;
		width: 100%;
		align-items: center;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li > a.lock::after {
		background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 192 192"><path fill="%23ffffff" d="M90 125.12V138a6 6 0 0 0 12 0v-12.88a21 21 0 1 0-12 0ZM96 96a9 9 0 1 1-9 9 9 9 0 0 1 9-9Zm60-36h-27V39a33 33 0 0 0-66 0v21H36a12 12 0 0 0-12 12v84a12 12 0 0 0 12 12h120a12 12 0 0 0 12-12V72a12 12 0 0 0-12-12ZM75 39a21 21 0 0 1 42 0v21H75Zm81 117H36V72h120Z" /></svg>') no-repeat center center / contain;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li > .dropSp label {
		display: block;
		width: 1.2rem;
		height: 1.2rem;
		position: absolute;
		top: 1.4rem;
		right:1rem;
	}
 	#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: 0.2rem;
		width: 100%;
		top: 50%;
		margin-top: -0.1rem;
		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 1.5rem;
	}
	#gnav > ul > li > .dropSp .dropPc > ul > li > .dropSp ul > li > a {
		height: 4rem;
		color: #fff;
		font-size: 1.3rem;
		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;
	}
	
}

/* -------------------------------
TITLE
------------------------------- */
h1.title {
	height: 30rem;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 120px;
	font-size: 7.2rem;
	font-family: "ゴシックMB101 L",Gothic MB101 Light;
	text-shadow: 0 0 5px rgba(255,255,255,1),0 0 5px rgba(255,255,255,1),0 0 5px rgba(255,255,255,1);
}
@media screen and (max-width: 810px){
	h1.title {
		height: 14rem;
		margin-top: 70px;
		font-size: 3.6rem;
	}
}

/* -------------------------------
TITLE
------------------------------- */
#title {
	height: 16rem;
	background: url(../images/bg_title01.png) repeat-x center center / cover;
}
.col2 #title {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
}
#title .inn {
	width: 100%;
	height: 100%;
	max-width: 120rem;
	margin:  0 auto;
}
.col2 #title .inn {
	padding-left: 33rem;
}
#title .inn h1 {
	height: 100%;
	font-size: 4rem;
	color: #fff;
	padding: 2rem;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}
@media screen and (max-width: 1200px){
	#title .inn {
		max-width: 100vw;
	}
}
@media screen and (max-width: 920px){
	.col2 #title {
		position: relative;
		left: auto;
		right: auto;
		top: auto;
	}
	.col2 #title .inn {
		padding-left: 0;
	}
}
@media screen and (max-width: 810px){
	#title {
		height: 5rem;
		background: url(../images/bg_title01_s.png) repeat-x center center / cover;
	}
	#title .inn h1 {
		font-size: 2rem;
		color: #fff;
		padding: 1rem;
	}
}
/* -------------------------------
BREAD
------------------------------- */
#bread {
	background: #efefef;
	height: 4rem;
}
.col2 #bread {
	position: absolute;
	left: 0;
	right: 0;
	top: 16rem;
}
#bread nav {
	max-width: 120rem;
	margin:  0 auto;
}
.col2 #bread nav {
	padding-left: 32rem;
}

#bread ul {
	display: flex;
	flex-wrap: nowrap;
	white-space: nowrap;
	padding: 0 1rem;
}
#bread ul li a,
#bread ul li span {
	font-size: 1.4rem;
	line-height: 4rem;
}
#bread ul li:last-child a {
	pointer-events: none;	
}
#bread ul li a::after {
	content: ">";
	display: inline-block;
	margin: 0 0.5em;
}
#bread ul li:last-child a::after {
	content: "";
	display: none;
	margin: 0;	
}
@media screen and (max-width: 1200px){
	#bread nav {
		max-width: 100vw;
	}
}

@media screen and (max-width: 920px){
	.col2 #bread {
		position: relative;
		left: auto;
		right: auto;
		top: auto;
	}
	.col2 #bread nav {
		padding-left: 0;
	}
}
@media screen and (max-width: 810px){
	#bread {
		height: auto;
		padding: 0.5rem 0;
	}
	#bread ul {
		flex-wrap: wrap;
		white-space: normal;
	}
	#bread ul li a,
	#bread ul li span {
		line-height: inherit;
	}
}

/* -------------------------------
CONTENTS
------------------------------- */
#contents {
	width: 100%;
	padding: 0;
	position: relative;
}
#contents.col2 {
	padding-top: 20rem;
}
#contents .colorBoxPink {
	background: #ffeef1;
	padding: 0 1.5rem;
}
#contents .colorBoxGray {
	background: #efefef;
	padding: 0 1.5rem;
}
#contents .colorBoxGreen {
	background: #d0eae7;
	padding: 0 1.5rem;
}

@media screen and (max-width: 920px){
	#contents.col2 {
		padding-top: 0;
		padding-left: 0;
	}
}

@media screen and (max-width: 810px){
}
/* -------------------------------
CONT WRAP
------------------------------- */
#contents #contWrap {
	max-width: 120rem;
	margin: 0 auto;
	padding: 0 1rem;
}

#contents.col2 #contWrap {
	display: flex;
	flex-wrap: wrap;
}
@media screen and (max-width: 920px){
	#contents #contWrap {
		padding: 0;
	}
}
/* -------------------------------
SUBNAV
------------------------------- */
#subNav {
	position: relative;
	margin-top: -10rem;
	margin-right: 5rem;
	width: 28rem;
	z-index: 2;
}
#subNav .inn {
	border: 1px solid #ccc;
	background: rgba(255,255,255,0.8);
	padding: 0.4rem;
}
#subNav dl dt {
	height: 4rem;
	background: #595858;
	text-align: center;
}
#subNav dl dt label {
	line-height: 4rem;
	font-weight: bold;
	color: #fff;
	font-size: 1.6rem;
	height: 100%;
	display: block;
}
#subNav dl dt label::after {
	display: none;
}
#subNav dl > input {
	display: none;
}
#subNav dl dd {
	padding: 1rem;
}
#subNav dl dd .search {
}
#subNav dl dd .search form {
	display: flex;
	align-items: center;
}
#subNav dl dd .search form input.txt {
	border: none;
	width: 21rem;
	height: 3rem;
	border-radius: 0.5rem;
	border: 1px solid #b2b2b2;
}
#subNav dl dd .search form input.btn {
	width: 2.6rem;
	height: 2.6rem;
	border: none;
	background: url(../images/ico_search02.png) no-repeat center center / contain;
	margin-left: 1rem;
	cursor: pointer;
}
#subNav dl dd .kana {
	display: flex;
	flex-wrap: wrap;
}

#subNav dl dd .kana li {
	width: calc(100%/3);
	padding: 0.5rem 1.2rem;
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
#subNav dl dd .kana li {
	width: calc(99%/3);
}
}
#subNav dl dd .kana li a {
	font-size: 1.6rem;
}
#subNav dl dd .kana li a::before {
	content: "";
	display: inline-block;
	height: 0.4rem;
	width: 0.4rem;
	border-top: 3px solid #ffaab0;
	border-right: 3px solid #ffaab0;
	transform: rotate(45deg);
	margin-right: 0.5rem;
	vertical-align: middle;
	margin-top: -0.2rem;
}
#subNav dl dd .cat {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
}
#subNav dl dd .cat li {
	width: 100%;
	padding: 0.5rem 1.2rem;
}
#subNav dl dd .cat li a {
	font-size: 1.6rem;
	text-indent: -0.7em;
	display: block;
}
#subNav dl dd .cat li a::before {
	content: "";
	display: inline-block;
	height: 0.4rem;
	width: 0.4rem;
	border-top: 3px solid #ffaab0;
	border-right: 3px solid #ffaab0;
	transform: rotate(45deg);
	margin-right: 0.5rem;
	vertical-align: middle;
	margin-top: -0.2rem;
}
#subNav dl dd .menu {
	margin: 0 -1.4rem;
}
#subNav dl dd .menu li {
	width: 100%;
	padding: 1.5rem 1.5rem 1.5rem 2.7rem;
	border-top: 1px solid #ccc;
}
#subNav dl dd .menu li:first-child {
	border-top: none;
}
#subNav dl dd .menu li:last-child {
	margin-bottom: -1.4rem;
}
#subNav dl dd .menu li.current {
	background: #ffdce1;
}
#subNav dl dd .menu li a {
	font-size: 1.6rem;
	text-indent: -0.7em;
	display: block;
}
#subNav dl dd .menu li a::before {
	content: "";
	display: inline-block;
	height: 0.4rem;
	width: 0.4rem;
	border-top: 3px solid #ffaab0;
	border-right: 3px solid #ffaab0;
	transform: rotate(45deg);
	margin-right: 0.5rem;
	vertical-align: middle;
	margin-top: -0.2rem;
}

#subNav dl dd .menu li ul {
	border-top: 1px solid #ccc;
	background: #fff;
	margin: 1.5rem -1.5rem 0 -2.7rem;
}
#subNav dl dd .menu li ul li:last-child {
	margin-bottom: -1.5rem;
}
#subNav dl dd .menu li ul li a{
	margin-left: 1.5rem;
}

#subNav ul.other {
	margin: 0 -0.4rem;
}
#subNav ul.other li {
	width: 100%;
	padding: 1.5rem 1.5rem 1.5rem 2.7rem;
	border-top: 1px solid #ccc;
}
#subNav ul.other li:last-child {
	margin-bottom: -0.4rem;
}
#subNav ul.other li.current {
	background: #ffdce1;
}
#subNav ul.other li a {
	font-size: 1.6rem;
	text-indent: -0.7em;
	display: block;
}
#subNav ul.other li a::before {
	content: "";
	display: inline-block;
	height: 0.4rem;
	width: 0.4rem;
	border-top: 3px solid #ffaab0;
	border-right: 3px solid #ffaab0;
	transform: rotate(45deg);
	margin-right: 0.5rem;
	vertical-align: middle;
	margin-top: -0.2rem;
}
#subNav .bnrArea {
	margin-top: 3.5rem;;
	padding-top: 1.5rem;
	border-top: 1px solid #ccc;
}
#subNav .bnrArea ul li {
	margin-top: 1.5rem;
}
#subNav .bnrArea ul li a img {
	width: 100%;	
}

@media screen and (max-width: 920px){
	#subNav {
		position: relative;
		left: auto;
		top: auto;
		width: 100%;
		margin-top: 0;
		margin-right: 0;
	}
	#subNav .inn {
		border: none;
		background: #fff;
		padding: 2rem 3.5rem;
		height: 8rem;
		display: flex;
		justify-content: space-between;
		overflow: visible;
		position: relative;
		z-index: 2;
	}
	#subNav dl {
		width: calc((100%/3) - 1rem );
	}
	#subNav dl:only-child {
		width: 100%;
		display: flex;
		flex-direction: column;
		align-items: flex-end;
	}
	#subNav dl dt {
		height: 4rem;
		line-height: 4rem;
		font-weight: bold;
		color: #fff;
		font-size: 1.6rem;
		background: #595858;
		text-align: center;
		position: relative;
	}
	#subNav dl:only-child dt {
		width: 12rem;
	}
	#subNav dl dt label::after {
		content: "";
		display: block;
		position: absolute;
		border-right: 3px solid #fff;
		border-bottom: 3px solid #fff;
		height: 0.7rem;
		width: 0.7rem;
		top: 50%;
		right: 1rem;
		margin-top: -0.7rem;
		transform: rotate(45deg);
		transition: all 0.4s ease;
	}
	#subNav dl input:checked + dt label::after {
		transform: rotate(225deg) translateX(-3.5px)translateY(-4px);
	}
	#subNav dl dd {
		height: 0;
		margin-top: 1.5rem;
		position: relative;
		max-height: 0vh;
		transition: all 0.4s ease;
		background: rgba(255,255,255,0.95);
		padding: 0;
		border: 1px solid #fff;
	}
	#subNav dl dd::after {
		content: "";
		position: absolute;
		display: block;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 0 6px 0px 6px;
		border-color: transparent transparent #595858 transparent;
		bottom:100%;
		left: 50%;
		margin-left: -0.6rem;
		transition: all 0.4s ease;
	}
	#subNav dl:only-child dd::after {
		left: auto;
		margin-left: 0;
		right: 6rem;
		margin-right: -0.6rem;
	}
	#subNav dl input:checked + dt + dd {
		height: auto;
		max-height: 100vh;
		border: 1px solid #ccc;
	}
	#subNav dl input:checked + dt + dd::after {
		border-style: solid;
		border-width: 0 6px 10px 6px;
		border-color: transparent transparent #595858 transparent;
	}
	#subNav dl dd .search {
		display: none;
		padding: 1.5rem 0.5rem;
	}
	#subNav dl input:checked + dt + dd .search {
		display: block;
		padding: 2.5rem 1.5rem;
	}
	#subNav dl dd .search form input.txt {
		border: none;
		width: 100%;
		height: 3rem;
		border-radius: 0.5rem;
		border: 1px solid #b2b2b2;
	}
	#subNav dl dd .search form input.btn {
		width: 2.6rem;
		height: 2.6rem;
		border: none;
		background: url(../images/ico_search02.png) no-repeat center center / contain;
		margin-left: 1rem;
		cursor: pointer;
	}
	#subNav dl dd .kana {
		flex-wrap: wrap;
		padding: 1rem;
		display: none;
	}
	#subNav dl input:checked + dt + dd .kana {
		display: flex;
	}
	#subNav dl dd .cat {
		display: none;
		flex-wrap: wrap;
		flex-direction: column;
		padding: 1rem;
	}
	#subNav dl input:checked + dt + dd .cat {
		display: flex;
	}
	#subNav dl dd .cat li {
		width: 100%;
		padding: 0.5rem 1.2rem;
	}
	#subNav dl dd .cat li a {
		font-size: 1.6rem;
		text-indent: -0.7em;
		display: block;
	}
	#subNav dl dd .cat li a::before {
		content: "";
		display: inline-block;
		height: 0.4rem;
		width: 0.4rem;
		border-top: 3px solid #ffaab0;
		border-right: 3px solid #ffaab0;
		transform: rotate(45deg);
		margin-right: 0.5rem;
		vertical-align: middle;
		margin-top: -0.2rem;
	}
	#subNav dl dd .menu {
		display: none;
		flex-wrap: wrap;
		flex-direction: column;
		padding: 1rem;
		margin: 0;
	}
	#subNav dl input:checked + dt + dd .menu {
		display: flex;
	}
	#subNav dl dd .menu li {
		width: 100%;
		padding: 0.5rem 1.2rem;
		margin: 0;
		border-top: none;
	}
	#subNav dl dd .menu li:last-child {
		margin-bottom: 0;
	}
	#subNav dl dd .menu li.current {
		background: none;
	}
	#subNav dl dd .menu li a {
		font-size: 1.6rem;
		text-indent: -0.7em;
		display: block;
	}
	#subNav dl dd .menu li a::before {
		content: "";
		display: inline-block;
		height: 0.4rem;
		width: 0.4rem;
		border-top: 3px solid #ffaab0;
		border-right: 3px solid #ffaab0;
		transform: rotate(45deg);
		margin-right: 0.5rem;
		vertical-align: middle;
		margin-top: -0.2rem;
	}
	#subNav ul.other {
		display: none;
	}
	#subNav .bnrArea {
		display: none;
	}
}
@media screen and (max-width: 810px){
	#subNav .inn {
		padding: 0;
		background: #ccc;
		height: 4.4rem;
		z-index: 2;
	}
	#subNav dl {
		width: calc((100%/3) - 1px );
	}
	#subNav dl:only-child {
		width: 100%;
		display: block;
	}
	#subNav dl dt {
		height: 4.4rem;
		line-height: 4.4rem;
		font-size: 1.4rem;
	}
	#subNav dl:only-child dt {
		width: 100%;
	}
	#subNav dl dt label {
		font-size: 1.4rem;
		line-height: 3.2rem;
		position: relative;
	}
	#subNav dl:only-child dt label {
		font-size: 1.4rem;
		line-height: 4.4rem;
		position: relative;
	}
	#subNav dl dt label::after {
		top: auto;
		left: 50%;
		bottom: 0.8rem;
		right: auto;
		margin-top: 0;
		transition: all 0.4s ease;
	}
	#subNav dl:only-child dt label::after {
		position: absolute;
		top: 50%;
		left: auto;
		bottom: 0.8rem;
		right: 1rem;
		margin-top: -0.7rem;
		transition: all 0.4s ease;
	}
	
	#subNav dl input:checked + dt label::after {
		transform: rotate(225deg) translateX(-3.5px)translateY(-4px);
	}
	#subNav dl dd {
		height: 0;
		margin-top: 1.5rem;
		position: absolute;
		width: 100vw;
		left:0;
		right: 0;
		max-height: 0vh;
		transition: all 0.4s ease;
		background: rgba(255,255,255,0.95);
		padding: 0;
		border: none;
	}
	#subNav dl dd::after {
		bottom:100%;
	}
	#subNav .inn dl:nth-child(1) dd::after {
		left: calc(50%/3);
		margin-left: -0.3rem;
	}
	#subNav .inn dl:nth-child(2) dd::after {
		left: 50%;
		margin-left: -0.2rem;
	}
	#subNav .inn dl:nth-child(3) dd::after {
		left: auto;
		right: calc(50%/3);
		margin-left: 0;
		margin-right: -1.1rem;
	}
	#subNav .inn dl:only-child dd::after {
		left: 50%;
		margin-left: -0.2rem;
	}
	#subNav dl dd .kana a {
		font-size: 1.5rem;
	}
	#subNav dl dd .cat li a {
		font-size: 1.5rem;
	}
}

/* -------------------------------
MAIN COL
------------------------------- */
#mainCol {
	flex: 1;
	padding-top: 3rem;
}
.col2 #mainCol {
	overflow: hidden;
}
#mainCol .sub {
	font-size: 1.5rem;
	margin-bottom: 1.5rem;
	display: block;
}
#mainCol article > p.summary,
#mainCol article .inn > p.summary {
	text-align:left !important;
}
#mainCol article h2 {
	font-size: 3.6rem;
	padding-bottom: 1.5rem;
	line-height: 1;
	position: relative;
	margin-bottom: 4rem;
}
#mainCol article h2::before {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 3px;
	background: #d6d6d6;
}
#mainCol article h2::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	height: 3px;
	width: 11.5rem;
	background: #ffaab0;
}
#mainCol .classify {
	font-size: 1.5rem;
	margin-bottom: 5rem;
	display: inline-block;
	border: 1px solid #717272;
	padding:  0.5rem;
	line-height: 1;
	margin-top: -2rem;
	vertical-align: middle;
}

#mainCol article h3 {
	font-size: 2.7rem;
	text-align: center;
	position: relative;
	padding-bottom: 0.5rem;
	margin-bottom: 2rem;
}
#mainCol article h3::after {
	content: "";
	display: block;
	position: absolute;
	width: 10rem;
	height: 0.3rem;
	background: #b2b2b2;
	left: 50%;
	bottom: 0;
	margin-left: -5rem;
}
#mainCol article h3 span {
	display: block;
	font-size: 0.8em;
}
#mainCol article .movWrap {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 3rem;
	margin-bottom: 3rem;
}
@media screen and (max-width: 920px){
	#mainCol {
		flex: auto;
	}
	#mainCol .sub {
		margin-left: 3.5rem;
		margin-right: 3.5rem;
	}
	#mainCol article h2 {
		margin-left: 3.5rem;
		margin-right: 3.5rem;
	}
	#mainCol article h3 {
		margin-left: 3.5rem;
		margin-right: 3.5rem;
	}
	#mainCol .classify {
		margin-left: 3.5rem;
	}
}
@media screen and (max-width: 810px){
	#mainCol {
		width: 100%;
		padding-top: 2rem;
	}
	#mainCol article .sub {
		font-size: 1rem;		
		margin-bottom: 1rem;
		margin-left: 1.5rem;
		margin-right: 1.5rem;
	}
	#mainCol article h2 {
		font-size: 2.2rem;
		padding-bottom: 1.5rem;
		line-height: 1;
		position: relative;
		margin-bottom: 1.5rem;
		margin-left: 1.5rem;
		margin-right: 1.5rem;
	}
	#mainCol article h2::before {
		height: 0.2rem;
	}
	#mainCol article h2::after {
		height: 0.2rem;
		width: 5.5rem;
	}
	#mainCol article .classify {
		font-size: 1.4rem;
		margin: -0.5em 1.5rem 2rem;
	}
	#mainCol article h3 {
		font-size: 1.7rem;
		padding-bottom: 0.5rem;
		margin-bottom: 2rem;
		margin-left: 1.5rem;
		margin-right: 1.5rem;
	}
	#mainCol article h3::after {
		width: 7rem;
		height: 0.2rem;
		margin-left: -3.5rem;
	}
	
	#mainCol article .movWrap {
		width: 100%;
		position: relative;
		padding-top: 90.57%;
	}
	#mainCol article .movWrap iframe {
		position: absolute;
		top: 0;
		right: 0;
		width: 100% !important;
		height: 100% !important;
	}
	#mainCol article .movWrap .h5_player {
		position: absolute !important;
		top: 0;
		right: 0;
		width: 100% !important;
		height: 100% !important;
	}
	.h5_player .player_main {
		position: absolute !important;
		top: 0;
		right: 0;
		width: 100% !important;
		height: 100% !important;
	}
	.h5_player .video_main {
		width: 100% !important;
		height: 100% !important;
	}	
}
/* -------------------------------
FOOTER
------------------------------- */
footer {
	width: 100%;
	margin-top: 8rem !important;
	border-top: none !important;
}
footer #contact {
	background: #ffaab0;
	padding: 5rem 0 7rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	display: none !important;
}
footer #contact::before {
	content: "";
	display: inline-block;
	width: 5.5rem;
	height: 4rem;
	background: url(../images/ico_inquiry02.png) no-repeat center center / contain;
}
footer #contact p {
	margin-top: 4rem;
	font-size: 2.7rem;
	color: #fff;
}
footer #contact a {
	border: 2px solid #fff;
	margin-top: 4rem;
	font-size: 2.7rem;
	width: 100%;
	text-align: center;
	text-decoration: none;
	max-width: 42rem;
	height: 7rem;
	line-height: 7rem;
	color: #fff;
	background: #ffaab0;
	position: relative;
	transition: all 0.4s ease;
}
footer #contact a:hover {
	color: #ffaab0;
	background: #fff;
}
footer #contact a::after {
	content: "";
	display: block;
	width: 2.9rem;
	height: 2.9rem;
	background: url(../images/ico_arrow03.png) no-repeat center center / contain;
	position: absolute;
	top: 50%;
	right: 1rem;
	margin-top: -1.45rem;
}
footer #fnav {
	background: #ededed;
	position: relative;
	padding: 7rem 0 4rem;
}
footer #fnav #btnReturn {
	position: absolute;
	top: -3.5rem;
	left: 50%;
	margin-left: -3.5rem;
}
footer #fnav #btnReturn a {
	display: block;
	width: 7rem;
	height: 7rem;
	background: url(../images/btn_return01.png) no-repeat center center / contain;
	transition: all 0.4s ease;
}
footer #fnav #btnReturn a:hover {
	background: url(../images/btn_return01_h.png) no-repeat center center / contain;
}
footer #fnav nav {
	max-width: 120rem;
	margin: 0 auto;
}
footer #fnav nav::after {
	content: "";
	display: block;
	clear: both;	
}
footer #fnav nav > ul {
	padding: 0 5rem;
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	max-height: 38rem;
	height: 38rem;
}
footer #fnav nav > ul::after {
	content: "";
	display: block;
	clear: both;	
}

footer #fnav nav > ul > li {
	margin: 0 1rem;
	line-height: 1;
}
footer #fnav nav > ul > li:nth-child(1) {
	flex: 100%;
}
footer #fnav nav > ul > li > a {
	display: inline-block;
	font-size: 1.6rem;
	font-weight: bold;
	margin-bottom: 2rem;
}
footer #fnav nav > ul > li > ul > li {
	margin-bottom: 1.2rem;
	line-height: 1;
}
footer #fnav nav > ul > li > ul > li:last-child {
	margin-bottom: 2rem;
}
footer #fnav nav > ul > li > ul > li > a {
	font-size: 1.5rem;
	display: inherit;
}
@media screen and (max-width: 1200px){
	footer #fnav {
		padding: 5.83vw 0 3.33vw;
	}
	footer #fnav nav > ul {
		padding: 0 4.167vw;
		height: calc( 26000vw / 1100);
	}
	footer #fnav nav > ul > li {
		margin: 0 0.83vw;
	}
	footer #fnav nav > ul > li > a {
		font-size: 1.33vw;
		margin-bottom: 1.67vw;
	}
	footer #fnav nav > ul > li > ul > li {
		margin-bottom: 1vw;
	}
	footer #fnav nav > ul > li > ul > li:last-child {
		margin-bottom: 1.67vw;
	}
	footer #fnav nav > ul > li > ul > li > a {
		font-size: 1.25vw;	
	}
}
footer #relation {
	background: #d3d3d3;
}
footer #relation .inn {
	max-width: 120rem;
	padding: 5rem 5rem 4rem;
	margin: 0 auto;
}
footer #relation .inn h3 {
	font-size: 2.7rem;
	text-align: center;
}
footer #relation ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
footer #relation ul li {
	width: calc(30000% / 1100);
	margin-top: 5rem;
}
footer #relation ul li a {
	display: block;
}
footer #relation ul li a img {
	width: 100%;
	vertical-align: bottom;
}

footer aside {
	background: #ffaab0;
	height: 6rem;
	line-height: 6rem;
}
footer aside .inn {
	display: flex;
	justify-content: space-between;
	align-items: center;
	max-width: 120rem;
	margin: 0 auto;
}
footer aside nav {
}
footer aside nav ul {
	display: flex;
	padding: 0 5rem;
}
footer aside nav ul li {
	margin-right: 4rem;
}
footer aside nav ul li a {
	font-size: 1.6rem;
	color: #fff;
}
footer aside .sns {
	display: flex;
}
footer aside .sns ul {
	display: flex;
	padding: 0 5rem;
}
footer aside .sns ul li {
	margin-left: 2rem;
}
footer aside .sns ul li img {
	width: 36px;
	display: block;
}
footer #copyright {
	padding: 1rem 0 1.5rem;
	display: flex;
	justify-content: center;
	flex-direction: column;
}
footer #copyright address {
	font-size: 1.4rem;
	text-align: center;
}
footer #copyright small {
	font-size: 1.4rem;
	font-family: Arial;
	margin-top: 1rem;
	text-align: center;
}
@media screen and (max-width: 810px){
	footer {
		margin-top: 2rem;
	}
	footer #contact {
		padding: 1.5rem 0.5rem 3rem;
	}
	footer #contact::before {
		width: 2.5rem;
		height: 1.8rem;
	}
	footer #contact p {
		margin-top: 0.7rem;
		font-size: 1.4rem;
	}
	footer #contact a {
		border: 1px solid #fff;
		margin-top: 1rem;
		font-size: 1.7rem;
		width: 100%;
		text-align: center;
		text-decoration: none;
		max-width: 23rem;
		height: 4rem;
		line-height: 4rem;
		transition: none;
	}
	footer #contact a:hover {
		color: #ffaab0;
		background: #fff;
	}
	footer #contact a::after {
		content: "";
		display: block;
		width: 2rem;
		height: 2rem;
		right: 0.5rem;
		margin-top: -1rem;
	}

	footer #fnav {
		padding: 0;
		
	}
	footer #fnav #btnReturn {
		top: -1.75rem;
		left: 50%;
		margin-left: -1.75rem;
	}
	footer #fnav #btnReturn a {
		width: 3.5rem;
		height: 3.5rem;
		transition: none;
	}
	footer #fnav nav {
		display: none;
	}

	footer #relation .inn {
		padding: 3.5rem 0.5rem 1.3rem;
	}
	footer #relation .inn h3 {
		font-size: 1.5rem;
	}
	footer #relation ul {
		margin-top: 1.5rem;
	}
	footer #relation ul li {
		width: calc(50% - 0.5rem);
		margin-bottom: 1.2rem;
		margin-top: 0;
	}	
	footer aside {
		background: #ffaab0;
		height: auto;
	}
	footer aside .inn {
		display: block;
	}
	footer aside nav ul {
		flex-wrap: wrap;
		flex-direction: column;
		padding: 0;
	}
	footer aside nav ul li {
		margin-right: 0;
		margin-bottom: 0;
		height: 4rem;
		line-height: 4rem;
		padding: 0 1rem;
		border-bottom: 1px solid #fff;
	}
	footer aside nav ul li a {
		font-size: 1.3rem;
		color: #fff;
	}
	footer aside .sns {
		padding: 15px 0;
		width: 100%;
	}
	footer aside .sns ul {
		width:100%;
		justify-content: center;
	}
	footer aside .sns ul li {
		margin: 0 10px;
	}
	footer #copyright {
		padding: 0.5rem 0;
		display: flex;
		justify-content: center;
		flex-direction: column;
	}
	footer #copyright address {
		font-size: 1.1rem;
	}
	footer #copyright small {
		font-size: 1rem;
		margin-top: 0.5rem;
	}

}

footer + .acms-container {
	margin-top: 80px;
}
footer + .acms-container #adminBox, .acms-admin-box {
	position: fixed;
	margin: 0;
	bottom:0;
	left:0;
	right:0;
	z-index: 999;
	margin-bottom: 0 !important;
}
.js-lazy-load {
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px);
    opacity: 0;
    -webkit-transition: opacity .8s cubic-bezier(0.5, 0, 0, 1) .1s,-webkit-transform .9s cubic-bezier(0.5, 0, 0, 1) .1s;
    transition: opacity .8s cubic-bezier(0.5, 0, 0, 1) .1s,-webkit-transform .9s cubic-bezier(0.5, 0, 0, 1) .1s;
    transition: opacity .8s cubic-bezier(0.5, 0, 0, 1) .1s,transform .9s cubic-bezier(0.5, 0, 0, 1) .1s;
    transition: opacity .8s cubic-bezier(0.5, 0, 0, 1) .1s,transform .9s cubic-bezier(0.5, 0, 0, 1) .1s,-webkit-transform .9s cubic-bezier(0.5, 0, 0, 1) .1s
}

.js-lazy-load.loading {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    opacity: 1
}
