@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;
	font-size: 1.6rem;
	color: #000;
}
/* -------------------------------
LAYOUT
------------------------------- */
* {
	word-break: break-all;
	word-wrap: break-word;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
html,
body {
	height: 100%;
	-webkit-text-size-adjust: 100%;
}
body.boxer-open {
	overflow: hidden;
}
#container {
	width: 100%;
	min-height: 100%;
	height: auto !important;
	height: 100%;
	position: relative;
	margin: 0 auto;
	overflow-anchor: none;
	overflow-x: hidden;
}
.boxer-open #container {
}

@media screen and (max-width: 768px){
	#container {
		padding-top: 6rem;
	}
}
.pc {
}
.sp {
	display: none;
}
@media screen and (max-width: 768px){
	.pc {
		display: none;
	}
	.sp {
		display: block;
	}
}
/* -------------------------------
FONT
------------------------------- */
/* -------------------------------
FONT
------------------------------- */
.font_mb_l{font-family: Gothic MB101 Light !important;}
.font_mb_r{font-family: Gothic MB101 Regular !important;}
.font_mb_m{font-family: Gothic MB101 Medium !important;}
.font_mb_b{font-family: Gothic MB101 Bold !important;}
.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: 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: #4E9D29;
	outline: none !important;
	text-decoration: none;
}
a:visited {
	color: #4E9D29;
	text-decoration: none;
}
a:hover {
	color: #4E9D29;
	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: 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; }
.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; }
.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 */
.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; }
/* 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;
}
.picLeft,
.picRight { 
	display: flex;
	flex-wrap: wrap;
}
.picLeft {
	flex-direction: row;
}
.picRight { 
	flex-direction: row-reverse;
}
.picLeft .pic {
	margin-right: 2rem;
}
.picRight .pic {
	margin-left: 2rem;
}
.picLeft .txt,
.picRight .txt {
	flex: 1;
}
.picCenter {
	text-align: center;
}
@media screen and (max-width: 768px){
	.picLeft,
	.picRight,
	.picCenter { 
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		align-items: center;
	}
	.picLeft .pic {
		margin-right: 0;
	}
	.picRight .pic {
		margin-left: 0;
	}
	.picLeft .pic,
	.picRight .pic {
		margin-bottom: 3rem;
	}
}
.disc {
	margin-top: 1rem;
}
.disc li {
	font-size: 2rem;
	margin-top: 0.5rem;
	list-style: disc;
	margin-left: 2rem;
}
@media screen and (max-width: 768px){
	.floatLeft .txt p,
	.floatRight .txt p {
		font-size: 1.4rem;
	}
}


@media screen and (max-width: 991px){
html {
	min-width: 100%;
}
body {
	min-width: 100%;
	overflow-x: hidden;
}
}
/* -------------------------------
HEADER
------------------------------- */
header{
	width: 100%;
	height: 5rem;
	background: #fff;
	z-index: 100;
	top: 0;
}
header .inn {
	width: 100%;
	max-width: 1200px;
	height: 100%;
	padding: 0 4rem;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
}
header .logo {
	display: flex;
	align-items: center;
	margin-right: 3.5rem;
}
header .logo a {
	display: flex;
	align-items: center;
}
header .links {
	flex: 1 0 auto;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: space-between;
}
header #navBtn {
	display: none;
}
@media screen and (max-width: 1200px){
	header{
		height: calc( 5000vw / 1200 );
	}
	header .inn {
		padding: 0 calc( 4000vw / 1200 );
	}
	header .logo {
		width: calc( 19600vw / 1200 );
		margin-right: 3500vw / 1200 );
	}
	header .logo img {
		width: 100%;
	}
	header .links .btm {
		height: calc( 4200vw / 1200 );
	}
}
@media screen and (max-width: 768px){
	header {
		height: 6rem;
		position: fixed;
	}
	header .inn {
		flex-direction: column;
		align-items: flex-start;
		padding: 1.5rem;
		background: #fff;
		z-index: 100;
	}
	header .logo {
		width: 22rem;
		margin-right: 0;
	}
	header .logo img {
		width: 100%;
	}
	header .links { 
		position: absolute;
		width: 100%;
		top: 6rem;
		left: 100%;
		transition: all 0.4s ease;
		background: #fff;
	}
	header.open .links {
		display: block;
		left:0;
		height: auto;
	}
	header #navBtn {
		cursor: pointer;
		display: block;
		padding:  16px;
		position: absolute;
		bottom: 0;
		right: 0;
		top: 0;
		text-decoration: none;
	}
 	header #navBtn p {
		font-size: 1rem;
		white-space: nowrap;
		text-align: center;
		font-family: Gothic MB101 Medium;
	}
 	header #navBtn span {
		display: block;
		height: 4px;
		width: 100%;
		background: #666;
		border-radius: 2px;
		transition: all 0.5s ease;
	}
	header #navBtn span:nth-of-type(2),
	header #navBtn span:nth-of-type(3) {
		margin-top: 5px;
	}
	header.open #navBtn span:nth-of-type(1) {
		-webkit-transform: translateY(9px) translateX(0) rotate(45deg);
		transform: translateY(9px) translateX(0) rotate(45deg);
	}
	header.open #navBtn span:nth-of-type(2) {
		margin-top: 5px;
		opacity: 0;
		-webkit-transform: translateY(9px);
		transform: translateY(9px);
	}
	header.open #navBtn span:nth-of-type(3) {
		-webkit-transform: translateY(-9px) translateX(0) rotate(-45deg);
		transform: translateY(-9px) translateX(0) rotate(-45deg);
	}
	#bgModal {
		display: none;
		background: rgba(0, 0, 0, 0.6);
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 10;
	}
}
/* -------------------------------
GNAV
------------------------------- */
#gnav {
	height: 100%;
	margin-right: 24rem;
}
#gnav ul {
	height: 100%;
	display: flex;
	justify-content: space-around;
}
#gnav ul li {
	line-height: 1;
}
#gnav ul li a{
	height: 100%;
	color: #000;
	display: flex;
	align-items:center;
	justify-content: center;
	position: relative;
	flex-direction: column;
	font-size: 1.6rem;
	font-family:-apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", sans-serif;
	text-decoration: none;
	padding: 0.3rem 0;
}
#gnav ul li a::after {
	content: "";
	display: block;
	height: 2px;
	width: 100%;
	bottom: 50%;
	left: 0;
	right: 0;
	margin-bottom: -0.6em;
	position: absolute;
	background: #666;
	transform: scaleX(0);
	transition: all 0.2s ease;
}
#gnav ul li a:hover::after {
	transform: scaleX(1);
}
#gnav ul li a span {
	display: block;
	text-align: center;
	position: relative;
	font-size: 1.2rem;
	color: #007632;
	margin-bottom: 0.5rem;
}
@media screen and (max-width: 1200px){
	#gnav {
		margin-right: calc( 24000vw / 1200 );
	}
	#gnav ul li a{
		font-size: calc( 1800vw / 1200 );
	}
	#gnav ul li a span {
		font-size: calc( 1200vw / 1200 );
	}
}
@media screen and (max-width: 768px){
	#gnav {
		margin-right: 0;
	}
	#gnav > ul {
		display: flex;
		justify-content: flex-start;
		flex-direction:column;
		flex-wrap: wrap;
		margin-top: 0px;
		width: 100%;
		background: #fff;
		border-left: 0;
	}
	#gnav > ul > li {
		width: 100%;
		position: relative;
		border-top: 1px solid #ccc;
		border-right: none;
		padding: 0;
	}
	#gnav > ul > li > a {
		color: #4B4948;
		display: block;
		position: relative;
		padding: 1.5rem;
		text-decoration: none;
		width: 100%;
		font-size: 1.4rem;
	}
	#gnav > ul > li > a::before {
		content: "";
		display: inline-block;
		height: 0.4rem;
		width: 0.4rem;
		border-top: 3px solid #4E9D29;
		border-right: 3px solid #4E9D29;
		transform: rotate(45deg);
		margin-right: 1rem;
		vertical-align: middle;
		margin-top: -0.2rem;
	}
	#gnav > ul > li > a::after {
		display: none;
	}
	#gnav > ul > li > a span {
		display: none;
	}
}

