@charset "utf-8";
/* CSS Document */



/*
* "Noto Sans JP" licensed under the SIL Open Font License 1.1
* by https://fonts.google.com/specimen/Noto+Sans+JP
*/
@font-face {
	font-family: "Noto Sans JP";
	font-style: normal;
	font-weight: 500;
	src: url("fonts/NS-500.woff2") format("woff2"), url("fonts/NS-500.woff") format("woff");
	font-display: swap;
}

@font-face {
	font-family: "Noto Sans JP";
	font-style: normal;
	font-weight: 900;
	src: url("fonts/NS-900.woff2") format("woff2"), url("fonts/NS-900.woff") format("woff");
	font-display: swap;
}

@font-face {
	font-family: "Noto Sans JP vt";
	font-style: normal;
	font-weight: 900;
	src: url("fonts/NS-900-vertical.woff2") format("woff2"), url("fonts/NS-900-vertical.woff") format("woff");
	font-display: swap;
}





/*--------------------------------------------------------------------------
   reset
---------------------------------------------------------------------------*/

h1,
h2,
h3,
h4,
h5,
h6,
p,
span,
small,
dl,
dt,
dd,
ol,
ul,
li {
	margin: 0;
	font-size: 100%;
}

ul {
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

img {
	vertical-align: top;
}

li {
	list-style-type: none;
	vertical-align: baseline;
}

input,
button,
textarea,
select {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}



/*--------------------------------------
　Base
---------------------------------------*/
* {
	box-sizing: border-box;
}

img {
	-webkit-backface-visibility: hidden;
}


body {
	font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
	font-weight: 500;
	font-size: 1.6em;
	line-height: 2.0;
	color: #1b140b;
	text-align: justify;
}

img {
	max-width: 100%;
	height: auto;
}

a {
	color: #1b140b;
	text-decoration: none;
}

a:hover {
	text-decoration: none;
}

p {
	text-align: justify;
}

p a {
	text-decoration: underline;
}


.fl {
	float: left;
}

.fr {
	float: right;
}

.strong {
	font-weight: bold;
}

.f110 {
	font-size: 110%;
}

.f120 {
	font-size: 120%;
}

.f130 {
	font-size: 130%;
}

.f150 {
	font-size: 150%;
}

.f200 {
	font-size: 200%;
}

.f300 {
	font-size: 300%;
}


/* Micro clearfix */

/* For modern browsers */
.cf:before,
.cf:after {
	content: "";
	display: table;
}

.cf:after {
	clear: both;
}

/* For IE 6/7 (trigger hasLayout) */
.cf {
	zoom: 1;
}


.flImg {
	float: left;
}

.frImg {
	float: right;
}


h1,
h2 {
	position: relative;
	font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
	font-weight: 900;
	padding: 0;
	line-height: 1.5;
}

h3,
h4,
h5,
h6 {
	position: relative;
	font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
	font-weight: 900;
	padding: 0;
	line-height: 1.5;
}


.sttl {
	position: relative;
	margin: 0 0 12px;
	font-size: 2.4rem;
	font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
	font-weight: 900;
	line-height: 1.5;
}

.catch {
	position: relative;
	margin: 0 0 12px;
	font-size: 2.2rem;
	font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
	font-weight: 900;
	line-height: 1.6;
}


.fontS {
	font-size: 67%;
}

.fontL {
	font-size: 150%;
}

.fontBold {
	font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
	font-weight: 900;
}

.fontGr {
	color: #169a5a;
}

.fontOr {
	color: #ee5c21;
}


html {
	font-size: 62.5%;
}



.ulBox,
.liBox {
	position: relative;
}




/*------------
600px--common
------------*/

.sp,
.sp_br {
	display: none !important;
}

.sp2 {
	display: none;
}


body {
	position: relative;
	width: 100%;
	min-width: 1000px;
}

.forTab {
	overflow: hidden;
}


a {
	transition: all .2s ease-in-out;
}

a:hover {
	opacity: 0.7;
}

a:hover img {
	opacity: 1;
}

.mainWrap h1 a,
.mainWrap h2 a,
.mainWrap h3 a,
.mainWrap h4 a,
.mainWrap h5 a,
.mainWrap h6 a {
	text-decoration: none;
}


.areaInner {
	position: relative;
	width: 1000px;
	margin: 0 auto;
}





/*--------------------------------------
　body_PC
---------------------------------------*/
* {
	text-underline-offset: 0.15em;
}


/*--------------------------------------
　header_PC
---------------------------------------*/
#header {
	position: relative;
	z-index: 14;
	height: 36rem;
}

#header .topArea2 {
	position: absolute;
	top: 1.5rem;
	right: 2rem;
	text-align: right;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.6;
	color: #fff;
	z-index: 1;
}

#header .siteName {
	display: inline-block;
}

#header .siteName a {
	color: #fff;
}

#header .siteSps {
	display: inline-block;
}


#header .logo {
	position: absolute;
	top: 1.8rem;
	left: 2rem;
	width: 17rem;
	filter: drop-shadow(0px 0px 20px rgba(0, 0, 0, 0.5));
	z-index: 1;
}

#header .logo img {
	width: 100%;
}

#header .sps {}


#header .mvbg {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 200%;
	height: 40rem;
	overflow: hidden;
}

#header .mvbg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 0 0;
}

#header .mvbg::before {}




/*--------------------------------------
　Main Contents_PC
---------------------------------------*/
#contents {
	position: relative;
	z-index: 14;
	width: 100%;
	overflow-x: hidden;
	margin: -8rem 0 0;
	padding: 0 0 0;
}

#contents::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: 8rem;
	left: 0;
	width: 100%;
	height: calc(100% - 8rem);
	background: #f7edde;
}

.mainWrap {
	position: relative;
	z-index: 1;
	padding: 0 0 5rem;
	background: #fff;
	border-radius: 8rem 8rem 0 0;
	min-height: 500px;
}

.mainWrap>.areaInner {
	padding: 0 0 5rem;
}

.smappage a br {
	display: none;
}


.index a,
.mainWrap a {
	display: block;
}

.index p a,
.mainWrap p a,
.index li a,
.mainWrap li a,
.index td a,
.mainWrap td a {
	display: inline;
}


/*--------------------------------------
　pankuzu_PC
---------------------------------------*/
#pankuzuWrap {
	position: relative;
	width: 100%;
	margin: 0 0 0;
}

#pankuzu {
	width: 100%;
	margin: 0 auto .5rem;
	padding: 2rem 0 0;
	font-size: 1.2rem;
	color: #666;
}

#pankuzu a {
	display: inline;
	text-decoration: underline;
	color: #666;
}

#pankuzu br {
	display: none;
}



/*--------------------------------------
　page-top_PC
---------------------------------------*/
#page-top {
	position: fixed;
	z-index: 101;
	bottom: 3rem;
	right: 1rem;
	width: 70px;
}

#page-top {
	transition: .3s;
	/*デフォルトで非表示にする*/
	opacity: 0;
	visibility: hidden;
}

/*このクラスが付与されると表示する*/
#page-top.active {
	opacity: 1;
	visibility: visible;
}

/*このクラスが付与されると停止する*/
#page-top.absolute {}





/*--------------------------------------
　Global Nav
---------------------------------------*/
#gNav_pc {
	position: fixed;
	top: 1.9rem;
	right: 4.2rem;
	z-index: 10000;


	transition: .3s;
	/*デフォルトで非表示にする*/
	opacity: 0;
	visibility: hidden;
}

/*このクラスが付与されると表示する*/
#gNav_pc.active {
	opacity: 1;
	visibility: visible;
}



/* ハンバーガーメニュー */

#gNav_pc #showRight2 {
	z-index: 10000;
}

#gNav_pc button {
	position: relative;
	width: 5.0rem;
	height: 5.0rem;
	/*background: #ccc;*/
	border-radius: 50%;
	transition: .3s all;
}

#gNav_pc button span {
	position: absolute;
	left: 25%;
	width: 50%;
	height: 2px;
	background-color: #1b140b;
	transition: .3s all;
}

#gNav_pc button span:nth-child(1) {
	top: 30%;
}

#gNav_pc button span:nth-child(2) {
	top: calc(30% + .8rem);
}

#gNav_pc button span:nth-child(3) {
	top: calc(30% + 1.6rem);
}

#gNav_pc button.active span:nth-child(1) {
	transform: translateY(8px) rotate(-45deg);
}

#gNav_pc button.active span:nth-child(2) {
	opacity: 0;
}

#gNav_pc button.active span:nth-child(3) {
	transform: translateY(-8px) rotate(45deg);
}


#gNav_pc button:hover {
	opacity: .7;
}



/* General styles for all menus */
#gNav_pc .cbp-spmenu {
	position: fixed;
	margin: 0 0 0;
	padding: 10rem 0 10rem;
	background: #f7edde;

	overflow: auto;
	-ms-overflow-style: none;
	/* IE, Edge 対応 */
	scrollbar-width: none;
	/* Firefox 対応 */
}

#gNav_pc .cbp-spmenu::before {
	content: "";
	position: fixed;
	bottom: 0;
	left: 0;
	width: 62rem;
	height: 71.5rem;
	background: url(./img/nav_img.jpg) 0 0 no-repeat;
	background-size: 62rem auto;
	border-radius: 0 16rem 0 0;
}

#gNav_pc .cbp-spmenu #mainMenu2 {
	position: relative;
	z-index: 1;
	/*overflow: auto;*/
	overflow: visible;
	margin: 0 auto;
	padding: 10rem 10rem 0 73rem;
	height: 100%;
	/*width: 120rem;*/
}

#gNav_pc .cbp-spmenu #mainMenu2::-webkit-scrollbar {
	display: none;
	/* Chrome, Safari 対応 */
}

#gNav_pc .cbp-spmenu #mainMenu2::before {
	content: "";
	position: absolute;
	top: 4rem;
	left: 71rem;
	width: 16rem;
	height: 3.2rem;
	background: url(./img/eng_menu.svg) 0 0 no-repeat;
	background-size: auto 3.2rem;
}


#gNav_pc .cbp-spmenu #mainMenu2 .gnavBox {
	position: relative;
	margin: 0 0 3.5rem;
}

#gNav_pc .cbp-spmenu #mainMenu2 .gnavBox:nth-child(2n) {}



#gNav_pc .cbp-spmenu a {
	display: block;
	text-decoration: none;
	line-height: 1.3;
	cursor: pointer;
	font-size: 1.5rem;
	/*color: #fff;*/
}

#gNav_pc .cbp-spmenu .sttl {
	margin: 0;
	border-bottom: 1px solid #b7b5b4;
}

#gNav_pc .cbp-spmenu .sttl a {
	position: relative;
	display: flex;
	align-items: center;
	margin: 0;
	padding: 2.5rem 5rem 2.5rem 1.0rem;
	background: url(./img/arrow_gr.svg) 99% calc(50% + 1px) no-repeat;
	background-size: 1.8rem auto;
	font-size: 1.8rem;
}

#gNav_pc .cbp-spmenu .sttl::before {
	content: "";
	position: absolute;
	top: 0;
	left: -2.2rem;
	width: 7.5rem;
	height: 7rem;
	background: url(./img/h3_deco.svg) 0 0 no-repeat;
	background-size: 7.5rem auto;
	opacity: .2;
}

#gNav_pc .cbp-spmenu li {
	border-bottom: 1px solid #b7b5b4;
}

#gNav_pc .cbp-spmenu li.subCat {
	border-bottom: none;
}

#gNav_pc .cbp-spmenu ul.subList {
	border-top: 1px solid #b7b5b4;
}


#gNav_pc .cbp-spmenu li a {
	position: relative;
	background: url(./img/arrow_gr.svg) 99% calc(50% + 1px) no-repeat;
	background-size: 1.8rem auto;
	padding: 1.6rem 5rem 1.7rem 2.8rem;
}

#gNav_pc .cbp-spmenu li a::before {
	content: "";
	position: absolute;
	top: calc(50% - .6rem);
	left: 1rem;
	width: 1.2rem;
	height: 1.2rem;
	background: #169a5a;
	border-radius: 50%;
}


#gNav_pc .cbp-spmenu a:hover {
	opacity: 0.7;
}

#gNav_pc .cbp-spmenu a:active {}

/* Orientation-dependent styles for the content of the menu */

#gNav_pc .cbp-spmenu-vertical {
	width: 100%;
	height: 100%;
	top: 0;
	z-index: -1;
}

#gNav_pc .cbp-spmenu-vertical a {
	/*border-bottom: 1px solid #848484;*/
	padding: 14px 4rem 14px 0;
}


/* Vertical menu that slides from the left or right */

#gNav_pc .cbp-spmenu-right {
	opacity: 0;
	visibility: hidden;
	/*right: -100vw;*/
	right: 0;
}

#gNav_pc .cbp-spmenu-right.cbp-spmenu-open {
	opacity: 1;
	visibility: visible;
	right: 0;
	z-index: 1000;
}


/* Transitions */
#gNav_pc .cbp-spmenu,
#gNav_pc .cbp-spmenu-push {
	transition: all 0.5s ease;
}

#gNav_pc .accChild {
	display: none;
}

#gNav_pc .cbp-spmenu #mainMenu2 a br {
	display: none;
}


body.body-fix {
	overflow: hidden;
}









/*--------------------------------------
　fixNav_PC
---------------------------------------*/

#fixNav {
	position: fixed;
	z-index: 1001;
	right: 2.5rem;
	top: .5rem;

	transition: .3s;
	/*デフォルトで非表示にする*/
	opacity: 0;
	visibility: hidden;
}

/*このクラスが付与されると表示する*/
#fixNav.active {
	opacity: 1;
	visibility: visible;
}

/*このクラスが付与されると停止する*/
#fixNav.absolute {
	/*opacity: 0;
visibility: hidden;*/
}


#fixNav .navBox {
	display: flex;
	align-items: center;
	padding: 1.4rem 7.4rem 1.4rem 1.6rem;
	background: #fff;
	box-shadow: -1px 0px 20px 0px rgba(0, 0, 0, 0.2);
	border-radius: 9999px;
	min-height: 78px;
}
/* /host/ 配下だけパディングを調整 */
body.is-host #fixNav .navBox {
	padding: 1.4rem 6.8rem 1.4rem 1.6rem;
}

#fixNav .fixBan {
	position: relative;
	display: flex;
	align-items: center;
	background: #fabd0e;
	height: 5rem;
	padding: 0 1.8rem .3rem 5rem;
	border-radius: 9999px 0 0 9999px;
	line-height: 1;
	font-size: 1.5rem;
	font-weight: 900;
}

