.kosugi-maru-regular {
  font-family: "Kosugi Maru", sans-serif;
  font-weight: 400;
  font-style: normal;
}

html,body{
	height: 100%;
}

.sp_only{
	display: inline;
}
@media screen and (min-width:480px) {
	.sp_only{
		display: none;
	}
}

.link-none {
   pointer-events: none;
}

.fb{
	font-weight: bold;
	font-size: 1.1em;
}

.header_pc {
	display: none;
}
.header_sp {
	height: 82px;
	position: sticky;
	top:0;
	left: 0;
	background-color: #FFF;
}
.header_sp #logo{
	position:absolute;
	width:62%;
	top:20%;
	left:3%;
}
.topline {
	position:absolute;
	top:0;
	width: 100%;
	height: 8px;
	background-color: #CCDFC5;
}
.bottomline {
	position:absolute;
	bottom: 0;
	width: 100%;
	height: 14px;
	background-color: #CCDFC5;
}
.hamburger-menu {
	width: 40px;
	height: 40px;
	position: absolute;
	top:15px;
	right:1%;
	border: none;
	background: transparent;
	appearance: none;
	cursor: pointer;
	z-index: 8888;
}
.hamburger-menu__bar {
	display: inline-block;
	width: 36px;
	height: 2px;
	background: #9ABF8C;
	position: absolute;
	top: 29%;
	left: 29%;
	transform: translateX(-50%);
	transition: .5s;
}
.hamburger-menu__bar:first-child {
	top: 16px;
}
.hamburger-menu__bar:nth-child(2) {
	top: 24px;
}
.hamburger-menu__bar:last-child {
	top: 32px;
}
.hamburger-menu--open .hamburger-menu__bar {
	top: 50%;
}
.hamburger-menu--open .hamburger-menu__bar:first-child {
	transform: translateX(-50%) translateY(-50%) rotate(45deg);
}
.hamburger-menu--open .hamburger-menu__bar:last-child {
	transform: translateX(-50%) translateY(-50%) rotate(-45deg);
}
.hamburger-menu--open .hamburger-menu__bar:nth-child(2) {
	display: none;
}
.pageall{
	display: none;
	position: fixed;
	top:0;
	left: 0;
	width:100%;
	height:100%;
	background: #2d714f;
	z-index: 7777;
}
.navigation {
	display: none;
	background: #006633;
	position: absolute;
	top: 82px;
	width: 100%;
	z-index: 9999;
}
.navigation__list {
	text-align: center;
	list-style: none;
	padding: 0;
	margin: 0;
}
.navigation__list-item {
	border-bottom: solid 1px #474747;
}
.navigation__list-item:first-child {
	border-top: solid 1px #474747;
}
.navigation__link {
	color: #fff;
	font-weight: 700;
	text-decoration: none;
	display: block;
	padding: 24px 0;
	transition: .5s;
}

/*フッター処理*/
.footer_pc {
	display: none;
}
.footer_sp {
	position: fixed;
	width:100%;
	bottom:0;
}
.footer_sp ol{
	width:100%;
}
.footer_sp ol li{
	width:20%;
	float: left;
}
.footer_sp ol li img{
	width:100%;
}

