@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@500&family=Roboto&display=swap');

.g-10, .gx-10 {
    --bs-gutter-x: 6rem;
}

/* -------------------------------
FONT
------------------------------- */
html { font-size: 62.5%; }
body {
	font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro','メイリオ', 'Meiryo', '游ゴシック', 'Yu Gothic', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	line-height: 1.8;
	font-size: 16px;
	font-size: 1.6rem;
	color: #4F2121;
}
/* -------------------------------
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,
.sp02 {
	display: none !important;
}
@media screen and (max-width: 810px){
	.sp {
		display: inline;
	}
	.sp02 {
		display: block !important;
	}
	.pc {
		display: none !important;
	}
}
/* -------------------------------
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: 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: #4F2121;
	outline: none !important;
	text-decoration: none;
}
a:visited {
	color: #4F2121;
	text-decoration: none;
}
a:hover {
	color: #4F2121;
	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; }
.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; }
.mt60 { margin-top: 6.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; }
.alignJustify { text-align: justify!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;
}

@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: 100;
	position: fixed;
	top: 0;
}
header > .inn {
	width: 100%;
	max-width: 132rem;
	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: 130px;
	}
	header #navBtn {
		cursor: pointer;
		display: block;
		padding: 2rem 1.5rem;
		position: absolute;
		bottom: 0;
		right: 0;
		top: 0;
		width: 6rem;
		text-decoration:none;
	}
 	header #navBtn span {
		display: block;
		height: 0.1rem;
		width: 100%;
		background: #3A7728;
		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: 1rem;
		background: transparent;
		color: #3A7728;
		font-size: 1.1rem;
		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: 10;
	}
}
/* -------------------------------
NAVIGATION
------------------------------- */
#navigation {
	flex: 1;
	display: flex;
	flex-direction: column-reverse;
	align-items: flex-end;
	margin-left: 15%;
	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(111,185,44,0.95);
		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 > li {
	margin-left: 1.5rem;
	display: flex;
	align-items: center;
	font-size: 1.2rem;
	font-weight: bold;
	color: #3A7728;
	border-left: solid 1px #D1D3D1;
	padding-left: 1.5rem;
}
#snav >ul >li a {	
	color: #3A7728;
}
#snav > ul > li i {
	font-size: 2rem;
	margin-right: 0.5rem;
}
#snav > ul > li > .dropPc {
	display: flex;
    align-items: center;
}
#snav > ul > li > .dropPc > label {
	display: flex;
    align-items: center;
	cursor: pointer;
}
#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: 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 {
	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: #649e26;
	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 > li {
		width: 100%;
		position: relative;
		padding: 0;
		border-bottom: 1px solid #fff; 
		margin-left: 0;
		border-left: none;
	}
	#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:only-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:only-child > li:first-child,
	#snav > ul:only-child > li:nth-child(2) {
		width: auto;
		border-bottom: none;
	}
	#snav > ul:only-child > li:last-child {
		position: fixed;
		top: 0;
		right: 5rem;
		height: 6rem;
		width: 6rem;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	#snav > ul:only-child > li:last-child .dropPc > label i {
		font-size: 2.4rem;
		margin-right: 0;
		color: #3A7728;
	}
	#snav > ul:only-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 > li > .dropPc > input:checked + .snavModal > .inn {
		padding: 3rem;
	}
	
}

/* -------------------------------
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: 1px;
	width: 100%;
	bottom: 0;
	left: 0;
	right: 0;
	position: absolute;
	background: #4F2121;
	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 + .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: 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 > .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;
	}
	
}

@media screen and (max-width: 810px){
/*--------------------------------------
SP
---------------------------------------*/
}