#fixNav .fixBan:last-child {
	background: #bf0000;
	margin: 0 0 0 .6rem;
	padding: 0 3rem .3rem 5rem;
	border-radius: 0 9999px 9999px 0;
	color: #fff;
}

#fixNav .fixBan::before {
	content: "";
	position: absolute;
	top: 0;
	left: 1.7rem;
	width: 2.6rem;
	height: 100%;
	background: url(./img/icon_cart.svg) 0 50% no-repeat;
	background-size: 2.6rem auto;
}

#fixNav .fixBan:last-child::before {
	background-image: url(./img/icon_cart_wt.svg);
}


#fixNav .logo {
	position: fixed;
	top: 0;
	left: 0;
	width: 25rem;
	height: 8rem;
	padding: 1rem 4.2rem 0;
	background: #fff;
	box-shadow: -1px 0px 20px 0px rgba(0, 0, 0, 0.2);
	border-radius: 0 0 4rem 0;
}

#fixNav .logo a {}








/*--------------------------------------
　h1Area_PC
---------------------------------------*/
.h1Area {
	position: relative;
	z-index: 2;
	margin: 0 0 12rem;
	padding: 13rem 0 0;
	text-align: center;
}

.h1Area::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 35rem;
	background: url(./img/h1_deco.png) 50% 0 no-repeat;
}

.h1Area h1 {
	position: relative;
	margin: 0 0 2rem;
	font-size: 4.5rem;
}

.h1Area .headNote {
	line-height: 1.5;
	font-size: 1.2rem;
}






/*--------------------------------------
　Footer_PC
---------------------------------------*/

footer {
	position: relative;
	z-index: 14;
	width: 100%;
	padding: 6.5rem 0 0;
	background: url("./img/footbg.jpg") 0 0 no-repeat;
	background-size: cover;
	background-attachment: fixed;
}

footer .footInner {
	width: 1200px;
	margin: 0 auto;
	padding: 0 0 2rem;
}



footer .footInner .areaL {
	width: 41.5rem;
	float: left;
}

.footLogo {
	position: relative;
	margin: 0 auto 3.5rem;
}

.footLogo .logoImg {
	width: 22.5rem;
	margin: 0 auto;
}

footer .noticeArea {
	padding: 2.5rem 3rem;
	background: rgba(255, 255, 255, .80);
	border-radius: 2rem;
}

footer .noticeArea p {
	font-size: 1.2rem;
}

footer .noticeArea p:nth-child(1) {}

footer .noticeArea a {
	text-decoration: underline;
}

footer .noticeArea .botPrg {
	padding: .8rem 0 0;
	text-align: center;
}




footer .footInner .areaR {
	width: 73rem;
	float: right;
}

footer .footBox {
	position: relative;
	z-index: 9;
	margin: 0 0 40px;
	text-align: left;
}


footer .footBox a {
	color: #fff;
}

.footBox .sttl {
	margin: 0 0 12px;
	padding: 0 0 10px;
	border-bottom: 1px solid rgba(255, 255, 255, .5);
}

.footBox .sttl a {
	position: relative;
	display: block;
	padding: 4px 0 4px;
	font-size: 1.8rem;
	line-height: 1.3;
}

footer .smap .sttl a {
	font-size: 1.8rem;
}

.footBox>ul {
	padding: 0 0;
}

.footBox li {
	display: inline-block;
}

.footBox li ul {}

.footBox li a {
	font-size: 1.5rem;
}

.footBox li:after {
	content: "　/　";
	color: #fff;
}

.footBox li:last-child:after {
	content: "";
}


.footBox li.subCat {
	display: inline;
	margin: 0 20px 0 0;
}

.footBox li.subCat:after {
	content: "";
}

.footBox li.subCat>a {}

.footBox li.subCat>a:after {}

.footBox ul.subList {
	display: inline;
}

.footBox ul.subList>li:first-child::before {
	content: "：";
}

.footBox ul.subList li:after {
	content: " / ";
}

.footBox ul.subList li:last-child::after {
	content: "";
}

.footBox ul.subList a {
	font-weight: 500;
}

.footBox a br {
	display: none;
}


footer .botArea {
	position: relative;
	min-width: 1200px;
	box-sizing: border-box;
	background: #169a5a;
}

footer .botArea .botInner {}

footer .botArea .copy {
	padding: .8rem 2rem 1.2rem;
	font-size: 1.3rem;
	text-align: center;
	color: #fff;
}

footer .botArea .copy a {
	text-decoration: none;
	color: #fff;
}






/* ================== */
/*  PC共通パーツ　*/
/* ================== */
/* p */
.mainWrap p,
.index p {
	margin: 15px 0;
	padding: 0 0;
	word-break: break-all;
}




.mainWrap h2 {
	position: relative;
	margin: 85px 0 35px;
	padding: 2.5rem 2rem 2.8rem 3.5rem;
	background: #e6f2e8;
	border-radius: 2rem;
	font-size: 3.4rem;
	color: #4f3b20;
}

.mainWrap h2::before {
	content: "";
	position: absolute;
	top: 2.5rem;
	left: 0;
	width: 1rem;
	height: calc(100% - 5rem);
	background: #ef5c22;
}

.mainWrap h2::after {}



.mainWrap h2 a {
	position: relative;
	display: block;
	padding: 0 45px 0 0;
	color: #4f3b20;
}

.mainWrap h2 a::before {
	content: "";
	position: absolute;
	z-index: 10;
	top: 0;
	right: .7rem;
	width: 3rem;
	height: 100%;
	background: url("./img/arrow_gr.svg") 99% calc(50% + 1px) no-repeat;
	background-size: 2.6rem auto;
	transition: all .2s ease-in-out;
}

.mainWrap h2 a:hover::before {}

.mainWrap h2 a::after {}

.mainWrap h2 a:hover::after {}




.mainWrap h3 {
	position: relative;
	margin: 4rem 0 3rem;
	padding: 1.5rem 1rem 2rem 1rem;
	border-bottom: 1px solid #b7b5b4;
	font-size: 2.8rem;
	color: #169a5a;
}

.mainWrap h3::before {
	content: "";
	position: absolute;
	top: 0;
	left: -3rem;
	width: 9rem;
	height: 9rem;
	background: url(./img/h3_deco.svg) 0 0 no-repeat;
	background-size: 9rem auto;
	opacity: .1;
}

.mainWrap h3 a {
	position: relative;
	z-index: 1;
	display: block;
	padding: 0 5.5rem 0 0;
	color: #169a5a;
}

.mainWrap h3 a::before {
	content: "";
	position: absolute;
	z-index: 10;
	top: 0;
	right: 1.7rem;
	width: 30px;
	height: 100%;
	background: url("./img/arrow_gr.svg") 99% calc(50% + 1px) no-repeat;
	background-size: 2.6rem auto;
	transition: all .2s ease-in-out;
}

.mainWrap h3 a:hover::before {}

.mainWrap h3 a::after {}

.mainWrap h3 a:hover::after {}



.mainWrap h4,
.mainWrap h5,
.mainWrap h6 {
	position: relative;
	margin: 4rem 0 3rem;
	padding: 1rem 1rem 1.2rem 1rem;
	border-bottom: 1px solid #b7b5b4;
	font-size: 2.2rem;
}

.mainWrap h5::before,
.mainWrap h6::before {}

.mainWrap h4 a,
.mainWrap h5 a,
.mainWrap h6 a {
	position: relative;
	padding: 0 5.5rem 0 0;
}

.mainWrap h4 a::before,
.mainWrap h5 a::before,
.mainWrap h6 a::before {
	content: "";
	position: absolute;
	z-index: 10;
	top: 0;
	right: 2.1rem;
	width: 30px;
	height: 100%;
	background: url("./img/arrow_gr.svg") 99% calc(50% + 1px) no-repeat;
	background-size: 2.2rem auto;
	transition: all .2s ease-in-out;
}

.mainWrap h5 a:hover::before,
.mainWrap h6 a:hover::before {}

.mainWrap h5 a::after,
.mainWrap h6 a::after {}

.mainWrap h5 a:hover::after,
.mainWrap h6 a:hover::after {}




/* ulol */
.mainWrap ul,
.index ul,
#mainVis ul {
	margin: 20px 0 20px;
	padding: 10px 10px 0;
}

.mainWrap ul li,
.index ul li,
#mainVis ul li {
	position: relative;
	padding: 3px 0 3px 20px;
}

.mainWrap ul li::before,
.index ul li::before {
	position: absolute;
	content: "";
	top: 14px;
	left: 2px;
	width: 12px;
	height: 12px;
	background: #169a5a;
	border-radius: 50%;
}

.mainWrap ol {
	margin: 20px 0 20px;
	padding: 10px 10px 0;
}

.mainWrap ol li {
	padding: 3px 0 3px 22px;
	list-style: none;
	position: relative;
	counter-increment: number;
}

.mainWrap ol li::before {
	position: absolute;
	top: 10px;
	left: 0;
	width: 15px;
	height: 14px;
	padding: 2px 0 1px;
	background: #ef5c22;
	text-align: center;
	letter-spacing: -0.5px;
	line-height: 1.0;
	font-family: Arial, Helvetica, "sans-serif";
	font-weight: 900;
	font-size: 1.4rem;
	color: #fff;
}


.mainWrap ol li::before {
	content: counter(number);
}


.mainWrap li a,
.index li a {
	text-decoration: underline;
}

.mainWrap li a:hover,
.index li a:hover {
	text-decoration: none;
}




/* btns */
.btn-internal,
.btn-web,
.btn-tel {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 3.6rem auto;
	text-align: center;
}

.btn-internal a,
.btn-web a,
.btn-tel a {
	position: relative;
	top: 0;
	left: 0;
	margin: 0 6px 0 0;
	width: 40rem;
	min-height: 11rem;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1.0rem 7rem 1.2rem;
	box-shadow: .6rem .6rem 0 0 #0c5934;
	border-radius: 2rem 5rem 2rem 2rem;
	text-align: center;
	line-height: 1.5;
	font-weight: 900;
	font-size: 1.8rem;
	overflow: hidden;
	transition: all .2s ease-in-out;
}

.btn-internal a::before,
.btn-web a::before {
	content: '';
	position: absolute;
	width: 0px;
	height: 0px;
	aspect-ratio: 1/1;
	background-color: #169a5a;
	border-radius: 50%;
	transform: translateX(-50%);
	left: 50%;
	top: 50%;
	z-index: 1;
}

.btn-web a::before {
	background-color: #fff;
}

@media (hover: hover) {

	.btn-internal a:hover::before,
	.btn-web a:hover::before {
		width: auto;
		height: 500%;
		top: -200%;
		left: 50%;
		opacity: 0;
		transition: 0.5s ease-in-out;
	}

	.btn-internal a:hover,
	.btn-web a:hover {
		position: relative;
		top: 3px;
		box-shadow: .6rem .3rem 0 0 #0c5934;

		color: #fff;
		background-color: #169a5a;
		transition: color 0s, background-color 0.2s, top 0.2s, box-shadow 0.2s;
		transition-delay: 0.2s;
		opacity: 1;
	}

	.btn-web a:hover {
		color: #1b140b;
		background-color: #fff;
		box-shadow: .6rem .3rem 0 0 #ba8b0b;
	}

	.btn-web2 a:hover {
		box-shadow: .6rem .3rem 0 0 #800000;
	}
}




.btn-internal a {
	background: #fff;
	border: 3px solid #169a5a;
}

.btn-internal a::after {
	content: "";
	position: absolute;
	z-index: 10;
	top: 0;
	right: 2rem;
	width: 4.4rem;
	height: 100%;
	background: url("./img/arrow_gr.svg") 99% calc(50% + 1px) no-repeat;
	background-size: 2.4rem auto;
	transition: all .4s ease-in-out;
}



.btn-web a {
	padding: 1.0rem 7rem 1.2rem 8rem;
	background: #fabd0e;
	border: 3px solid #fabd0e;
	box-shadow: .6rem .6rem 0 0 #ba8b0b;
}

.btn-web a::after {
	content: "";
	position: absolute;
	z-index: 10;
	top: 0;
	left: 3rem;
	width: 4rem;
	height: 100%;
	background: url("./img/icon_cart.svg") 0 calc(50% + 1px) no-repeat;
	background-size: 4rem auto;
	transition: all .4s ease-in-out;
}

.btn-web a:hover::after {}


.btn-web2 a {
	background: #bf0000;
	border: 3px solid #bf0000;
	box-shadow: .6rem .6rem 0 0 #800000;
	color: #fff;
}

.btn-web2 a::after {
	background-image: url("./img/icon_cart_wt.svg");
}

.btn-web2 a:hover::after {
	background-image: url("./img/icon_cart.svg");
}

.btnWebWrap {
	position: relative;
	margin: 3.6rem 0;
	text-align: center;
}

.btnWebWrap .fuki {
	position: relative;
	z-index: 2;
	width: 40rem;
	margin: 0 auto -4rem;
	text-align: left;
}

.btnWebWrap .fuki .inner {
	position: relative;
	display: inline-block;
	margin: 0 0 -1rem 2rem;
	padding: 1rem 2rem 1.2rem;
	background: #4f3b20;
	border-radius: 1rem;
	box-shadow: .4rem .4rem 0 0 #40301a;
	line-height: 1;
	font-weight: 900;
	color: #fff;
}

.btnWebWrap .fuki .inner .fontS {
	vertical-align: top;
}