/* -------------------------------
COMMON
------------------------------- */
section {
	position: relative;
}
section .next {
	position: absolute;
	left: 50%;
	bottom: -2rem;
	margin-left: -2rem;
	z-index: 2;
}

/* -------------------------------
SNS
------------------------------- */
#sns {
	width: 100%;
	max-width: 120rem;
	margin: 5rem auto 0;
}
#sns ul {
	display: flex;
	justify-content: flex-end;
	align-items: stretch;
}
#sns ul li {
	margin-left: 1rem;
	line-height: 0;
}
.fb_iframe_widget {
	line-height: 0 !important;
}
@media screen and (max-width: 768px){
	#sns {
		padding: 0 1.5rem;
	}
}
/* -------------------------------
FOOTER
------------------------------- */
footer {
	width: 100%;
	background: #9a9a9a;
	padding: 2rem 0 1rem;
	position: relative;
	margin-top: 6rem;
}
footer .return {
	width: 100%;
	max-width: 120rem;
	margin: 0 auto;
	position: relative;
	text-align: right;
	height: 0;
}
footer .return a {
	position: absolute;
	top: -5rem;
}
footer #fnav {
}
footer #fnav ul {
	display: flex;
	justify-content: center;
}
footer #fnav ul li {
	margin: 0 1rem;
	color: #fff;
}
footer #fnav ul li a {
	color: #fff;
}
footer #copyright {
	font-size: 1.4rem;
	color: #fff;
	font-family:-apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", sans-serif;
	margin-top: 2.5rem;
	text-align: center;
	display: block;
}
footer #copyright br {
	display: none;
}
@media screen and (max-width: 768px){
	footer {
		padding: 0 0 1rem;
	}
	footer #fnav {
		background: #fff;
	}
	footer #fnav ul {
		display: block;
	}
	footer #fnav ul li {
		margin: 0;
		padding: 1rem 2rem;
		border-top: 1px solid #ccc;
		color: #000;
	}
	footer #fnav ul li.slush {
		display: none;
	}
	footer #fnav ul li a {
		color: #000;
	}
	footer #fnav ul li a {
	}
	footer #copyright {
		font-size: 1.2rem;
		color: #fff;
		font-family:-apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", sans-serif;
		margin-top: 1rem;
		text-align: center;
		display: block;
	}
	footer #copyright br {
		display: inherit;
	}
}