@media screen and (min-width:480px) {
	/*ヘッダー処理*/
	.header_sp {
		display: none;
	}
	.header_pc {
		display: block;
		width:100%;
		background-image: url(../images/header_pc.png);
		background-repeat:repeat-x;
	}
	.header_pc .inner{
		width:900px;
		height:104px;
		position: relative;
		margin: 0 auto;
	}
	.header_pc #logo{
		position: absolute;
		top:15px;
		left:13px;
	}
	.header_pc #addr{
		font-size: 14px;
		color: #4C9F24;
		position: absolute;
		top:81px;
		left:11px;
	}
	.header_pc #tel_top{
		font-size: 18px;
		color: #4C9F24;
		position: absolute;
		top:79px;
		right:17px;
	}
	.header_pc #menu{
		position: absolute;
		top:47px;
		right:17px;
	}
	.header_pc #menu li{
		float: left;
		margin-right: 50px;
	}
	.header_pc #menu li:last-of-type{
		margin-right: 0px;
	}
	.header_pc #menu li a{
		font-size: 14px;
		color: #006633 !important;
		font-weight: bold;
		position:relative;
		padding-left:25px;
	}
	.header_pc #menu li a:hover{
		opacity:0.6;
	}
	.header_pc #menu li a:before{
		content: '';
		display: block;
		width: 18px;
		height: 18px;
		background-size: contain;
		background-repeat:no-repeat;
		position:absolute;
		top:0;
		left:0;
	}
	#home_menu:before{
		background-image: url(../images/home.png);
	}
	#product_menu:before{
		background-image: url(../images/product.png);
	}
	#outline_menu:before{
		background-image: url(../images/outline.png);
	}
	#access_menu:before{
		background-image: url(../images/access.png);
	}
	/*フッター処理*/
	.footer_sp {
		display: none;
	}
	.footer_pc {
		display: block;
		width:100%;
		background-image: url(../images/footer_pc.png);
		background-repeat:repeat-x;
	}
	.footer_pc .inner{
		width:900px;
		height:23px;
		margin: 0 auto;
		padding-top: 0px;
		padding-left: 13px;
		padding-right: 13px;
		color: #006633;
	}
	.footer_pc .inner #copyright{
		float: left;
		padding-top: 4px;
		font-size: 10px;
	}
	.footer_pc .inner ol{
		float: right;
	}
	.footer_pc .inner li{
		display: inline-block;
		float: left;
	}
	.footer_pc .inner li:first-of-type{
		margin-right: 27px;
	}
	.footer_pc .inner li a{
		font-size: 12px;
		color: #006633;
	}

}
@media (hover: hover) and (pointer: fine) {
	.navigation__link:hover {
		background: #333;
	}
	.footer_pc .inner li:hover {
		background: #bebaba;
	}
}
/*メインコンテンツ*/
.contents{
	width:96%;
	margin: 0 auto;
	padding-top: 20px;
	padding-bottom: 160px;
	font-size: 1em;
}

.contents_f p{
	width:96%;
	margin: 0 auto;
	padding-top: 20px;
	padding-bottom: 90px;
	text-align: justify;
	text-justify: inter-ideograph;
	line-height: 2;
}
@media screen and (min-width:480px) {
	.contents{
		width:900px;
		margin: 0 auto;
	}
	.contents_f p{
		width:100%;
		font-size: 1.3em;
	}
}
.contents_f .space{
	float: right;
	height: 6em;
}
@media screen and (min-width:480px) {
	.contents_f .space{
		height: 2em;
	}
}

.contents_f img{
	float: right;
	clear: both;
	width:30%;
	height: auto;
	margin: 0em 0 0 1.2em;
}
@media screen and (min-width:480px) {
	.contents_f img{
		width:25%;
	}
}

.contents_s h2{
	display: block;
	color: #00B786;
	font-size: 1.3em;
	font-weight: bold;
	border-bottom: solid 1px #00B786;
	margin-bottom: 20px;
}
@media screen and (min-width:480px) {
	font-size: 1.4em;
}

.price_main{
	display:flex;
	flex-flow: row;
	padding-bottom: 20px;
}

.price_main .rubyimg{
	width: 40%;
}
.price_main .rubyimg img{
	width: 100%;
}

.price_main .price{
	width: 60%;
	margin-top: auto;
	padding-left:20px;
}
@media screen and (min-width:480px) {
	.price_main .price{
		padding-left:80px;
	}
}

.brown{
	padding-top: 30px;
	color: brown;
}

.free_d{
	font-size: 1.6em;
}

.contents_s p a{
	color: #068f7a !important;
	text-decoration: underline;
}