.btnWebWrap .fuki .inner::before {
	content: "";
	position: absolute;
	bottom: -1.4rem;
	left: 2.5rem;
	width: 1.7rem;
	height: 1.5rem;
	background: url(./img/tri1.svg) 0 100% no-repeat;
	background-size: 1.7rem auto;
	filter: drop-shadow(4px 3px 0px #40301a);
}

.btnWebWrap .caption {
	width: 40rem;
	margin: -1.0rem auto;
	text-align: left;
}



.btn-tel {
	display: none;
}

.btn-tel a {
	padding: 1.0rem 7rem 1.2rem 8rem;
	background: #169a5a;
	box-shadow: .6rem .6rem 0 0 #23684a;
	color: #fff;
}

.btn-tel a::after {
	content: "";
	position: absolute;
	top: 0;
	left: 3.2rem;
	width: 2.7rem;
	height: 100%;
	background: url(./img/ico_tel.svg) 0 50% no-repeat;
	background-size: 2.5rem auto;
}




.btn-link {
	position: relative;
	z-index: 1;
	margin: 2rem 0;
	text-align: right;
}

.btn-link a {
	position: relative;
	display: inline-block;
	padding: 4rem 6rem 4rem 0;
	line-height: 1.5;
	text-align: right;
	font-weight: 900;
}

.btn-link a::before {
	content: "";
	position: absolute;
	top: 0;
	right: 3.5rem;
	width: 1.7rem;
	height: 100%;
	background: url("./img/arrow_gr.svg") 99% calc(50% - 0px) no-repeat;
	background-size: 1.7rem auto;
	transition: all .3s ease-in-out;
}

.btn-link a::after {
	content: "";
	position: absolute;
	z-index: -1;
	top: calc(50% - 4.25rem);
	right: 0;
	width: 8.5rem;
	height: 8.5rem;
	background: #f7edde;
	border-radius: 50%;
	transition: all .3s ease-in-out;
}


/* テキストリンクアニメ */
.btn-link a:hover {
	opacity: 1;
}

.btn-link a:hover::after {
	transition: all .3s ease-in-out;
	transform: scale(.8, .8);
}

.btn-link a.is-active::before {
	animation: arrainm1 .3s ease-in-out forwards;
}

.btn-link a.is-nonactive::before {
	animation: arrainm2 .3s ease-in-out forwards;
}

@keyframes arrainm1 {
	0% {
		transform: translate(0, 0);
		opacity: 1;
	}

	33% {
		transform: translate(50%, 0);
		opacity: 0;
	}

	66% {
		transform: translate(-50%, 0);
		opacity: 0;
	}

	100% {
		transform: translate(0, 0);
		opacity: 1;
	}
}

@keyframes arrainm2 {
	0% {
		transform: translate(0, 0);
		opacity: 1;
	}

	33% {
		transform: translate(-50%, 0);
		opacity: 0;
	}

	66% {
		transform: translate(50%, 0);
		opacity: 0;
	}

	100% {
		transform: translate(0, 0);
		opacity: 1;
	}
}


.btn-link.outlink a::before {
	content: "";
	position: absolute;
	top: 0;
	right: 3.7rem;
	width: 1.3rem;
	background-image: url("./img/arrow_gr_45.svg");
	background-size: 1.3rem auto;
}










/* ================== */
/*  テーブル　　　　　*/
/* ================== */
table {
	width: 98%;
	margin: 5rem auto 7rem;
}

table th {
	width: 22%;
	padding: 1.6rem 1.5rem;
	background: #f7f5f3;
	border: 1px solid #b7b5b4;
	font-weight: 900;
	font-size: 1.6rem;
	line-height: 1.6;
	text-align: center;

	word-break: break-all;
}

table td {
	background: #fff;
	border: 1px solid #b7b5b4;
	padding: 1.6rem 1.5rem;
	line-height: 1.6;
	word-break: break-all;
}

table a {
	text-decoration: underline;
}

table a:hover {
	text-decoration: none;
}

table td .caption {
	white-space: normal;
}






/* ================== */
/*  PCカスタマイズ共通　*/
/* ================== */
.caption,
.source {
	margin: 10px 0 0;
	padding: 0 0 4px;
	font-size: 1.0rem;
	line-height: 1.5;
	color: #999;
	/*overflow: auto;*/
	letter-spacing: 0;
	text-align: center;
	word-break: break-all;

	overflow: auto;
	white-space: nowrap;
}

/*
.caption{
-ms-overflow-style: none;
scrollbar-width: none;
}
*/
.caption::-webkit-scrollbar {
	height: 3px;
}

.caption::-webkit-scrollbar-track {
	border-radius: 3px;
	background: #eee;
}

.caption::-webkit-scrollbar-thumb {
	border-radius: 3px;
	background: #bbb;
}

.caption a {
	display: inline;
	color: #999;
	text-decoration: underline;
}

.caption a:hover {
	text-decoration: none;
}




.marker {
	position: relative;
	display: inline;
	background: linear-gradient(transparent 65%, rgba(250, 189, 14, .5) 0%) no-repeat bottom 0 left;
	/*border-bottom: 3px solid #e76400;*/
	/*background: linear-gradient(transparent 88%, #e76400 0%) no-repeat bottom 0 left; */
	padding: 0 .5% 0;
	margin: 0 .5%;
	font-weight: 900;
	line-height: 1;
}

.txt_bold {
	font-weight: 900;
	color: #ee5c21;
}


/* float-wrap */

.float-wrap {
	margin: 50px 0;
	padding: 0 20px;
}

.float-wrap .catch {
	margin: 0 0 15px;
	font-size: 2.2rem;
	color: #ee5c21;
}


.float-wrap .flame {
	position: relative;
}


.float-wrap img {
	width: auto;
}

.float-wrap p {
	margin: 10px 0;
	padding: 0;
}

.float-wrap ul {
	display: inline-block;
	margin: 10px 0;
}

.float-wrap .fl {
	width: 320px;
	padding: 0 30px 20px 0;
	text-align: left;
}

.float-wrap .fr {
	width: 320px;
	padding: 0 0 20px 30px;
	text-align: left;
}

.float-wrap .ct {
	width: auto;
	margin: 0 auto;
	padding: 0 0 20px;
	text-align: center;
}



/* ================== */
/*  サイトマップ*/
/* ================== */
.smap h2 {
	margin: 0 0 25px;
}

.smap ul {
	margin: 0 0 70px;
}






/* ================== */
/*  追加パーツ*/
/* ================== */



/*--------------------------------------
　mokuji_PC
---------------------------------------*/

.mokuji {
	transition: .3s;
	/*デフォルトで非表示にする*/
	opacity: 1;
	/*visibility: hidden;*/
}

/*このクラスが付与されると表示する*/
.mokuji.active {
	opacity: 1;
	visibility: visible;
}

/*このクラスが付与されると停止する*/
.mokuji.absolute {}


.mokuji {
	position: relative;
	margin: 3rem 10rem 10rem;
}

.mokuji .inner {
	position: relative;
	padding: 1rem 4rem 0;
	background: #fff;
	border: 2px solid #ebd3a9;
	border-radius: 2rem;
}

.mokuji .inner::before {
	content: "";
	position: absolute;
	top: 2.4rem;
	left: 9.5rem;
	width: 10rem;
	height: 1.9rem;
	background: url("./img/eng_idx.svg") 0 0 no-repeat;
	background-size: auto 1.9rem;
}

.mokuji .sttl {
	margin: 0 0 1rem;
	padding: .8rem 0 1.6rem;
	border-bottom: 1px solid #b7b5b4;
	font-size: 2.0rem;
}

.mokuji .sttl::before {
	content: "";
	position: absolute;
	top: .7rem;
	left: -4rem;
	width: .8rem;
	height: calc(100% - 1.8rem);
	background: #169a5a;
}


.mokuji #toc {
	padding: 0 0 2rem;
	position: relative;
	height: auto;
	max-height: 12rem;
	overflow: hidden;
	transition: max-height 1s;
}

.mokuji #toc ul {
	margin: 0;
	padding: 5px 0 5px;
}

.mokuji #toc ul li {
	position: relative;
	margin: 2px 0;
	padding: 2px 0 2px 4rem;
	text-align: left;
	line-height: 1.4;
}

.mokuji #toc ul li.chapter-h-two {
	counter-increment: count;
}

.mokuji #toc ul li.chapter-h-two::before {
	content: counter(count, decimal-leading-zero)".";
	/*2桁対応*/
	position: absolute;
	top: 1rem;
	left: 0;
	transform: translate(0, -50%);
	background: none;
	font-size: 1.6rem;
	font-weight: 900;
	color: #e76400;
	top: 50%;
	width: auto;
	height: auto;
}

.mokuji li a {
	display: inline-block;
	width: auto;
	padding: 5px 0;
	background: none;
	font-weight: 500;
	font-size: 1.6rem;
	text-decoration: none;
}

.mokuji #toc ul li.chapter-h-two a {
	font-weight: 900;
}

.mokuji #toc ul ul {
	margin: 0;
	padding: 0 0 2px;
}

.mokuji #toc ul li.chapter-h-three {
	padding: 0 0 0 6rem;
}

.mokuji #toc ul li.chapter-h-three::after {
	content: "";
	position: absolute;
	top: 0;
	left: 4.5rem;
	width: 8px;
	height: 100%;
	background: url("./img/l_deco.png") 0 6px no-repeat;
	background-size: 8px auto;
}

.mokuji #toc ul li.chapter-h-three::before {
	width: 0;
	height: 0;
	background: none;
	border: none;
}

.mokuji li br {
	display: none;
}

/*----------------------------------------------
	more content settings
*/



.mokuji #toc.is-open::after {
	display: none;
}

.js-more-gr-btn {
	max-width: 32rem;
	margin: 1rem auto 0 auto;
	padding: 1rem 6rem;
	border: 1px solid #169a5a;
	background-color: #fff;
	text-align: center;
	position: relative;
	transition: opacity 0.3s;
	cursor: pointer;
	border-radius: 50vh;
	top: 2.3rem;
}

.js-more-gr-btn::before {
	content: "";
	width: 2rem;
	height: .2rem;
	background: #000;
	position: absolute;
	top: 50%;
	right: 3rem;
	transform: translate(0, -50%);
}

.js-more-gr-btn::after {
	content: "";
	width: .2rem;
	height: 2rem;
	background: #000;
	position: absolute;
	top: 50%;
	right: 3.9rem;
	transform: translate(0, -50%);
	transition: transform 0.3s;
}

.js-more-gr-btn.is-open::after {
	transform: translate(0, -50%) rotate(270deg);
}

/* accordion_grd */
.mokuji .text {
	/*height: 120px;
overflow: hidden;*/
}

.mokuji .show_more2 {
	position: absolute;
	bottom: 0;
	left: 0px;
	width: 100%;
	height: 70px;
	padding-top: 60px;
	text-align: center;
	line-height: 70px;
	background: linear-gradient(180deg,
			rgb(245, 245, 237, 0) 0%,
			rgb(245, 245, 237, 1) 40%);
	border-radius: 0 0 15px 15px;
	cursor: pointer;
	transition: bottom 0.2s;
}

.mokuji .active {
	background: none;
	/*bottom: -20px;*/
}

.mokuji .show_more2 span {
	position: relative;
	top: -3rem;
	display: inline-block;
	width: 34rem;
	min-height: 6rem;
	padding: 1.5rem 3rem 1.6rem;
	background: url(./img/plus.svg) 92% calc(50% - 1px) no-repeat #fff;
	background-size: 1.9rem auto;
	border-radius: 9999px;
	border: 1px solid #262626;
	text-align: center;
	line-height: 1.5;
	font-weight: 900;
	font-size: 1.6rem;
}

.mokuji .active span {
	background: url(./img/minus.svg) 90% 50% no-repeat #fff;
	background-size: 1.9rem auto;
}








/* relations_PC */
.relations {
	position: relative;
	margin: 10rem 10rem 0;
}

.relations .inner {
	position: relative;
	padding: 1rem 4rem 2rem;
	background: #fff;
	border: 2px solid #ebd3a9;
	border-radius: 2rem;
}

.relations .inner::before {
	content: "";
	position: absolute;
	top: 2.4rem;
	left: 13.5rem;
	width: 8rem;
	height: 1.9rem;
	background: url("./img/eng_link.svg") 0 0 no-repeat;
	background-size: auto 1.9rem;
}

.relations .relations-title {
	position: relative;
	margin: 0 0 2rem;
	padding: .8rem 0 1.6rem;
	border-bottom: 1px solid #b7b5b4;
	line-height: 1.5;
	font-size: 2.0rem;
	font-weight: 900;
}

.relations .relations-title::before {
	content: "";
	position: absolute;
	top: .7rem;
	left: -4rem;
	width: .8rem;
	height: calc(100% - 1.8rem);
	background: #169a5a;
}


.relations .relations-wrapper {
	position: relative;
	padding: 0 0 5px;
}

.relations ul {
	margin: 0;
}

.relations ul li {
	position: relative;
	margin: 4px 0;
	padding: 0 0 0 0 !important;
	text-align: left;
	line-height: 1.2;
}

.relations ul li::before {
	width: 0 !important;
	height: 0 !important;
	background: none !important;
	border: none !important;
}

.relations li a {
	position: relative;
	display: inline-block;
	width: auto;
	padding: 0 0 0 2.0rem;
	font-size: 1.5rem;
	text-decoration: none;
}

.relations li a::before {
	content: "";
	position: absolute;
	z-index: 10;
	top: 1.4rem;
	left: 0;
	width: 1.2rem;
	height: 1.2rem;
	background: #ef5c22;
	border-radius: 50%;
	transition: all .2s ease-in-out;
}

.relations li a:hover::before {}

.relations ul li a::after {}

.relations ul li a:hover::after {}

.relations li p {
	margin: 10px 0;
}




/* btns_PC */
.btns {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-end;
	padding: 1rem 6% 2rem;
}

.btns>div {
	/*display: flex;*/
	width: 44%;
	margin: 2rem 2rem 1rem;
}

.btns .btn-internal a,
.btns .btn-web a,
.btns .btn-tel a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.btns .btn-tel {
	display: none;
}

.btns .btnWebWrap div {
	margin: 0;
}

.btns .btnWebWrap .caption {
	margin: 2rem 0 0;
}

.btns .caption {
	width: 92%;
	margin: 1rem 0 0;
	text-align: left;
}

.btns .caption2 span {
	display: block;
	margin: 1rem 0 0;
}









/* check_PC */
.check {
	position: relative;
	margin: 4rem 0 4rem 4rem;
	padding: 1.8rem 1rem 2.0rem 6.5rem;
	background: #f7edde;
	border-radius: 1rem;
	font-size: 2.2rem;
	font-weight: 900;
	line-height: 1.5;
}

.check::before {
	content: "";
	position: absolute;
	top: calc(50% - 4.25rem);
	left: -4rem;
	width: 8.5rem;
	height: 8.5rem;
	background: url("./img/iconttl_ck.png") 0 0 no-repeat;
	background-size: 8.5rem auto;
}

.point {
	position: relative;
	margin: 4rem 0 4rem 4rem;
	padding: 1.8rem 1rem 2.0rem 6.5rem;
	background: #f7edde;
	border-radius: 1rem;
	font-size: 2.2rem;
	font-weight: 900;
	line-height: 1.5;
}

.point::before {
	content: "";
	position: absolute;
	top: calc(50% - 4.25rem);
	left: -4rem;
	width: 8.5rem;
	height: 8.5rem;
	background: url("./img/iconttl_pt.png") 0 0 no-repeat;
	background-size: 8.5rem auto;
}