/* -------------------------------
見出し
------------------------------- */
.midashi01 {
	font-size: 28px;
	font-size: 2.8rem;
	position: relative;
	text-align: center;
	padding-top: 40px;
	line-height: 1.6;
}
.midashi01::after {
	position: absolute;
	content: "";
	bottom: -20px;
	left: 50%;
	width: 10.1rem;
	transform: translateX(-50%);
	border-bottom: 4px dotted #846262;
}
.midashi02 {
	text-align: center;
	font-size: 22px;
	font-size: 2.2rem;
	line-height: 1.8;
}
.midashi03 {
  border-bottom: 1px solid #9B7B7B;
	text-align: center;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.2;
	display: inline-block;
  letter-spacing: .05em;
  padding: 80px 5px 15px;
  position: relative;
  z-index: 0;
  white-space: nowrap;
	margin-bottom: 50px;
}
.midashi03 span {
	font-family: 'Noto Serif JP', serif;
font-family: 'Roboto', sans-serif;
	color: #5B4343;
	font-size: 35px;
	font-size: 3.5rem;
	display: block;
}
.midashi03::after {
  background: #fff;
  border-right: 1px solid #9B7B7B;
  bottom: -16px;
  content: '';
  display: block;
  height: 20px;
  left: 50%;
  outline: 5px solid #fff;
  position: absolute;
  transform: rotate(39deg);
  width: 5px;
}
.midashi04 {
	color: #5EB13B;
	font-size: 22px;
	font-size: 2.2rem;
	position: relative;
	display: inline-block;
	padding: 0 0 0 55px;
	margin-bottom: 50px;
	line-height: 1.6;
}
.midashi04::before {
  content: '';
  position: absolute;
  top: 50%;
  left:0;
  display: inline-block;
  width: 45px;
  height: 1px;
  background-color: #5EB13B;
}
@media screen and (max-width: 810px){
	.midashi01 {
		font-size: 2.0rem;
		padding-top: 10px;
		padding: 0 30px;
	}
	.midashi01::after {
		bottom: -15px;
		width: 6rem;
	}
	.midashi02 {
		font-size: 1.8rem;
		text-align: left;
	}
	.midashi03 {
		font-size: 1.3rem;
  		padding: 50px 5px 15px;
		margin-bottom: 20px;
	}
	.midashi03 span {
		font-size: 2.8rem;
	}
	.midashi04 {
		font-size: 1.8rem;
		margin-bottom: 30px;
	}
}

/* -------------------------------
マーカー
------------------------------- */
.marker {
	font-weight: bold;
	background: linear-gradient(transparent 60%,#FCEA6D 60%);
}

/* -------------------------------
注釈
------------------------------- */
.kome {
	font-size: 12px;
	font-size: 1.2rem;
	margin-top: 20px;
}

/* -------------------------------
リンクボタン
------------------------------- */
.lbtn {
	text-align: center;
	margin-top: 40px;
	line-height: 1.8 !important;
}
.lbtn a {
	font-size: 14px;
	font-size: 1.4rem;
	display: inline-block;
	padding: 10px 20px 10px 50px;
	font-weight: bold;
	border: solid 1px #4F2121;
	border-radius: 100vw 100vw;
	transition: background 0.8s;
}
.lbtn a:hover {
	background: #462a2c;
	color: #FFF;
	text-decoration: none;
}

.lbtn a span {
  display: inline-block;
  vertical-align: middle;
  line-height: 1;
  position: relative;
  width: 0.8em;
  height: 0.1em;
  background: currentColor;
	margin-left: 30px;
	margin-right: 0px;
}
.lbtn a span::before {
  content: '';
  width: 0.65em;
  height: 0.65em;
  border: 0.1em solid currentColor;
  border-left: 0;
border-right: 0;
  border-bottom: 0;
  box-sizing: border-box;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 810px){
	.lbtn a {
		font-size: 1.3rem;
}
}

/*-------------------------------
ページャー
---------------------------------*/
.acms-pager {margin-top:30px;}

/* -------------------------------
カテゴリートップ以外のコンテンツ部分
------------------------------- */
.cnt {
	border-top: 1px solid #E0DEDE;
	padding-top: 20px;
}
.inn {
	margin-top:50px;
}
#eimg {
	position: relative;
	height: 400px;
}
#eimg::after {
  content: '';
  position: absolute;
  top: 35%;
  right: 0;
  width: 100%;
  height: 310px;
}
@media screen and (max-width: 810px){
	.inn {
		margin-top:30px;
	}
	#eimg {
		height: 250px;
	}
	#eimg::after {
  	content: '';
  	position: absolute;
  	right: 0;
  	width: 100%;
  	height: 160px;
}
}