/*アクセス*/
.accessbox{
	display:block;
}
.accessbox .leftbox{
	width: 100%;
}
.accessbox .rightbox{
	width: 100%;
}
.accessbox .rightbox img{
	width: 100%;
}
h1 {
	padding: 0.4em;/*文字周りの余白*/
	color: #494949;/*文字色*/
	background: #fffaf4;/*背景色*/
	border-left: solid 5px #ffaf58;/*左線（実線 太さ 色）*/
}
.accessbox .rightbox .tel_link{
	display: inline;
}
.accessbox .rightbox table{
	margin: 10px 0 10px;
	width: 100%;
	table-layout:fixed;
}
.accessbox .rightbox table th{
	width:20%;
}
.accessbox .rightbox table td:first-of-type{
	width:55%;
}
.accessbox .rightbox table td:nth-of-type(2){
	width:25%;
}
.accessbox .rightbox .addblock{
	margin: 30px 0 10px;
}
.accessbox .rightbox .telblock{
	margin: 30px 0 10px;
	line-height: 2;
}
@media screen and (min-width:480px) {
	.accessbox{
		display:flex;
		align-items:start;
	}
	.accessbox .leftbox{
		width: 60%;
	}
	.accessbox .rightbox{
		width: 40%;
		padding-left: 20px;
	}
	.accessbox .rightbox .telblock{
		line-height:inherit;
	}
}
.sp_disp{
	display:block;
	margin-bottom: 10px;
	font-size: 18px;
}
.pc_disp{
	display:none;
}
@media screen and (min-width:480px) {
	.sp_disp{
		display:none;
	}
	.pc_disp{
		display:block;
		margin-bottom: 10px;
		font-size: 20px;
	}
}

/*会社概要*/
.contents_inside{
	display: block;
	width:96%;
	margin: 0 auto;
	padding-top: 0px;
	padding-bottom: 0px;
}
@media screen and (min-width:480px) {
	.contents_inside{
		width:80%;
	}
}

table.outline_tbl{
	width:100% !important;
	table-layout: fixed;
	margin-top: 30px;
	border-bottom: solid 1px #E2E2E2;
}
.outline_tbl th{
	width: 30%;
	font-weight: 600;
	border-top: solid 1px #E2E2E2;
	padding-top: 16px;
	padding-bottom: 16px;
}
.outline_tbl td{
	width: 70%;
	border-top: solid 1px #E2E2E2;
	padding-top: 16px;
	padding-bottom: 16px;
	margin-bottom: 0px;
}
@media screen and (max-width:480px) {
	table.outline_tbl{
		width:100% !important;
		display: block;
		border-bottom: none;
		margin-bottom: 30px;
	}
	.outline_tbl th{
		width:100% !important;
		display: block;
		border-top: none;
		padding-top: 16px;
		padding-bottom: 8px;
	}
	.outline_tbl td{
		width:100% !important;
		display: block;
		padding-top: 8px;
		padding-bottom: 36px;
	}
}

.greeting{
	text-align: justify;
	text-justify: inter-ideograph;
}
.greeting img{
	float: right;
	margin: 0 0 10px 10px;
	width:35%;
}
@media screen and (min-width:480px) {
	.greeting img{
		float: right;
		margin: 0 0 15px 15px;
		width:25%;
	}
}

.rightside{
	display: block;
	text-align: right;
	font-family: "Zen Antique", serif;
	font-weight: 400;
	font-style: normal;
}

//topページ
.slider {
	width: 100%;
	overflow: hidden;
	margin: 0 auto;
	border: solid 1px red;
}
@media screen and (min-width:480px) {
	.slider{
		width:900px;
		margin: 0 auto;
	}
}
.slick-img img {
	width: 100%;
}
@keyframes fdzm {
	0% {
		transform: scale(1);
	}
	100% {
		transform: scale(1.1);
	}
}
.animation {
	animation: fdzm 4s 0s forwards;
}

/*商品一覧*/
.promo_top{
	width:100%;
	margin: 0 auto;
}
.promo_top img{
	width:100%;
}
@media screen and (min-width:480px) {
	.promo_top{
		width:900px;
	}
}