.num {
	position: relative;
	margin: 4rem 0 4rem 4rem;
	padding: 1.8rem 1rem 2.0rem 6.5rem;
	background: #f7edde;
	border-radius: 1rem;
	font-size: 2.2rem;
	font-weight: 900;
	line-height: 1.5;
}

.num::before {
	content: "";
	position: absolute;
	top: calc(50% - 4.25rem);
	left: -4rem;
	width: 8.5rem;
	height: 8.5rem;
	background: url("./img/iconttl_num.png") 0 0 no-repeat;
	background-size: 8.5rem auto;
}

.num .fontNum {
	position: absolute;
	top: calc(50% - 4.25rem);
	left: -4rem;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 8.5rem;
	height: 8.5rem;
	font-size: 2.4rem;
	font-weight: 900;
	line-height: 1;
	color: #fff;
}






/* talk_PC */
.talks {
	position: relative;
	margin: 8rem 0;
}

.talk {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
	margin: 0 0 5rem;
	padding: 4.5rem 5rem 2.5rem;

	flex-direction: row-reverse;

	background: #fff;
	border: 4px solid #169a5a;
	border-radius: 3rem 12rem 3rem 3rem;
}

.talk .imgArea {
	width: 18rem;
	margin: -2.5rem 0 0 5rem;
}

.talk .imgArea .flame {}

.talk .imgArea img {
	border-radius: 50%;
}

.talk .cap {
	position: relative;
	padding: 1.0rem 2rem 0;
	line-height: 1.5;
	text-align: center;
	font-size: 1.4rem;
}


.talk .txtArea {
	flex: 1;
	position: relative;
}

.talk .txtArea .inner {
	position: relative;
	/*padding: 25px 5rem 22px;*/
}

.talk .txtArea .catch {
	display: inline-block;
	margin: 0 0 1.5rem;
	font-size: 2.4rem;
	color: #ee5c21;
}

.talk .txtArea .catch span {
	position: relative;
}

.talk .txtArea .catch::before {
	content: "";
	position: absolute;
	top: -1.8rem;
	left: -2.5rem;
	width: 5rem;
	height: 5rem;
	background: url("./img/quote_a.png") 0 0 no-repeat;
}

.talk .txtArea .catch::after {
	content: "";
	position: absolute;
	bottom: -2.5rem;
	right: -2.5rem;
	width: 5rem;
	height: 5rem;
	background: url("./img/quote_b.png") 0 0 no-repeat;
}



/* bfaf_PC */
.bfaf {
	position: relative;
	margin: 15rem 0;
	padding: 3rem 0 8rem;
	background: #f7edde;
	border-radius: 3rem;
}

.bfaf::before {
	content: "";
	position: absolute;
	top: 1rem;
	right: 2rem;
	width: 23rem;
	height: 34rem;
	background: url("./img/bg_vege01.svg") 100% 0 no-repeat;
	background-size: 23rem auto;
	opacity: .1;
}

.bfaf .sttl {
	margin: 0 0 4rem 5rem;
	padding: 1.0rem 5rem 2.5rem 0;
	border-bottom: 1px solid #b7b5b4;
	font-size: 3.4rem;
}

.bfaf .sttl::before {
	content: "";
	position: absolute;
	top: .7rem;
	left: -5rem;
	width: 1rem;
	height: calc(100% - 2.5rem);
	background: #169a5a;
}

.bfaf .headtxt .note {
	position: relative;
	padding: 0 0 3rem;
	line-height: 1.5;
	font-size: 1.8rem;
	font-weight: 900;
	z-index: 0;
}

.bfaf .headtxt .note .fontL {
	position: relative;
	font-size: 4.2rem;
	color: #ee5c21;
	font-weight: 900;
}

.bfaf .headtxt .note .fontL::before {
	content: "";
	position: absolute;
	top: -2rem;
	left: calc(50% - 8rem);
	width: 10rem;
	height: 10rem;
	background: #fabd0e;
	border-radius: 50%;
	opacity: .4;
	z-index: -1;
}


.bfaf .imgArea {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	padding: 0 5rem 4rem;
}

.bfaf .imgArea .areaL {
	position: relative;
	width: 32.4rem;
}

.bfaf .imgArea .areaR {
	position: relative;
	width: 48rem;
}


.bfaf .areaL .flame {
	position: relative;
	padding: 4rem 0 0;
}

.bfaf .areaL .flame::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 14rem;
	height: 2.6rem;
	background: url("./img/eng_bf.svg") 0 0 no-repeat;
	background-size: auto 2.6rem;
	opacity: .8;
}

.bfaf .areaL .flame::after {
	content: "";
	position: absolute;
	top: 0;
	right: -6rem;
	width: 2.6rem;
	height: 100%;
	background: url("./img/tri2.svg") 0 50% no-repeat;
	background-size: 2.6rem auto;
}

.bfaf .areaR .flame {
	position: relative;
	padding: 5rem 0 0;
}

.bfaf .areaR .flame::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 15rem;
	height: 3.4rem;
	background: url("./img/eng_af.svg") 0 0 no-repeat;
	background-size: auto 3.4rem;
}

.bfaf .imgArea img {
	border-radius: 2rem;
}


.bfaf .txtArea {
	padding: 0 5rem 3rem;
}

.bfaf .tblArea {
	padding: 0 5rem;
}

.bfaf table {
	width: 100%;
	border-collapse: separate;
	margin: 0;
}

.bfaf th {
	border-bottom: none;
	font-size: 1.8rem;
	color: #169a5a;
}

.bfaf td {
	border: none;
	border-right: 1px solid #b7b5b4;
	border-top: 1px solid #b7b5b4;
}

.bfaf table tr:first-child th {
	border-radius: 2rem 0 0 0;
}

.bfaf table tr:first-child td {
	border-radius: 0 2rem 0 0;
}

.bfaf table tr:last-child th {
	border-radius: 0 0 0 2rem;
	border-bottom: 1px solid #b7b5b4;
}

.bfaf table tr:last-child td {
	border-radius: 0 0 2rem 0;
	border-bottom: 1px solid #b7b5b4;
}





/* sum_PC */
.sum {
	position: relative;
	margin: 15rem 0;
	padding: 3.5rem 5rem 2rem;
	background: #f7edde;
	border-radius: 3rem 12rem 3rem 3rem;
}

.sum .inner {
	position: relative;
}

.sum .logo {
	position: absolute;
	top: .5rem;
	right: 4rem;
	width: 21rem;
}

.sum .catch {
	padding: 1.5rem 30rem 1.5rem 0;
	font-size: 2.4rem;
}

.sum .catch::before {
	content: "";
	position: absolute;
	top: 1.0rem;
	left: -5rem;
	width: 1rem;
	height: calc(100% - 2.5rem);
	background: #ef5c22;
}

.sum .btn-link {
	margin: -2.0rem 0 0;
}

.sum .btn-link a::after {
	background: #fff;
}









/* spv_PC */
.spv {
	position: relative;
	margin: 10rem 0;
	padding: 4.5rem 5rem 2rem;
	border: 4px solid #169a5a;
	border-radius: 3rem;
}

.spv::before {
	content: "";
	position: absolute;
	bottom: 2.5rem;
	right: 2rem;
	width: 27rem;
	height: 28rem;
	background: url("./img/bg_vege02.svg") 0 0 no-repeat;
	background-size: 27rem auto;
	opacity: .1;
}

.spv .inner {
	position: relative;
	padding: 0 0 0 38rem;
}

.spv .boxTtl {
	position: absolute;
	top: 1rem;
	right: -4rem;
	font-size: 2.0rem;
	font-weight: 900;
	color: #169a5a;
	letter-spacing: .2em;
	font-family: "Noto Sans JP vt";
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

.spv .boxTtl::before {
	content: "";
	position: absolute;
	top: -.7rem;
	right: -1rem;
	width: 1rem;
	height: calc(100% + 1.2rem);
	background: #169a5a;
}


.spv .sttl {
	margin: 0 0 2.5rem;
	font-size: 1.8rem;
}

.spv .sttl img {
	width: 18rem;
	margin: 0 1rem 0 0;
	vertical-align: middle;
}

.spv .imgArea {
	position: absolute;
	top: 2.5rem;
	left: 0;
	width: 33rem;
}

.spv .flame {
	width: 33rem;
	height: 33rem;
	margin: 0 0 3rem;
}

.spv .flame img {
	width: 100%;
	object-fit: cover;
	border-radius: 2rem 8rem 2rem 2rem;
}

.spv .cap {
	text-align: center;
	font-size: 2.0rem;
	font-weight: 900;
}

.spv .cap .fuki {
	display: inline-block;
	margin: 0 0 .8rem;
	padding: .8rem 2rem 1.0rem;
	background: #4f3b20;
	border-radius: 9999px;
	line-height: 1;
	font-size: 1.6rem;
	color: #fff;
}

.spv .cap .fontS {
	font-size: 1.6rem;
}

.spv .catch {
	font-size: 2.4rem;
	color: #ee5c21;
}

.spv ul {
	margin: 0 0 1rem;
	padding: 0;
}

.spv .btn-web a::after {
	top: 0;
	left: auto;
	right: 2rem;
	width: 4.4rem;
	height: 100%;
	background: url(./img/arrow_bk.svg) 99% calc(50% + 1px) no-repeat;
	background-size: 2.4rem auto;
}





/* qa_PC */
.qaWrap {
	padding: 2rem 0 3rem;
}

.qa {
	padding: 2rem 0;
}

.qa .sttl {
	margin: 0 0 3rem;
	padding: 0 0 0 5rem;
	font-size: 2.0rem;
	line-height: 1.8;
}

.qa .sttl::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 4.1rem;
	height: 3.2rem;
	background: url("./img/eng_q.svg") 0 0 no-repeat;
	background-size: 4.1rem auto;
}

.qa .ansBox {
	position: relative;
	background: #f7edde;
	border-radius: 8rem 2rem 2rem 2rem;
	padding: 3rem 5rem 2rem 22rem;
}

.qa .catch {
	margin: 0 0 0;
	padding: 0 0 0 6rem;
	font-size: 2.0rem;
	line-height: 1.8;
	color: #169a5a;
}

.qa .catch::before {
	content: "";
	position: absolute;
	top: 1rem;
	left: 0;
	width: 4.5rem;
	height: 3.2rem;
	background: url("./img/eng_a.svg") 0 0 no-repeat;
	background-size: 4.5rem auto;
}

.qa .ansBox .imgArea {
	position: absolute;
	top: 3.5rem;
	left: 5rem;
	width: 14rem;
}

.qa .ansBox .imgArea .flame {
	width: 14rem;
	height: 14rem;
}

.qa .ansBox .flame img {
	width: 100%;
	object-fit: cover;
	border-radius: 50%;
}

.qa .ansBox .cap {
	position: relative;
	margin: -1rem 0 0;
	text-align: center;
	font-size: 2.0rem;
	font-weight: 900;
}

.qa .ansBox .cap .fuki {
	display: block;
	margin: 0 0 .8rem 0;
	padding: .8rem 2rem 1.0rem;
	background: #4f3b20;
	border-radius: 9999px;
	line-height: 1;
	font-size: 1.6rem;
	color: #fff;
}

.qa .ansBox .cap .fontS {
	font-size: 1.6rem;
}




/*--------------------------------------
　botCommon_PC
---------------------------------------*/
.botCommon {
	position: relative;
	padding: 14rem 0 9rem;
}

.mainWrap+.botCommon {
	padding: 19rem 0 14rem;
}

.mainWrap+.botCommon::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 5rem;
	background: #fff;
	border-radius: 0 0 8rem 8rem;
}



.botCommon .areaInner {
	width: 112rem;
	background: #169a5a;
	padding: 1.6rem;
	border-radius: .6rem;
}

.botCommon .areaInner2 {
	position: relative;
	background: #fff;
	border-radius: 3rem;
	padding: 6rem 4.6rem 4rem;
}

.botCommon .boxTtl {
	position: absolute;
	top: 4rem;
	right: 1.0rem;
	font-size: 2.0rem;
	font-weight: 900;
	color: #169a5a;
	letter-spacing: .2em;
	font-family: "Noto Sans JP vt";
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

.botCommon .boxTtl::before {
	content: "";
	position: absolute;
	top: -.7rem;
	right: -1rem;
	width: 1rem;
	height: calc(100% + 1.2rem);
	background: #169a5a;
}

.botCommon .mainArea {
	padding: 0 5rem 0 5.5rem;
}

.botCommon .imgArea {
	position: relative;
	width: 39rem;
	float: left;
	padding: 2.5rem 4.5rem 5.5rem;
	text-align: center;
}

.botCommon .imgArea::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 24.3rem;
	height: 24.3rem;
	background: #f7edde;
	border-radius: 50%;
}

.botCommon .imgArea .flame {
	position: relative;
	margin: 0 0 4rem;
}

.botCommon .txtArea {
	width: 50rem;
	float: right;
	padding: 3rem 0 0;
}

.botCommon .txtArea .headArea {
	margin: 0 0 2.5rem;
	padding: 0 0 2.0rem;
	border-bottom: 1px solid #b7b5b4;
}

.botCommon .txtArea .sttl {
	margin: 0 0 .5rem;
	font-size: 2.0rem;
}

.botCommon .txtArea .sttl .line1 {
	display: block;
	margin: 0 0 1.5rem;
}

.botCommon .txtArea .sttl .fontL {
	font-size: 3.4rem;
}

.botCommon .txtArea .sttl .txt_bold {
	display: block;
	text-align: center;
	color: #ee5c21;
	font-size: 5.2rem;
}

.botCommon .txtArea .sps {
	line-height: 1.5;
	text-align: right;
}


.botCommon .ssttl {
	margin: 0 0 1.5rem;
	font-size: 2.2rem;
	font-weight: 900;
	line-height: 1.5;
	text-align: center;
	color: #169a5a;
}

.botCommon .mini {
	margin: 0 0 1.8rem;
}

.botCommon .mini .catch {
	margin: 0 0 .5rem;
	padding: 0 0 0 4rem;
}

.botCommon .mini .catch::before {
	content: "";
	position: absolute;
	top: 1rem;
	left: 0;
	width: 3rem;
	height: 1.2rem;
	background: url("./img/num_01_red.svg") 0 0 no-repeat;
	background-size: auto 1.2rem;
}

.botCommon .miniArea .mini:nth-child(2) .catch::before {
	background-image: url("./img/num_02_red.svg");
}

.botCommon .miniArea .mini:nth-child(3) .catch::before {
	background-image: url("./img/num_03_red.svg");
}

.botCommon .btn-web a {
	font-size: 2.0rem;
}


.botCommon .btn-link {
	margin: -2rem 0 0;
}