/* -------------------------------
区切り線
------------------------------- */
.line {
	border-top:solid 1px #A88E8E;
	padding-top: 50px;
	margin-top: 50px;
}
.ldash {
	border-top:dashed 1px #A88E8E;
	padding-top: 50px;
	margin-top: 50px;
}
@media screen and (max-width: 810px){
	.line,
	.ldash {
		padding-top: 40px;
		margin: 40px 0 0;
	}
}

/* -------------------------------
カテゴリートップのタイトル部分
------------------------------- */
#mainArea {
	margin-top: 9rem;
}
.mainTit {
	position: relative;
	height: 400px;
}
.mainTit::before {
	content: "";
	position: absolute;
	left: 0;
	bottom: -40px;
	width: 50%;
	height: 420px;
	background: #EFEDED;
}
.mainTit::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 80%;
  height: 400px;
}
.mainTit h1 {
	position: relative;
  top: 340px;
	left:11%;
	background: #FFF;
	display: inline-block;
	font-size: 33px;
	font-size: 3.3rem;
	padding: 20px 35px;
	z-index: 11;
}

@media screen and (max-width: 810px){
#mainArea {
	margin-top: 6rem;
}
.mainTit {
	position: relative;
	height: 180px;
}
.mainTit::before {
	content: "";
	position: absolute;
	left: 0;
	bottom: -30px;
	width: 80%;
	height: 200px;
	background: #EFEDED;
}
.mainTit::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 90%;
  height: 180px;
}
.mainTit h1 {
	position: relative;
  top: 150px;
	left:0;
	background: #FFF;
	display: inline-block;
	font-size: 2.0rem;
	padding: 10px 20px;
	z-index: 11;
}
}
/* -------------------------------
ぱんくず
------------------------------- */
#pankuzu {
	margin-top: 60px;
	font-size: 13px;
	font-size: 1.3rem;
}
@media screen and (max-width: 810px){
	#pankuzu {
		display: none;
}
}
/* -------------------------------
リード文
------------------------------- */
p.lead {
	text-align: center;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 2.0;
	margin: 4rem 10vw;
}
@media screen and (max-width: 810px){
	p.lead {
		text-align: left;
		font-size: 1.4rem;
		line-height: 2.0;
		margin: 4rem 1vw;
	}
}

/* -------------------------------
関連コンテンツ
------------------------------- */
#rcnt {padding-bottom: 20px;}
#rcnt ul li a {
	width: 100%;
	max-width: 22.0rem;
	display: inline-block;
	font-weight: bold;
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.4;
}
#rcnt ul li a p:first-of-type {
	overflow: hidden;
	border-radius: 5px;
	margin-bottom: 10px;
}
#rcnt ul li a p:first-of-type img {
	transition: all .3s;
	transform:scale(1);
}
#rcnt ul li a:hover p:first-of-type img {transition: all .3s;transform: scale(1.1);}
#rcnt .lbtn {
	margin-top: 40px;
}

@media screen and (max-width: 810px){
	#rcnt ul li a {
		font-size: 1.3rem;
	}
}