.submenu {
  width:100%;
  height:auto;
  display:flex;
  flex-direction:row; /* 記載しなくてもデフォルトで指定されている */
  flex-wrap:wrap; /* 折り返し */
  justify-content:space-between; /* 子要素を均等に配置・両端揃え */
  margin-top: 20px;
  margin-bottom: 20px;
}
.submenu a{
	display: block;
	width:48%;
}
.submenu a:nth-of-type(n+3) {
	margin-top:20px;
}
.box-child {
	text-align: center;
	border-radius: 10px;
	font-size: 0.8em;
	color: #1a6e27;
	border-left:3px solid #06d5bc;
	border:2px solid #06d5bc;
	background-color: #F2FCE0;
	line-height: 1;
	padding-top: 4px;
	padding-bottom: 4px;
}

@media screen and (min-width:480px) {
	.submenu a{
		width:19%;
	}
	.submenu a:nth-of-type(n+3) {
		margin-top:0px;
	}
	.box-child{
		font-size: 1em;
	}
}

.disptit{
	display:block;
	margin-bottom: 20px;
	padding: 8px 0;
	padding-left: 10px;
	font-size: 18px;
	color: #623942;
	border-top: solid 2px #882633;
	border-bottom: solid 2px #882633;
	background-color: #F3E9D0;
}
.disptit:first-of-type{
	margin-bottom: 10px;
}
@media screen and (min-width:480px) {
	.disptit{
		font-size: 20px;
	}
}

.contents_promo{
	width:96%;
	margin: 0 auto;
}
@media screen and (min-width:480px) {
	.contents_promo{
		width:100%;
	}
}

.promo_tit{
	font-size: 18px;
	padding: 5px 0;
	padding-left: 10px;
	background-color: #fffaf4;
}
@media screen and (min-width:480px) {
	.promo_tit{
		font-size: 20px;
		padding: 6px 0;
		padding-left: 10px;
	}
}

.pb_h{
	padding-bottom: 8px;
}

.pt_h{
	width:100%;
	padding-top: 0px;
}
.pt_h20{
	width:100%;
	padding-top: 20px;
	padding-bottom: 10px;
}
.pt_h img{
	width:100%;
}

.contents_promo p{
	display: block;
	padding: 20px 0;
	text-align: justify;
	text-justify: inter-ideograph;
}

.contents_promo h2{
	display: block;
	color: #333;
	font-size: 1.1em !important;
	font-weight: bold;
	border-bottom: solid 1px #00B786;
	padding-top: 20px;
	margin-bottom: 10px;
}

.half{
	display:flex;
	flex-flow: column;
}
.half_p{
	width:100%;
	padding-bottom: 34px;
	padding-left: 0px;
}
.half_p:first-of-type{
	padding-bottom: 0px;
}
@media screen and (min-width:480px) {
	.half{
		flex-flow: nowrap;
	}
	.half_p{
		width:50%;
		padding-left: 0px;
	}
}

.ani{
	margin-bottom: 20px;
	position: relative;
	left: -100%; /* 初期状態で画面外 */
	opacity: 0;
	transition: all 1s ease-out; /* アニメーション設定 */
}
.ani img{
	width:100%;
}

.ani.move{
	left: 0;   /* 元の位置に移動 */
	opacity: 1;
}

.ani_r{
	margin-bottom: 50px;
	position: relative;
	right: -100%; /* 初期状態で画面外 */
	opacity: 0;
	transition: all 1s ease-out; /* アニメーション設定 */
}
.ani_r img{
	width:100%;
}

.ani_r.move{
	right: 0;   /* 元の位置に移動 */
	opacity: 1;
}