/*--------------------------------------
　about_PC
---------------------------------------*/

.about {
	position: relative;
	z-index: 14;
	padding: 13rem 0 13rem;
	background: #f7edde;
}

.about .inner {
	position: relative;
	width: 100rem;
	margin: 0 auto;
	padding: 5.0rem 5rem 2rem;
	background: #fff;
	border-radius: 3rem 12rem 3rem 3rem;
}

.about .inner::before {
	content: "";
	position: absolute;
	top: 5.5rem;
	right: 5rem;
	width: 17rem;
	height: 3.3rem;
	background: url(./img/eng_about.svg) 0 0 no-repeat;
	background-size: auto 3.3rem;
	opacity: .3;
}

.about .sttl::before {
	content: "";
	position: absolute;
	top: 0rem;
	left: -5rem;
	width: 1rem;
	height: calc(100% - 0rem);
	background: #169a5a;
}

.about .txtArea {
	font-size: 1.5rem;
}

.about .sttl {
	padding: .6rem 0;
	margin: 0 0 2rem;
}

.about .btn-link {
	margin: -2rem 0 0;
}



/* End_PC */







@media screen and (max-width: 480px) {


	/*------------
common--480px
------------*/

	html {}

	.mainWrap .catch,
	.mainWrap .sttl,
	.index .catch,
	.index .sttl {
		font-size: 1.8rem;
	}

	#contents {
		position: relative;
		z-index: 0;
	}



	body {
		min-width: 320px;
		text-align: left;
		line-height: 1.9;
		word-break: break-all;
		overflow-x: hidden;
	}


	.sp,
	.sp_br {
		display: block !important;
	}

	.pc,
	.pc_br {
		display: none !important;
	}

	img:not([width]) {
		width: 100%;
		height: auto;
		max-width: 100%;
	}

	a {
		text-decoration: none;
	}

	a:hover,
	a:hover img {
		opacity: 1;
	}

	.areaInner {
		width: auto;
		margin: 0;
	}






	/* notice 30px_4% */



	/*--------------------------------------
　body_SP
---------------------------------------*/





	/*--------------------------------------
　header_SP
---------------------------------------*/
	#header {
		position: relative;
		z-index: 14;
		height: 20rem;
	}

	#header .topArea2 {
		position: absolute;
		top: .8rem;
		right: auto;
		left: 5%;
		text-align: left;
		font-weight: 500;
		font-size: 1.0rem;
		line-height: 1.6;
		color: #fff;
		z-index: 1;
	}

	#header .siteName {
		display: block;
	}

	#header .siteName a {
		color: #fff;
	}

	#header .siteSps {
		display: block;
	}



	#header .logo {
		width: 12.5rem;
		margin: 00;
		padding: 6.0rem 0 .5rem;
	}

	#header .logo img {
		width: 100%;
	}


	#header .mvbg {
		position: absolute;
		z-index: -1;
		top: 0;
		left: 0;
		width: 320%;
		height: 20rem;
		overflow: hidden;
	}

	#header .mvbg img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: 0 0;
	}




	/*--------------------------------------
Main Contents_SP
---------------------------------------*/

	#contents {
		position: relative;
		z-index: 14;
		width: 100%;
		overflow-x: hidden;
		margin: -3rem 0 0;
		padding: 0 0 0;
	}

	#contents::before {
		content: "";
		position: absolute;
		z-index: -1;
		top: 8rem;
		left: 0;
		width: 100%;
		height: calc(100% - 8rem);
		background: #f7edde;
	}

	.mainWrap {
		position: relative;
		z-index: 1;
		padding: .7rem 0 2.5rem;
		background: #fff;
		border-radius: 3rem 3rem 0 0;
		min-height: 0;
		width: auto;
		float: none;
	}

	.mainWrap>.areaInner {
		padding: 0 0 2.5rem;
	}









	/*--------------------------------------
pankuzu_SP
---------------------------------------*/

	#pankuzuWrap {
		overflow: auto;
		white-space: nowrap;
		margin: 0 5% 0;
		padding: 10px 0 0;
		position: static;
		box-sizing: border-box;
		width: auto;
	}

	#pankuzuWrap::-webkit-scrollbar {
		height: 3px;
	}

	#pankuzuWrap::-webkit-scrollbar-track {
		border-radius: 3px;
		background: #eee;
	}

	#pankuzuWrap::-webkit-scrollbar-thumb {
		border-radius: 3px;
		background: #bbb;
	}

	#pankuzu {
		width: 100%;
		margin: 0 auto 10px;
		padding: 0 0;
		font-size: 1.1rem;
	}

	#pankuzu a {
		text-decoration: underline;
	}




	/*--------------------------------------
　page-top_SP
---------------------------------------*/
	#page-top {
		position: fixed;
		z-index: 101;
		bottom: 2%;
		right: 2%;
		width: 5.5rem;
	}

	#page-top {
		transition: .3s;
		/*デフォルトで非表示にする*/
		opacity: 0;
		visibility: hidden;
	}

	/*このクラスが付与されると表示する*/
	#page-top.active {
		opacity: 1;
		visibility: visible;
	}

	/*このクラスが付与されると表示する*/
	#page-top.absolute {}








	/*--------------------------------------
　Global Nav_SP
---------------------------------------*/
	#gNav {
		position: fixed;
		top: 1rem;
		right: 1rem;
		z-index: 10000;


		transition: .3s;
		/*デフォルトで非表示にする*/
		opacity: 0;
		visibility: hidden;
	}

	/*このクラスが付与されると表示する*/
	#gNav.active {
		opacity: 1;
		visibility: visible;
	}


	/* ハンバーガーメニュー */
	#gNav #showRight {
		width: 5rem;
		position: fixed;
		top: .8rem;
		right: .5rem;
		z-index: 10000;
	}

	#gNav button {
		position: relative;
		width: 5rem;
		height: 4rem;
		background: #fff;
		box-shadow: -1px 0px 20px 0px rgba(0, 0, 0, 0.2);
		border-radius: 2rem;
		transition: all .2s ease-in-out;
	}


	#gNav button span {
		position: absolute;
		left: 32%;
		width: 36%;
		height: 1px;
		background-color: #1b140b;
		transition: .3s all;
	}

	#gNav button span:nth-child(1) {
		top: 35%;
	}

	#gNav button span:nth-child(2) {
		top: calc(35% + .6rem);
	}

	#gNav button span:nth-child(3) {
		top: calc(35% + 1.2rem);
	}

	#gNav button.active span:nth-child(1) {
		transform: translateY(6px) rotate(-45deg);
	}

	#gNav button.active span:nth-child(2) {
		opacity: 0;
	}

	#gNav button.active span:nth-child(3) {
		transform: translateY(-6px) rotate(45deg);
	}

	/*#gNav button.active{
background: url(./img/sp-btn-menu_off.png) 0 0 no-repeat;
background-size: 5.2rem auto;
}
#gNav button.active img{
opacity: 0;
}
*/

	/* General styles for all menus */
	#gNav .cbp-spmenu {
		position: fixed;
		margin: 0 0 0;
		padding: 5rem 0 0;
		background: #f7edde;

		overflow: auto;
		-ms-overflow-style: none;
		/* IE, Edge 対応 */
		scrollbar-width: none;
		/* Firefox 対応 */
	}


	#gNav .cbp-spmenu #mainMenu {
		position: relative;
		z-index: 1;
		/*overflow: auto;*/
		overflow: visible;
		margin: 0 0;
		padding: 7rem 0 7rem;
		height: 100%;
	}

	#gNav .cbp-spmenu #mainMenu::-webkit-scrollbar {
		display: none;
		/* Chrome, Safari 対応 */
	}

	#gNav .cbp-spmenu #mainMenu::before {
		content: "";
		position: absolute;
		top: 2.5rem;
		left: 0;
		width: 100%;
		height: 4.5rem;
		background: url(./img/eng_menu.svg) 6.5% 0 no-repeat;
		background-size: auto 2.3rem;
		border-bottom: 1px solid #b7b5b4;
	}


	#gNav .cbp-spmenu a {
		display: block;
		padding: 14px 10% 14px;
		text-decoration: none;
		line-height: 1.3;
		font-size: 1.4rem;
	}

	#gNav .cbp-spmenu li a {
		padding: 16px 10% 16px;
	}

	#gNav .cbp-spmenu .sttl {
		margin: 0;
		font-size: 1.6rem;
		letter-spacing: 0;
	}

	#gNav .cbp-spmenu .sttl a {
		background: url(./img/arrow_bk.svg) calc(100% - 2.0rem) 50% no-repeat;
		background-size: 1.5rem auto;
	}

	#gNav .cbp-spmenu .sttl.tglMenu a {
		background: none;
	}

	#gNav .cbp-spmenu .sttl.tglMenu a::before {
		content: '';
		display: inline-block;
		width: 1.5rem;
		height: .2rem;
		background-color: #1b140b;
		position: absolute;
		right: 2rem;
		top: 50%;
		transform: translateY(-50%);
		transition: opacity .5s;
	}

	#gNav .cbp-spmenu .sttl.tglMenu a::after {
		content: '';
		display: inline-block;
		width: 1.5rem;
		height: .2rem;
		background-color: #1b140b;
		position: absolute;
		right: 2rem;
		top: 50%;
		transform: translateY(-50%) rotate(-90deg);
		transition: transform .5s;
	}

	#gNav .cbp-spmenu .sttl.open a::before {
		opacity: 0;
	}

	#gNav .cbp-spmenu .sttl.open a::after {
		transform: translateY(-50%) rotate(-180deg);
	}



	#gNav .cbp-spmenu .home a {
		background: url(./img/arrow_bk.svg) calc(100% - 2.0rem) 50% no-repeat;
		background-size: 1.5rem auto;
	}

	#gNav .cbp-spmenu .subList a {
		padding: 14px 10% 14px calc(5% + 2em);
		font-weight: 500;
	}

	#gNav .cbp-spmenu li a {
		position: relative;
		background: url(./img/arrow_bk.svg) calc(100% - 2.0rem) 50% no-repeat #fcf8f1;
		background-size: 1.5rem auto;
		padding: 14px 10% 14px calc(5% + 1em);
		font-weight: 500;
	}

	#gNav .cbp-spmenu li a::before {
		content: "";
		position: absolute;
		top: calc(50% - .45rem);
		left: 2rem;
		width: 1.0rem;
		height: 1.0rem;
		background: #169a5a;
		border-radius: 50%;
	}

	#gNav .cbp-spmenu .subList li a::before {
		left: calc(5% + 1em);
	}



	#gNav .cbp-spmenu a:hover {
		opacity: 1;
	}

	#gNav .cbp-spmenu a:active {}

	/* Orientation-dependent styles for the content of the menu */
	#gNav .cbp-spmenu-vertical {
		/*width: calc(100% - 100px);*/
		width: 100%;
		height: 100%;
		top: 0;
		z-index: -1;
	}

	#gNav .cbp-spmenu-vertical a {
		border-bottom: 1px solid #b7b5b4;
		padding: 16px 11% 16px 5%;
	}

	#gNav .cbp-spmenu-vertical .home a {
		border-bottom: 1px solid #b7b5b4;
	}

	#gNav .cbp-spmenu-vertical .smap .home a {
		border-top: none;
	}



	/* Vertical menu that slides from the left or right */
	#gNav .cbp-spmenu-right {
		opacity: 0;
		right: -100%;
		/*right: -280px;*/
		/*right: 0;*/
	}

	#gNav .cbp-spmenu-right.cbp-spmenu-open {
		opacity: 1;
		right: 0;
		z-index: 1000;
	}


	/* Transitions */
	#gNav .cbp-spmenu,
	#gNav .cbp-spmenu-push {
		transition: all 0.3s ease;
	}

	#gNav .accChild {
		display: none;
	}



	/* navBox */
	#gNav .navBox {
		display: flex;
		align-items: center;
		margin: 4rem 5% 0;
		padding: 1.2rem 1.2rem 1.2rem;
		background: #fff;
		box-shadow: none;
		border-radius: 9999px;
	}

	#gNav .navBox .fixBan {
		position: relative;
		display: flex !important;
		align-items: center !important;
		border: none;
		background: #fabd0e;
		width: 55%;
		height: 5rem;
		padding: 0 2rem .3rem 4rem;
		border-radius: 9999px 0 0 9999px;
		line-height: 1;
		font-size: 1.4rem;
		font-weight: 900;
	}

	#gNav .navBox .fixBan:last-child {
		background: #bf0000;
		width: 45%;
		margin: 0 0 0 .6rem;
		padding: 0 2rem .3rem 4rem;
		border-radius: 0 9999px 9999px 0;
		color: #fff;
	}

	#gNav .navBox .fixBan::before {
		content: "";
		position: absolute;
		top: 0;
		left: 1.3rem;
		width: 2.0rem;
		height: 100%;
		background: url(./img/icon_cart.svg) 0 50% no-repeat;
		background-size: 2.0rem auto;
	}

	#gNav .navBox .fixBan:last-child::before {
		background-image: url(./img/icon_cart_wt.svg);
	}



	/*--------------------------------------
　fixNav_SP
---------------------------------------*/

	#fixNav_sp {
		position: fixed;
		z-index: 1001;
		bottom: 0;
		left: 0;
		width: 21rem;

		transition: .3s;
		/*デフォルトで非表示にする*/
		opacity: 0;
		visibility: hidden;
	}

	/*このクラスが付与されると表示する*/
	#fixNav_sp.active {
		opacity: 1;
		visibility: visible;
	}

	/*このクラスが付与されると停止する*/
	#fixNav_sp.absolute {
		/*opacity: 0;
visibility: hidden;*/
	}


	#fixNav_sp .logo {
		position: fixed;
		top: 0;
		left: 0;
		width: 15rem;
		height: 5.4rem;
		padding: 0.9rem 2rem 0 2rem;
		background: #fff;
		box-shadow: -1px 0px 20px 0px rgba(0, 0, 0, 0.2);
		border-radius: 0 0 2rem 0;
	}

	#fixNav_sp .logo a {}





	/*--------------------------------------
　h1Area_SP
---------------------------------------*/
	.h1Area {
		position: relative;
		z-index: 2;
		margin: 0 0 0;
		padding: 5.5rem 5% 2rem;
		text-align: center;
	}

	.h1Area::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 35rem;
		background: url(./img/h1_deco.png) 50% 0 no-repeat;
		background-size: 13.5rem auto;
	}

	.h1Area h1 {
		position: relative;
		margin: 0 0 1.5rem;
		font-size: 2.5rem;
		line-height: 1.4;
	}

	.h1Area .headNote {
		line-height: 1.6;
		font-size: 1.1rem;
	}





	/*--------------------------------------
　Footer_SP
---------------------------------------*/

	footer {
		position: relative;
		z-index: 13;
		width: 100%;
		padding: 3rem 0 0;
		background: url("./img/footbg_sp.jpg") 0 0 no-repeat #452d22;
		background-size: 100% auto;
		background-attachment: scroll;
	}


	footer .footInner {
		width: auto;
		margin: 0;
		padding: 0 0 0;
	}


	footer .footInner .areaL {
		width: auto;
		float: none;
		margin: 0 5% 4rem;
	}

	.footLogo {
		position: relative;
		margin: 0 auto 1.5rem;
	}

	.footLogo .logoImg {
		width: 12.5rem;
		margin: 0 auto 3.0rem;
	}

	footer .noticeArea {}

	footer .noticeArea p {
		font-size: 1.2rem;
	}

	footer .noticeArea p:nth-child(1) {}

	footer .noticeArea a {
		text-decoration: underline;
	}

	footer .noticeArea .botPrg {
		padding: 1.2rem 0 0;
		text-align: center;
	}




	footer .footInner .areaR {
		width: auto;
		float: none;
	}

	footer .footBox {
		margin: 0 0 0;
		/*z-index: 0;*/
	}

	.footBox:first-of-type {
		border-top: 1px solid rgba(255, 255, 255, .5);

	}

	.footBox a {}

	.footBox a:hover {
		opacity: 1;
	}


	.footBox .sttl {
		margin: 0;
		padding: 0;
		border: none;
		background: none;
	}

	.footBox .sttl a {
		display: block;
		padding: 1.2em 10% 1.3em 4%;
		font-size: 1.5rem;
		border-bottom: 1px solid rgba(255, 255, 255, .5);
		text-align: left;
		letter-spacing: 0;
	}

	.footBox .sttl a::before {
		content: '';
		display: inline-block;
		width: 1.5rem;
		height: .2rem;
		background-color: #fff;
		position: absolute;
		right: 1.9rem;
		top: 50%;
		transform: translateY(-50%);
		transition: opacity .5s;
	}

	.footBox .sttl a::after {
		content: '';
		display: inline-block;
		width: 1.5rem;
		height: .2rem;
		background-color: #fff;
		position: absolute;
		right: 1.9rem;
		top: 50%;
		transform: translateY(-50%) rotate(-90deg);
		transition: transform .5s;
	}


	.footBox>ul {
		padding: 0;
	}

	.footBox li {
		display: block;
	}


	.footBox li:after {
		content: "";
	}

	.footBox li a {
		display: block;
		padding: 1.3em 10% 1.3em 10.5%;
		background: url(./img/arrow_wt.svg) calc(100% - 2.0rem) 50% no-repeat;
		background-size: 1.5rem auto;
		border-bottom: 1px solid rgba(255, 255, 255, .5);
		text-align: left;
		font-size: 1.3rem;
	}

	.footBox li li a {
		padding: 1.3em 7% 1.3em 16.5%;
	}


	.footBox li a.ssttl {
		display: block;
		padding: 1.3em 10% 1.3em 4.5%;
		background: url(./img/arrow_wt.svg) calc(100% - 2.0rem) 50% no-repeat;
		background-size: 1.5rem auto;
		border-bottom: 1px solid rgba(255, 255, 255, .5);
	}

	.footBox li.sp a {
		padding: 1.3em 10% 1.3em 4.5%;
	}

	/* サイトマップ */
	footer .smap .sttl a {
		background: url(./img/arrow_wt.svg) calc(100% - 2.0rem) 50% no-repeat;
		background-size: 1.5rem auto;
		font-size: 1.4rem;
	}

	footer .smap .sttl a::before,
	footer .smap .sttl a::after {
		width: 0;
		height: 0;
		background: none;
		border: none;
	}



	.footBox.accordion .accChild {
		display: none;
		/*background: #d2ebee;*/
	}

	.footBox.accordion .accChild a {
		background: url(./img/arrow_wt.svg) calc(100% - 2.0rem) 50% no-repeat #281a14;
		background-size: 1.5rem auto;
		border-bottom: 1px solid rgba(255, 255, 255, .5);
	}


	.footBox.accordion .open a::before {
		opacity: 0;
	}

	.footBox.accordion .open a::after {
		transform: translateY(-50%) rotate(-180deg);
	}




	.footBox li.subCat {
		display: block;
		margin: 0 0 0 0;
	}

	.footBox ul.subList {
		display: block;
		margin: 0 0 0;
	}

	.footBox ul.subList>li:first-child::before {
		content: "";
		margin: 0;
	}

	.footBox ul.subList li:after {
		content: "";
	}




	footer .botArea {
		min-width: 0;
		padding: 1.5rem 5% 7.7rem;
		box-sizing: border-box;
		text-align: center;
		background: #169a5a;
	}

	footer .botArea .copy {
		padding: 0 0;
		font-size: 1.1rem;
		text-align: center;
		line-height: 1.6;
	}

	footer .botArea a {
		display: inline-block;
		text-decoration: none;
		font-size: 1.1rem;
		color: #fff;
	}




	/* ================== */
	/*  SP共通パーツ　*/
	/* ================== */

	/* p */
	.mainWrap p,
	.index p {
		margin: 1rem 0;
		line-height: 1.9;
	}

	.mainWrap>.areaInner>p,
	.index>.areaInner>p {
		padding: 0 5%;
	}

	.mainWrap>.areaInner>.caption {
		margin: 0 5%;
	}

	.mainWrap>.areaInner>.low-center-img-box {
		padding: 0 5%;
	}

	.mainWrap>.areaInner>.low-center-img-box * {
		margin-left: 0;
		margin-right: 0;
	}


	.mainWrap h2 {
		position: relative;
		margin: 4rem 5% 2rem;
		padding: 1.5rem 3% 1.7rem 2.2rem;
		background: #e6f2e8;
		border-radius: 1.5rem;
		font-size: 2.3rem;
	}

	.mainWrap h2::before {
		content: "";
		position: absolute;
		top: 1.5rem;
		left: 0;
		width: .7rem;
		height: calc(100% - 3rem);
		background: #ef5c22;
	}

	.mainWrap h2 a {
		position: relative;
		display: block;
		padding: 0 10% 0 0;
	}

	.mainWrap h2 a::before {
		content: "";
		position: absolute;
		top: 0;
		right: .3rem;
		width: 2.0rem;
		height: 100%;
		background: url("./img/arrow_gr.svg") 99% calc(50% + 0px) no-repeat;
		background-size: 2.0rem auto;
		transition: all .2s ease-in-out;
	}

	.mainWrap h2 a:hover::before {}

	.mainWrap h2 a::after {}

	.mainWrap h2 a:hover::after {}






	.mainWrap h3 {
		position: relative;
		margin: 3rem 5%;
		padding: 1.2rem 3% 1.4rem 2%;
		border-bottom: 1px solid #b7b5b4;
		font-size: 2.0rem;
		color: #169a5a;
	}

	.mainWrap h3::before {
		content: "";
		position: absolute;
		top: .2rem;
		left: -1.3rem;
		width: 6.2rem;
		height: 6rem;
		background: url(./img/h3_deco.svg) 0 0 no-repeat;
		background-size: 6.2rem auto;
		opacity: .1;
	}

	.mainWrap h3 a {
		position: relative;
		z-index: 1;
		display: block;
		padding: 0 10% 0 0;
	}

	.mainWrap h3 a::before {
		content: "";
		position: absolute;
		top: 0;
		right: .4rem;
		width: 1.8rem;
		height: 100%;
		background: url("./img/arrow_gr.svg") 99% calc(50% + 0px) no-repeat;
		background-size: 1.8rem auto;
		transition: all .2s ease-in-out;
	}

	.mainWrap h3 a:hover::before {}

	.mainWrap h3 a::after {}

	.mainWrap h3 a:hover::after {}






	.mainWrap h4,
	.mainWrap h5,
	.mainWrap h6 {
		margin: 20px 5%;
		padding: 10px 3% 10px .5rem;
		border-bottom: 1px solid #b7b5b4;
		font-size: 1.8rem;
	}

	.mainWrap h5::before,
	.mainWrap h6::before {}

	.mainWrap h4 a,
	.mainWrap h5 a,
	.mainWrap h6 a {
		position: relative;
		padding: 0 5% 0 0;
	}

	.mainWrap h4 a::before,
	.mainWrap h5 a::before,
	.mainWrap h6 a::before {
		content: "";
		position: absolute;
		z-index: 10;
		top: 0;
		right: .4rem;
		width: 1.8rem;
		height: 100%;
		background: url("./img/arrow_gr.svg") 99% calc(50% + 1px) no-repeat;
		background-size: 1.8rem auto;
		transition: all .2s ease-in-out;
	}









	.mainWrap ul {
		margin: 1.5em 4% 1.5em;
		padding: 0.5em 1% 0;
	}

	.mainWrap ul li {
		padding: 0 0 .4rem 1.7rem;
	}

	.mainWrap ul li::before,
	.index ul li::before {
		position: absolute;
		content: "";
		top: 1.1rem;
		left: .2rem;
		width: 1.0rem;
		height: 1.0rem;
	}


	.mainWrap ol {
		margin: 1.5em 4% 1.5em;
		padding: 0.5em 1% 0;
	}

	.mainWrap ol li {
		padding: 0 0 .4rem 2.0rem;
	}

	.mainWrap ol li::before {
		width: 1.6rem;
		height: 1.7rem;
		top: .7rem;
		left: 0;
		box-sizing: border-box;
		padding: 0.13em 0 0;
		letter-spacing: 0;
		line-height: 1.0;
		font-size: 1.3rem;
	}







	/*  btns*/
	.btn-internal,
	.btn-web,
	.btn-tel {
		position: relative;
		z-index: 1;
		width: 85%;
		display: flex;
		align-items: center;
		justify-content: center;
		margin: 2.5rem auto;
		text-align: center;
	}


	.btn-internal a,
	.btn-web a,
	.btn-tel a {
		position: relative;
		top: 0;
		left: 0;
		width: 100%;
		min-height: 7.5rem;
		display: flex;
		align-items: center;
		justify-content: center;
		margin: 0 .5rem 0 0;
		padding: 1.6rem 15% 1.8rem;
		box-shadow: .6rem .6rem 0 0 #0c5934;
		border-radius: 1.5rem 3.5rem 1.5rem 1.5rem;
		text-align: center;
		line-height: 1.7;
		font-weight: 900;
		font-size: 1.6rem;
		overflow: hidden;
	}

	.btn-internal a::before,
	.btn-web a::before {
		width: 0;
		height: 0;
		background: none;
		border: none;
	}

	.btn-internal a:hover,
	.btn-web a:hover {
		opacity: 1;
	}




	.btn-internal a {
		background: #fff;
		border: 3px solid #169a5a;
	}

	.btn-internal a::after {
		content: "";
		position: absolute;
		z-index: 10;
		top: 0;
		right: 1.5rem;
		width: 1.8rem;
		height: 100%;
		background: url("./img/arrow_gr.svg") 99% calc(50% + 1px) no-repeat;
		background-size: 1.8rem auto;
		transition: all .4s ease-in-out;
	}






	.btn-web a {
		padding: 1.6rem 11% 1.8rem 19%;
		background: #fabd0e;
		box-shadow: .6rem .6rem 0 0 #ba8b0b;
	}

	.btn-web a::after {
		content: "";
		position: absolute;
		z-index: 10;
		top: 0;
		left: 2rem;
		width: 3.3rem;
		height: 100%;
		background: url("./img/icon_cart.svg") 0 calc(50% + 1px) no-repeat;
		background-size: 3.3rem auto;
		transition: all .4s ease-in-out;
	}


	.btn-web2 a {
		background: #bf0000;
		box-shadow: .6rem .6rem 0 0 #800000;
		color: #fff;
	}

	.btn-web2 a::after {
		background-image: url("./img/icon_cart_wt.svg");
	}

	.btn-web2 a:hover::after {
		background-image: url("./img/icon_cart_wt.svg");
	}



	.btnWebWrap {
		position: relative;
		margin: 2.5rem 0;
		text-align: center;
	}

	.btnWebWrap .fuki {
		position: relative;
		z-index: 2;
		width: 85%;
		margin: 0 auto -2.7rem;
		text-align: left;
	}

	.btnWebWrap .fuki .inner {
		position: relative;
		display: inline-block;
		margin: 0 0 -1.5rem 2.3rem;
		padding: .7rem 3% .9rem;
		background: #4f3b20;
		border-radius: .8rem;
		box-shadow: .3rem .3rem 0 0 #40301a;
		line-height: 1;
		font-weight: 900;
		font-size: 1.3rem;
		color: #fff;
	}

	.btnWebWrap .fuki .inner .fontS {
		vertical-align: top;
		font-size: 1.0rem;
	}

	.btnWebWrap .fuki .inner::before {
		content: "";
		position: absolute;
		bottom: -1.1rem;
		left: 1.8rem;
		width: 1.3rem;
		height: 1.4rem;
		background: url(./img/tri1.svg) 0 100% no-repeat;
		background-size: 1.3rem auto;
		filter: drop-shadow(2.5px 1.5px 0px #40301a);
	}

	.btnWebWrap .caption {
		width: 85%;
		margin: -.6rem auto;
		text-align: left;
	}




	.btn-tel {
		display: block;
	}

	.btn-tel a {
		padding: 1.6rem 15% 1.8rem;
		background: #169a5a;
		box-shadow: .6rem .6rem 0 0 #23684a;
		color: #fff;
	}

	.btn-tel a::after {
		position: absolute;
		top: 0;
		left: 1.8rem;
		width: 2.2rem;
		height: 100%;
		background: url(./img/ico_tel.svg) 0 50% no-repeat;
		background-size: 2.2rem auto;
	}



	.btn-link {
		margin: 1.2rem 5%;
		text-align: right;
	}

	.btn-link a {
		position: relative;
		display: inline-block;
		padding: 2.2rem 4.0rem 1.8rem 0;
		line-height: 1.5;
		text-align: right;
		font-weight: 900;
	}

	.btn-link a::before {
		content: "";
		position: absolute;
		top: 0;
		right: 2.0rem;
		width: 1.2rem;
		height: 100%;
		background: url("./img/arrow_gr.svg") 99% calc(50% + .4rem) no-repeat;
		background-size: 1.2rem auto;
		transition: all .3s ease-in-out;
	}

	.btn-link a::after {
		content: "";
		position: absolute;
		z-index: -1;
		top: calc(50% - 2.25rem);
		right: 0;
		width: 5.5rem;
		height: 5.5rem;
		background: #f7edde;
		border-radius: 50%;
		transition: all .3s ease-in-out;
	}

	.btn-link.outlink a::before {
		content: "";
		position: absolute;
		top: 0;
		right: 2.3rem;
		width: 1.0rem;
		background-image: url("./img/arrow_gr_45.svg");
		background-size: 1.0rem auto;
	}


	/* テキストリンクアニメReset */
	.btn-link a:hover {
		opacity: 1;
	}

	.btn-link a:hover::after {
		transform: scale(1, 1);
	}

	.btn-link a.is-active::before {
		animation: none;
	}

	.btn-link a.is-nonactive::before {
		animation: none;
	}






	/* ================== */
	/*  テーブル　　　　　*/
	/* ================== */

	table {
		width: 88%;
		margin: 3rem auto;
		border-bottom: 1px solid #cdcdcd;
	}

	table th {
		width: 100%;
		display: block;
		padding: 1.5rem 2rem;
		border-bottom: none;
		line-height: 1.3;
		text-align: center;
		font-size: 1.6rem;
	}

	table td {
		width: 100%;
		display: block;
		padding: 1.5rem 2rem;
		border-bottom: none;
		line-height: 1.4;
		text-align: center;
		font-size: 1.6rem;
	}



	.tableB .tblWrap {
		overflow: auto;
		width: 88%;
		margin: 0 auto;
	}

	.tableB .note {
		padding: 0 5%;
		text-align: center;
		color: #999999;
		font-size: 1.3rem;
	}

	.tableB table {
		margin: 10px auto;
	}

	.tableB table th {
		white-space: nowrap;
		width: 22%;
		display: table-cell;
	}

	.tableB table td {
		display: table-cell;
		white-space: nowrap;
	}

	.tableC table {
		width: 88%;
		margin: 3rem auto;
		border-bottom: 1px solid #cdcdcd;
	}

	.tableC table th {
		display: table-cell;
		width: auto;
	}

	.tableC table tr:first-child th:first-child {}

	.tableC table td {
		display: table-cell;
		width: auto;
	}




	/* ================== */
	/*  SPカスタマイズ共通　*/
	/* ================== */
	.caption,
	.source {
		margin: 0.8em 0 0;
		font-size: 1.0rem;
		line-height: 1.3;
		word-break: break-all;
		color: #999;

		overflow: auto;
		white-space: nowrap;
	}

	.caption a:hover {
		text-decoration: underline;
	}


	.marker {}



	/*  float-wrap */

	.mainWrap .float-wrap .flame {
		position: relative;
	}

	.mainWrap .float-wrap .caption {
		margin-bottom: 5px;
	}

	.mainWrap .float-wrap {
		margin: 2.5em 6%;
		padding: 0 1%;
	}

	.mainWrap .float-wrap .catch {
		margin: 0em 0 0.4em;
		line-height: 1.7;
	}

	.mainWrap .float-wrap p {
		margin: 1rem 0;
		padding: 0;
	}

	.float-wrap ul {
		display: block;
		margin: 6px 0;
	}

	.mainWrap .float-wrap .fl,
	.mainWrap .float-wrap .fr,
	.mainWrap .float-wrap .ct {
		float: none;
		padding: 0 0 0.5em;
		width: 100%;
		width: auto;
		text-align: left;
	}

	.mainWrap .float-wrap .fl.t_small {
		width: 40%;
		float: left;
		padding: 0 5% 0 0;
	}

	.mainWrap .float-wrap .fr.t_small {
		width: 40%;
		float: right;
		padding: 0 0 0 5%;
	}

	.mainWrap .float-wrap img {}






	/* ================== */
	/*  サイトマップ*/
	/* ================== */
	.smap h2 {}

	.smap ul {}




	/* ================== */
	/*  追加パーツ*/
	/* ================== */


	/*--------------------------------------
　mokuji_SP
---------------------------------------*/

	.mokuji {
		transition: .3s;
		/*デフォルトで非表示にする*/
		opacity: 1;
		/*visibility: hidden;*/
	}

	/*このクラスが付与されると表示する*/
	.mokuji.active {
		opacity: 1;
		visibility: visible;
	}

	/*このクラスが付与されると停止する*/
	.mokuji.absolute {}



	.mokuji {
		position: relative;
		z-index: 2;
		width: auto;
		margin: 2rem 5% 1rem;
	}

	.mokuji .inner {
		position: relative;
		padding: 1rem 5% 0;
		background: #fff;
		border: 2px solid #ebd3a9;
		border-radius: 1.5rem;
	}

	.mokuji .inner::before {
		content: "";
		position: absolute;
		top: 2.2rem;
		left: 7.2rem;
		width: 8.5rem;
		height: 2.0rem;
		background: url("./img/eng_idx.svg") 0 0 no-repeat;
		background-size: auto 1.9rem;
	}


	.mokuji .sttl {
		margin: 0 0 .6rem;
		padding: .6rem 0 1.6rem;
		border-bottom: 1px solid #b7b5b4;
		font-size: 1.9rem;
	}

	.mokuji .sttl::before {
		content: "";
		position: absolute;
		top: .5rem;
		left: -6%;
		width: .7rem;
		height: calc(100% - 1.8rem);
		background: #169a5a;
	}


	.mokuji #toc {
		position: relative;
		padding: 0 0 2rem;
	}

	.mokuji #toc::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		z-index: 1;
		display: block;
		width: 100%;
		height: 100%;
		transition: 0.3s;
		background: linear-gradient(to bottom, transparent 0%, #ffffff 100%);
	}

	.mokuji #toc ul {
		margin: 0;
		padding: 5px 0;
	}

	.mokuji #toc ul li {
		position: relative;
		margin: 2px 0;
		padding: 2px 0 2px 3rem;
		text-align: left;
		line-height: 1.4;
	}

	.mokuji #toc ul li.chapter-h-two {
		counter-increment: count;
	}

	.mokuji #toc ul li.chapter-h-two::before {
		content: counter(count, decimal-leading-zero)".";
		/*2桁対応*/
		position: absolute;
		top: 17px;
		left: 0;
		width: 4rem;
		transform: translate(0, -50%);
		background: none;
		font-size: 1.6rem;
		font-weight: 900;
		color: #e85510;
	}

	.mokuji li a {
		display: inline-block;
		width: auto;
		padding: 5px 0;
		background: none;
		font-size: 1.6rem;
		text-decoration: none;
	}


	.mokuji #toc ul li.chapter-h-two a {
		font-weight: 900;
	}


	.mokuji #toc ul ul {
		margin: 0;
		padding: 0 0 2px;
	}

	.mokuji #toc ul li.chapter-h-three {
		padding: 0 0 0 5rem;
	}

	.mokuji #toc ul li.chapter-h-three::after {
		content: "";
		position: absolute;
		top: 0;
		left: 3.5rem;
		width: 8px;
		height: 100%;
		background: url("./img/l_deco.png") 0 6px no-repeat;
		background-size: 8px auto;
	}

	.mokuji #toc ul li.chapter-h-three::before {
		width: 0;
		height: 0;
		background: none;
		border: none;
	}

	.mokuji li br {
		display: none;
	}


	/* accordion_grd */
	.mokuji .text {
		/*height: 120px;
overflow: hidden;*/
	}

	.mokuji .show_more2 {
		position: absolute;
		bottom: 0;
		left: 0px;
		width: 100%;
		height: 70px;
		padding-top: 6.5rem;
		text-align: center;
		line-height: 6.5rem;
		background: linear-gradient(180deg,
				rgb(245, 245, 237, 0) 0%,
				rgb(245, 245, 237, 1) 60%);
		cursor: pointer;
		transition: bottom 0.2s;
	}

	.mokuji .active {
		background: none;
		/*bottom: -20px;*/
	}

	.mokuji .show_more2 span {
		position: relative;
		top: -2.5rem;
		display: inline-block;
		width: 85%;
		min-height: 5rem;
		padding: 1.3rem 10% 1.5rem;
		background: url(./img/plus.svg) 93% calc(50% - 1px) no-repeat #fff;
		background-size: 1.6rem auto;
		border-radius: 9999px;
		border: 1px solid #262626;
		text-align: center;
		line-height: 1.5;
		font-weight: 900;
		font-size: 1.6rem;
	}

	.mokuji .active span {
		background: url(./img/minus.svg) 90% 50% no-repeat #fff;
		background-size: 1.6rem auto;
	}








	/* relations_SP */
	.relations {
		position: relative;
		width: auto;
		margin: 1rem 5% 3rem;
	}

	.relations .inner {
		position: relative;
		padding: 1rem 5% 0;
		background: #fff;
		border: 2px solid #ebd3a9;
		border-radius: 1.5rem;
	}

	.relations .inner::before {
		content: "";
		position: absolute;
		top: 2.1rem;
		left: 11.0rem;
		width: 8rem;
		height: 2.0rem;
		background: url("./img/eng_link.svg") 0 0 no-repeat;
		background-size: auto 1.9rem;
	}


	.relations .relations-title {
		position: relative;
		margin: 0 0 .6rem;
		padding: .6rem 0 1.6rem;
		border-bottom: 1px solid #b7b5b4;
		font-size: 1.9rem;
	}

	.relations .relations-title::before {
		content: "";
		position: absolute;
		top: .5rem;
		left: -6%;
		width: .7rem;
		height: calc(100% - 1.8rem);
		background: #169a5a;
	}


	.relations .relations-wrapper {
		position: relative;
		padding: 0 0 2rem;
	}

	.relations ul {
		margin: 0;
	}

	.relations ul li {
		position: relative;
		margin: 2px 0;
		padding: 0 0 0 0 !important;
		text-align: left;
		line-height: 1.4;
	}

	.relations ul li::before {
		width: 0 !important;
		height: 0 !important;
		background: none !important;
		border: none !important;
	}

	.relations li a {
		display: inline-block;
		width: auto;
		padding: 2px 0 3px 2rem;
		background: none;
		font-size: 1.6rem;
		text-decoration: none;
	}

	.relations li a::before {
		content: "";
		position: absolute;
		z-index: 10;
		top: 1.6rem;
		left: 0.1rem;
		width: 1.1rem;
		height: 1.1rem;
		background: #ef5c22;
		transition: all .2s ease-in-out;
	}

	.relations li p {
		margin: .8rem 0;
		line-height: 1.4;
	}



	/* btns_SP */
	.btns {
		display: block;
		padding: .5rem 0;
	}

	.btns>div {
		width: 85%;
		margin: 2.5rem auto;
	}

	.btns .btn-internal a,
	.btns .btn-web a,
	.btns .btn-tel a {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: auto;
	}

	.btns .btn-tel {
		display: flex;
	}

	.btns .btnWebWrap div {
		width: 100%;
		margin: 0;
	}

	.btns .btnWebWrap .caption {
		margin: 2rem 0 0;
	}

	.btns .caption {
		width: 85%;
		margin: 1rem auto 00;
		text-align: left;
	}

	.btns .caption2 {
		overflow: visible;
		white-space: normal;
	}

	.btns .caption2 span {
		display: block;
		margin: .5rem 0 0;
		padding: 0 0 .5rem;
		overflow: auto;
		white-space: nowrap;
	}






	/* check_SP */
	.check {
		position: relative;
		margin: 2rem 5%;
		padding: 1.5rem 5% 1.7rem 7.5rem;
		background: #f7edde;
		border-radius: 1rem;
		font-size: 1.8rem;
		font-weight: 900;
		line-height: 1.5;
	}

	.check::before {
		content: "";
		position: absolute;
		top: calc(50% - 2.75rem);
		left: 1rem;
		width: 5.5rem;
		height: 5.5rem;
		background: url("./img/iconttl_ck.png") 0 0 no-repeat;
		background-size: 5.5rem auto;
	}

	.point {
		position: relative;
		margin: 2rem 5%;
		padding: 1.5rem 5% 1.7rem 7.5rem;
		background: #f7edde;
		border-radius: 1rem;
		font-size: 1.8rem;
		font-weight: 900;
		line-height: 1.5;
	}

	.point::before {
		content: "";
		position: absolute;
		top: calc(50% - 2.75rem);
		left: 1rem;
		width: 5.5rem;
		height: 5.5rem;
		background: url("./img/iconttl_pt.png") 0 0 no-repeat;
		background-size: 5.5rem auto;
	}


	.num {
		position: relative;
		margin: 2rem 5%;
		padding: 1.5rem 5% 1.7rem 7.5rem;
		background: #f7edde;
		border-radius: 1rem;
		font-size: 1.8rem;
		font-weight: 900;
		line-height: 1.5;
	}

	.num::before {
		content: "";
		position: absolute;
		top: calc(50% - 2.75rem);
		left: 1rem;
		width: 5.5rem;
		height: 5.5rem;
		background: url("./img/iconttl_num.png") 0 0 no-repeat;
		background-size: 5.5rem auto;
	}

	.num .fontNum {
		position: absolute;
		top: calc(50% - 2.75rem);
		left: 1rem;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 5.5rem;
		height: 5.5rem;
		font-size: 1.4rem;
		font-weight: 900;
		line-height: 1;
		color: #fff;
	}




	/* talk_SP */
	.talks {
		position: relative;
		margin: 6rem 5% 3rem;
	}

	.talk {
		position: relative;
		display: block;
		width: 100%;
		margin: 0 0 3rem;
		padding: 2.5rem 5% 2.0rem;
		background: #fff;
		border: 3px solid #169a5a;
		border-radius: 1.5rem 6rem 1.5rem 1.5rem;
	}

	.talk .imgArea {
		position: relative;
		width: 12.5rem;
		margin: 0 auto 1.8rem;
	}

	.talk .imgArea .flame {
		margin: 0 0;
	}

	.talk .imgArea img {
		border-radius: 50%;
	}

	.talk .cap {
		position: relative;
		padding: .8rem 0 0;
		line-height: 1.5;
		text-align: center;
		font-size: 1.4rem;
	}


	.talk .txtArea {
		flex: 1;
		position: relative;
	}

	.talk .txtArea .inner {
		position: relative;
	}

	.talk .txtArea .catch {
		display: inline-block;
		margin: 0 0 .5rem;
		font-size: 1.8rem;
		color: #ee5c21;
	}

	.talk .txtArea .catch span {
		position: relative;
	}

	.talk .txtArea .catch::before {
		content: "";
		position: absolute;
		top: -1.0rem;
		left: -1.0rem;
		width: 2.5rem;
		height: 2.5rem;
		background: url("./img/quote_a.png") 0 0 no-repeat;
		background-size: 2.5rem auto;
	}

	.talk .txtArea .catch::after {
		content: "";
		position: absolute;
		bottom: -1.0rem;
		right: -1.0rem;
		width: 2.5rem;
		height: 2.5rem;
		background: url("./img/quote_b.png") 0 0 no-repeat;
		background-size: 2.5rem auto;
	}



	/* bfaf_SP */
	.bfaf {
		position: relative;
		margin: 7.5rem 5%;
		padding: 1.5rem 0 3rem;
		background: #f7edde;
		border-radius: 1.5rem;
	}

	.bfaf::before {
		width: 0;
		height: 0;
		background: none;
		border: none;
	}

	.bfaf .sttl {
		margin: 0 0 2rem 6%;
		padding: 1.0rem 5% 2.5rem 0;
		border-bottom: 1px solid #b7b5b4;
		font-size: 2.0rem;
	}

	.bfaf .sttl::before {
		content: "";
		position: absolute;
		top: .7rem;
		left: -6%;
		width: .7rem;
		height: calc(100% - 2.5rem);
		background: #169a5a;
	}


	.bfaf .imgArea {
		display: block;
		padding: 0 5% 2rem;
	}

	.bfaf .imgArea .areaL {
		position: relative;
		width: auto;
		margin: 0 0 2rem;
	}

	.bfaf .imgArea .areaR {
		position: relative;
		width: auto;
	}

	.bfaf .headtxt .note {
		padding: 0 0 1rem;
		line-height: 1.5;
		font-size: 1.4rem;
		font-weight: 900;
	}

	.bfaf .headtxt .note .fontL {
		position: relative;
		font-size: 2.4rem;
		color: #ee5c21;
	}

	.bfaf .headtxt .note .fontL::before {
		content: "";
		position: absolute;
		top: -1rem;
		left: -1.5rem;
		width: 6rem;
		height: 6rem;
		background: #fabd0e;
		border-radius: 50%;
		opacity: .4;
	}


	.bfaf .areaL .flame {
		position: relative;
		margin: 0 0 0 14rem;
		padding: 2.4rem 0 0;
	}

	.bfaf .areaL .flame::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 8rem;
		height: 1.4rem;
		background: url("./img/eng_bf.svg") 0 0 no-repeat;
		background-size: auto 1.4rem;
		opacity: .8;
	}

	.bfaf .areaL .flame::after {
		content: "";
		position: absolute;
		top: auto;
		bottom: -2.5rem;
		right: auto;
		left: 0;
		width: 100%;
		height: 1.5rem;
		background: url("./img/tri2_sp.svg") 50% 100% no-repeat;
		background-size: 2.8rem auto;
	}

	.bfaf .areaR .flame {
		position: relative;
		padding: 2.4rem 0 0;
	}

	.bfaf .areaR .flame::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 7rem;
		height: 1.4rem;
		background: url("./img/eng_af.svg") 0 0 no-repeat;
		background-size: auto 1.4rem;
	}

	.bfaf .imgArea img {
		border-radius: 1rem;
	}


	.bfaf .txtArea {
		padding: 0 5% 1.5rem;
	}

	.bfaf .tblArea {
		padding: 0 5%;
	}

	.bfaf table {
		width: 100%;
		border-bottom: none;
		border-collapse: separate;
		margin: 0;
	}

	.bfaf th {
		display: table-cell;
		width: 12rem;
		padding: 1.5rem 1.5rem;
		border-bottom: none;
		font-size: 1.7rem;
		color: #169a5a;
	}

	.bfaf td {
		padding: 1.5rem 1.5rem;
		border: none;
		border-right: 1px solid #b7b5b4;
		border-top: 1px solid #b7b5b4;
		text-align: justify;
	}

	.bfaf table tr:first-child th {
		border-radius: 1.5rem 0 0 0;
	}

	.bfaf table tr:first-child td {
		border-radius: 0 1.5rem 0 0;
	}

	.bfaf table tr:last-child th {
		border-radius: 0 0 0 1.5rem;
		border-bottom: 1px solid #b7b5b4;
	}

	.bfaf table tr:last-child td {
		border-radius: 0 0 1.5rem 0;
		border-bottom: 1px solid #b7b5b4;
	}





	/* sum_SP */
	.sum {
		position: relative;
		margin: 7.5rem 5%;
		padding: 1.8rem 6% 2rem;
		background: #f7edde;
		border-radius: 2rem 6rem 2rem 2rem;
	}

	.sum .inner {
		position: relative;
	}

	.sum .logo {
		position: static;
		width: 10.5rem;
		margin: 0 0 1rem;
	}

	.sum .catch {
		margin: 0 0 -.5rem;
		padding: 1.2rem 0 1.2rem;
		font-size: 1.8rem;
	}

	.sum .catch::before {
		content: "";
		position: absolute;
		top: 1.7rem;
		left: -7.5%;
		width: .7rem;
		height: calc(100% - 3.0rem);
		background: #ef5c22;
	}

	.sum .btn-link {
		margin: -1.5rem 0 0;
	}

	.sum .btn-link a::after {
		background: #fff;
	}








	/* spv_SP */
	.spv {
		position: relative;
		margin: 5rem 5%;
		padding: 2.5rem 5% 2rem;
		border: 3px solid #169a5a;
		border-radius: 1.5rem;
	}

	.spv::before {
		width: 0;
		height: 0;
		background: none;
		border: none;
	}

	.spv .inner {
		position: relative;
		padding: 0 0 0;
	}

	.spv .boxTtl {
		position: absolute;
		top: 0;
		right: -5%;
		font-size: 1.5rem;
		font-weight: 900;
		color: #169a5a;
		letter-spacing: .2em;
		font-family: "Noto Sans JP vt";
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
	}

	.spv .boxTtl::before {
		content: "";
		position: absolute;
		top: -.4rem;
		right: -.5rem;
		width: .8rem;
		height: calc(100% + .6rem);
		background: #169a5a;
	}


	.spv .sttl {
		margin: 0 0 2.5rem;
		font-size: 1.5rem;
	}

	.spv .sttl img {
		display: block;
		width: 15rem;
		margin: 0 0 .5rem;
		vertical-align: middle;
	}

	.spv .imgArea {
		position: static;
		width: auto;
		margin: 0 0 1.5rem;
	}

	.spv .flame {
		width: 20rem;
		height: 18rem;
		margin: 0 auto 1.5rem;
	}

	.spv .flame img {
		width: 100%;
		height: 18rem;
		object-fit: cover;
		border-radius: 1.5rem 4.5rem 1.5rem 1.5rem;
	}

	.spv .cap {
		text-align: center;
		font-size: 1.7rem;
		font-weight: 900;
	}

	.spv .cap .fuki {
		display: inline-block;
		margin: 0 0 .5rem;
		padding: .8rem 5% 1.0rem;
		background: #4f3b20;
		border-radius: 9999px;
		line-height: 1;
		font-size: 1.3rem;
		color: #fff;
	}

	.spv .cap .fontS {
		font-size: 1.3rem;
	}

	.spv .catch {
		font-size: 1.8rem;
		color: #ee5c21;
	}

	.spv ul {
		margin: 0 0 1rem;
		padding: 0;
	}

	.spv .btn-web {
		width: 95%;
	}

	.spv .btn-web a {
		padding: 1.6rem 15% 1.8rem;
	}

	.spv .btn-web a::after {
		top: 0;
		right: 1.5rem;
		width: 1.8rem;
		height: 100%;
		background: url(./img/arrow_bk.svg) 99% calc(50% + 1px) no-repeat;
		background-size: 1.8rem auto;
	}




	/* qa_SP */
	.qaWrap {
		padding: 1.5rem 5% 5rem;
	}

	.qa {
		padding: 1rem 0;
	}

	.qa .sttl {
		margin: 0 0 2.5rem;
		padding: 0 0 0 3.5rem;
		font-size: 1.7rem;
		line-height: 1.6;
	}

	.qa .sttl::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 3.1rem;
		height: 3.2rem;
		background: url("./img/eng_q.svg") 0 0 no-repeat;
		background-size: 3.1rem auto;
	}

	.qa .ansBox {
		position: relative;
		background: #f7edde;
		border-radius: 1.5rem 6rem 1.5rem 1.5rem;
		padding: 1.5rem 5% 1.5rem;
	}

	.qa .catch {
		margin: 0 0 0;
		padding: 4rem 0 0;
		font-size: 1.7rem;
		line-height: 1.6;
		color: #169a5a;
	}

	.qa .catch::before {
		content: "";
		position: absolute;
		top: 1rem;
		left: 0;
		width: 3.3rem;
		height: 3.2rem;
		background: url("./img/eng_a.svg") 0 0 no-repeat;
		background-size: 3.3rem auto;
	}

	.qa .ansBox .imgArea {
		position: static;
		width: 11rem;
		float: right;
		margin: -3rem 0 0 1.5rem;
	}

	.qa .ansBox .imgArea .flame {
		width: 9rem;
		height: 9rem;
		margin: 0 auto;
	}

	.qa .ansBox .flame img {
		width: 100%;
		object-fit: cover;
		border-radius: 50%;
	}

	.qa .ansBox .cap {
		position: relative;
		margin: -1rem 0 0;
		text-align: center;
		font-size: 1.6rem;
		font-weight: 900;
	}

	.qa .ansBox .cap .fuki {
		display: block;
		margin: 0 0 .3rem;
		padding: .8rem 5% 1.0rem;
		background: #4f3b20;
		border-radius: 9999px;
		line-height: 1;
		font-size: 1.3rem;
		color: #fff;
	}

	.qa .ansBox .cap .fontS {
		font-size: 1.3rem;
	}



	/*--------------------------------------
　botCommon_SP
---------------------------------------*/

	.botCommon {
		padding: 6.5rem 3% 4rem;
	}

	.mainWrap+.botCommon {
		padding: 8rem 3% 4rem;
	}

	.mainWrap+.botCommon::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 1.5rem;
		background: #fff;
		border-radius: 0 0 3rem 3rem;
	}


	.botCommon .areaInner {
		width: auto;
		background: #169a5a;
		padding: 1.0rem;
		border-radius: .5rem;
	}

	.botCommon .areaInner2 {
		position: relative;
		background: #fff;
		border-radius: 1.5rem;
		padding: 3rem 5% 2rem;
	}

	.botCommon .boxTtl {
		position: absolute;
		top: 3rem;
		right: 1%;
		font-size: 1.5rem;
		font-weight: 900;
		color: #169a5a;
		letter-spacing: .2em;
		font-family: "Noto Sans JP vt";
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
	}

	.botCommon .boxTtl::before {
		content: "";
		position: absolute;
		top: -.4rem;
		right: -.5rem;
		width: .8rem;
		height: calc(100% + .6rem);
		background: #169a5a;
	}



	.botCommon .mainArea {
		padding: 0 0;
	}

	.botCommon .imgArea {
		position: relative;
		width: auto;
		float: none;
		margin: 0 0 -1.5rem;
		padding: 2.5rem 0 0;
		text-align: center;
	}

	.botCommon .imgArea::before {
		content: "";
		position: absolute;
		top: 0;
		left: 2rem;
		width: 18rem;
		height: 18rem;
		background: #f7edde;
		border-radius: 50%;
	}

	.botCommon .imgArea .flame {
		position: relative;
		width: 12rem;
		margin: 0 auto 2rem;
	}

	.botCommon .txtArea {
		width: auto;
		float: none;
		padding: 1.5rem 0 0;
	}

	.botCommon .txtArea .headArea {
		margin: 0 0 1.5rem;
		padding: 0 0 1.5rem;
		border-bottom: 1px solid #b7b5b4;
	}

	.botCommon .txtArea .sttl {
		margin: 0 0 .5rem;
		font-size: 1.5rem;
	}

	.botCommon .txtArea .sttl .line1 {
		display: block;
		margin: 0 0 1.0rem;
	}

	.botCommon .txtArea .sttl .fontL {
		font-size: 2.2rem;
	}

	.botCommon .txtArea .sttl .txt_bold {
		display: block;
		text-align: center;
		color: #ee5c21;
		font-size: 3.0rem;
	}

	.botCommon .txtArea .sps {
		line-height: 1.5;
		text-align: right;
		font-size: 1.3rem;
	}


	.botCommon .ssttl {
		margin: 0 0 1.5rem;
		font-size: 1.8rem;
		font-weight: 900;
		line-height: 1.5;
		text-align: center;
		color: #169a5a;
	}

	.botCommon .mini {
		margin: 0 0 1.8rem;
	}

	.botCommon .mini .catch {
		margin: 0 0 .5rem;
		padding: 0 0 0 3rem;
		font-size: 1.8rem;
	}

	.botCommon .mini .catch::before {
		content: "";
		position: absolute;
		top: .8rem;
		left: 0;
		width: 3rem;
		height: 1.1rem;
		background: url("./img/num_01_red.svg") 0 0 no-repeat;
		background-size: auto 1.1rem;
	}

	.botCommon .miniArea .mini:nth-child(2) .catch::before {
		background-image: url("./img/num_02_red.svg");
	}

	.botCommon .miniArea .mini:nth-child(3) .catch::before {
		background-image: url("./img/num_03_red.svg");
	}

	.botCommon .btns {
		margin: -2rem 0 0;
	}

	.botCommon .btns>div {
		width: 95%;
	}

	.botCommon .btn-web a {
		font-size: 1.6rem;
	}

	.botCommon .btn-link {
		margin: -1rem 0 0;
	}





	/*--------------------------------------
　about_SP
---------------------------------------*/

	.about {
		position: relative;
		z-index: 14;
		padding: 0 5% 6.5rem;
	}

	.about .inner {
		position: relative;
		width: auto;
		margin: 0 auto;
		padding: 3.0rem 5% 2rem;
		background: #fff;
		border-radius: 1.5rem 6rem 1.5rem 1.5rem;
	}

	.about .inner::before {
		content: "";
		position: absolute;
		top: 3.5rem;
		right: 5%;
		width: 11rem;
		height: 2.0rem;
		background: url(./img/eng_about.svg) 0 0 no-repeat;
		background-size: auto 2.0rem;
		opacity: .3;
	}

	.about .sttl::before {
		content: "";
		position: absolute;
		top: 0rem;
		left: -6%;
		width: .7rem;
		height: calc(100% - 0rem);
		background: #169a5a;
	}

	.about .txtArea {
		font-size: 1.5rem;
	}

	.about .sttl {
		padding: .4rem 0;
		margin: 0 0 2rem;
		font-size: 1.8rem;
	}

	.about .btn-link {
		margin: 0 0 0;
	}







}

/* End_SP */