/* -------------------------------
フッター
------------------------------- */
footer {
	background: #F2EAE2;
	margin-top: 40px;
	padding: 40px 15px;
}
#footerlink {
	max-width: 1320px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: center;
}
#footerlink ul {
	display: flex;
}
#footerlink ul:first-of-type li a {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: rgba(255,255,255,0.8);
	text-align: center;
	display: table-cell;
	box-sizing: border-box;
}
#footerlink ul:first-of-type li {
	margin-left: 20px;
}
#footerlink ul:first-of-type li a {
	padding-top: 5px;
}
#footerlink ul:first-of-type li:last-child a {
	text-decoration: none;
	font-size: 2.2rem;
}
#footerlink ul:last-of-type li {
	font-size: 12px;
	font-size: 1.2rem;
	border-left: 1px solid #724747;
	line-height: 1.2;
}
#footerlink ul:last-of-type li i {display: none;}
#footerlink ul:last-of-type li:last-child {
	border-right: 1px solid #724747;
}
#footerlink ul:last-of-type li a {
	padding: 0 30px;
}
#copyright {
	max-width: 1320px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	margin-top: 30px;
}
#copyright p:first-of-type {
	font-size: 11px;
	font-size: 1.1rem;
	margin-right: 20px;
	margin-top: 5px;
}

@media screen and (max-width: 810px){
	footer {
		padding: 0 0 30px;
	}
	#spfoot {
		background: #724747;
		padding: 20px 10px;
		display: flex !important;
	}
	#spfoot li {
		width: 50%;
		text-align: center;
		display: flex;		
	align-items: center;
		justify-content: center;
	}
	#spfoot li i {
		color: #F2EAE2;
	font-size: 2rem;
	margin-right: 0.5rem;
	}
	#spfoot li a {
		color: #F2EAE2;
		font-size: 1.3rem;		
	}
	#spfoot li:first-child {
		border-right: 4px dotted #F2EAE2;
	}
	#footerlink {
		display: flex;
		flex-direction: column;
		margin-top: 20px;
	}
	#footerlink ul:first-of-type li:first-child {
		margin-left: 0;
	}
	#footerlink ul:last-of-type {
		border-top: 1px solid #EADCCC;
		border-bottom: 1px solid #EADCCC;
		margin: 20px 10px;
		flex-wrap: wrap;
		justify-content: space-between;
	}		
	#footerlink ul:last-of-type li {
		width: 48%;
		border-left: none;
		line-height: 1.8;
		border-bottom: 1px solid #EADCCC;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	#footerlink ul:last-of-type li i {display: block;}
	#footerlink ul:last-of-type li:nth-child(3),
	#footerlink ul:last-of-type li:nth-child(4) {
		border-bottom: none;
	}
	#footerlink ul:last-of-type li:last-child {
		border-right: none;
	}
	#footerlink ul:last-of-type li a {
		display: block;
		padding: 15px 0;
	}
	#footerlink ul:last-of-type li i {
		color: #724747;
		font-size: 1.6rem;
	}
	#copyright {
		flex-direction: column-reverse;
		margin-top: 15px;
	}
	#copyright p:first-of-type {
		margin-right: 0;
		margin-top: 10px;
	}
}


/* -------------------------------
ページトップ
------------------------------- */
#page-top a{
	font-weight: bold;
  display: flex;
  justify-content:center;
  align-items:center;
	writing-mode:vertical-rl;
	-webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
  text-align: center;
  text-transform: uppercase; 
  text-decoration: none;
  font-size:0.8rem;
  transition:all 0.3s;
	position: relative;
}
#page-top a::before {
	position: absolute;
	content: "";
	display: block;
	height: 20px;
	width: 1px;
	background: #4F2121;
	top:-25px;
}

/*リンクを右下に固定*/
#page-top {
  position: fixed;
  right: 10px;
  z-index: 2;
    /*はじめは非表示*/
  opacity: 0;
  transform: translateY(100px);
}

/*　上に上がる動き　*/

#page-top.UpMove{
  animation: UpAnime 0.5s forwards;
}
@keyframes UpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }
  to {
    opacity: 1;
  transform: translateY(0);
  }
}

/*　下に下がる動き　*/

#page-top.DownMove{
  animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime{
  from {
    opacity: 1;
  transform: translateY(0);
  }
  to {
    opacity: 1;
  transform: translateY(100px);
  }
}
@media screen and (max-width: 810px){
	#page-top {
  right: 5px;
}
}