.qanda{
	width:100%;
	padding: 0 !important;
	margin-top:10px;
	margin-bottom:50px;
	border: solid 1px;
	border-color:#CACACA;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
@media screen and (min-width:480px) {
	.qanda{
		margin-top:34px;
	}
}
.qanda .picttitbox{
	display: block;
	margin: 0px auto;
	padding-top: 25px;
	padding-bottom: 50px;
	width:50%;
	height:10px;
}
@media screen and (min-width:480px) {
	.qanda .picttitbox{
		width:26%;
	}
}

.qanda .titimg{
	width: 100%;
	font-family: "Kosugi Maru", sans-serif;
	color: #FFF;
	background-color: #02B389;
	font-size: 1.2em;
	padding: 8px;
	margin-bottom: 10px;
}
@media screen and (min-width:480px) {
	.qanda .titimg{
		font-size: 1.3em;
	}
}

.qanda .qatxt{
	width:96%;
	margin: 0 auto;
}
.qanda .qatxt img{
	width:100%;
	margin-top: 0px;
	margin-bottom: 10px;
}
.qanda .qatxt p{
	display: block;
	width:100%;
	padding-top: 0px;
	padding-bottom: 40px;
	text-align: justify;
	text-justify: inter-ideograph;
}

.garimg img{
	width: 100%;
}
.price_main .garimg{
	width: 40%;
}

.price_main .gartxt{
	width: 60%;
	padding-left:20px;
}
.price_main .gartxt p{
	padding-top: 0;
	font-weight: bold;
}
.price_main .gartxt p span{
	color: #F00;
	font-size: 1.2em;
	font-weight: bold;
}

.help_sp{
	display: block;
	margin-bottom: 20px;
}
.help_pc{
	display: none;
}
@media screen and (min-width:480px) {
	.help_sp{
		display: none;
	}
	.help_pc{
		display: block;
	}
}

.help_sp h3,.help_pc h3{
	font-size: 1.2em;
	margin-bottom: 10px;
	border-bottom: solid 1px #CACACA;
}

.fiffif{
	display: flex;
}
.fiffif div{
	width: 50%;
}
.fiffif ol{
	padding-left: 1.3em;
	list-style: disc;
}
.fiffif ol li{
	padding-left 1em;
}

.art{
	line-height: 1.2;
}

.pict_l,.pict_r{
	width: 50%;
}
.pict_l{
	padding-right: 5px;
}
.pict_r{
	padding-left: 5px;
}
.pict_l img,.pict_r img{
	width: 100%;
}
.pict_l img,.pict_r img:first-of-type{
	margin-bottom: 30px;
}

.estatebox{
	display: flex;
	flex-flow: column;
}
.estatebox{
	padding-bottom: 30px !important;
}
.esl{
	width: 100%;
	margin-bottom: 10px;
}
.esl img{
	width: 100%;
}
.esl img:first-of-type{
	margin-bottom: 0px;
}
.esr{
	width: 100%;
	padding-left: 0px;
}
@media screen and (min-width:480px) {
	.estatebox{
		flex-flow: row;
	}
	.esl{
		width: 40%;
		margin-bottom: 0px;
	}
	.esl img{
		width: 100%;
	}
	.esl img:first-of-type{
		margin-bottom: 30px;
	}
	.esr{
		width: 60%;
		padding-left: 20px;
	}
}


/*プライバシーポリシー*/
.contents_p h2{
	display: block;
	color: #333;
	font-size: 1.1em !important;
	font-weight: bold;
	border-bottom: solid 1px #00B786;
	padding-top: 20px;
	margin-bottom: 10px;
}
.pr{
	padding-top: 10px;
	display:flex;
	flex-flow: row;
}
.pr1_1{
	width:6%;
}
.pr1_2{
	width:94%;
}
.pr2_1{
	width:9%;
}
.pr2_2{
	width:91%;
}
@media screen and (min-width:480px) {
	.pr1_1{
		width:3%;
	}
	.pr1_2{
		width:97%;
	}
	.pr2_1{
		width:4%;
	}
	.pr2_2{
		width:96%;
	}
}


.scroll_btn img{
	width: 18%;
	position:fixed;
	bottom: 84px;
	right: 7px;
}
.scroll_btn img:hover{
	cursor: pointer;
}
#topBtn{
	display: none;
}

@media only screen and (min-width: 480px) {
	.scroll_btn img{
		left: calc(900px + (100vw - 900px)/2 + 10px);
		width: 70px;
	}
}
