@charset "utf-8";
/* CSS Document */

#wrap{
	position: relative;
}

/* header
---------------------------------------------------------- */
.head-inner{
	width: 100%;
	padding-top: 20px;
	padding-bottom: 20px;
	background-color: #fff;
	z-index: 100;
}
.head-logo{
	width: 35%;
	max-width: 376px;
	height: 56px;
	position: absolute;
	top: 20px;
	left: 0;
	right: 0;
	margin: auto;
}
.g-nav-l{
	width: 30%;
	max-width: 400px;
	float: left;
}
.g-nav-r{
	width: 30%;
	max-width: 400px;
	float: right;
}
.g-nav ul{
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 56px;
}
.g-nav li a{
	color: #000;
	font-size: 15px;
	letter-spacing: .1em;
	position: relative;
	z-index: 10000;
}
.g-nav li a:after{
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -10px;
	margin: auto;
	width: 20px;
	height: 1px;
	background-color: #444;
	visibility: hidden;
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility: hidden;
	-o-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-transition:all 0.3s;
	-moz-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}
.g-nav li.amazon a::before {
	background: left center / contain no-repeat url("../images/icon_amazon.png");
	content: "";
	display: inline-block;
	height: 17px;
	width: 55px;
	margin-top: 2px;
	margin-right: 5px;
	vertical-align: middle;
}
.g-nav li.instagram a {
	background: center / contain no-repeat url("../images/logo_instagram.png");
	display: inline-block;
	overflow: hidden;
	padding-top: 29px;
	height: 0;
	width: 97px;
	vertical-align: middle;
}
@media screen and (min-width: 769px) {
	.g-nav li a:hover{
		text-decoration: none;
		opacity:0.8;
	}
	.g-nav li a:hover:after{
		bottom: -8px;
		visibility: visible;
	}
}

/* footer
---------------------------------------------------------- */
.pagetop{
	position: fixed;
	right: 15px;
	bottom: 15px;
	width: 50px;
	height: 50px;
	background: url(../images/icon_pagetop.png) no-repeat;
	background-size: 50px 50px;
}
footer{
	background: url(../images/bg_footer.jpg) no-repeat center center;
	background-size: cover;
}
.foot-top{
	max-width: 850px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 220px;
	padding-bottom: 40px;
}
.address{
	padding-top: 10px;
	color: #fff;
	font-size: 14px;
	line-height: 24px;
	letter-spacing: .15em;
}
.foot-nav{
	max-width: 750px;
	margin-left: auto;
	margin-right: auto;
	padding-bottom: 40px;
}
.foot-nav ul{
	display: flex;
	justify-content: space-between;
}
.foot-nav li a{
	color: #fff;
	font-size: 14px;
	letter-spacing: .2em;
}
.border-b{
	border: 1px solid #000;
}
.copy{
	color: #fff;
	font-size: 10px;
	letter-spacing: .2em;
	text-align: center;
	padding-bottom: 40px;
}

/* content
---------------------------------------------------------- */
.content{
	background: url(../images/bg_content.png);
}
.inner{
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
}
.inner-xs{
	width: 100%;
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
}
.view-pc{
	display: block;
}
.view-sp{
	display: none;
}
.g-p{
	padding-bottom: 20px;
}

/* section */
.section-first{
	padding-top: 60px;
	padding-bottom: 60px;
}
.section{
	padding-bottom: 60px;
}
.section-ttl{
	position: relative;
}
.section-ttl h1{
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	margin-left: auto;
	margin-right: auto;
	margin-top: -1em;
	z-index: 1;
	color: #fff;
	font-size: 38px;
	font-weight: normal;
	letter-spacing: .18em;
	text-align: center;
	text-shadow: 0 0 5px rgba(0, 0, 0, 1);
}

/* hx */
.ttl1{
	position: relative;
	padding-bottom: 30px;
	margin-bottom: 20px;
	text-align: center;
}
.ttl1:after{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 17px;
	background: url(../images/line_ttl1.png) no-repeat center bottom;
	background-size: 479px 17px;
}
.ttl2{
	color: #333;
	font-size: 24px;
	text-align: center;
	letter-spacing: .2em;
	position: relative;
	padding-bottom: 30px;
	margin-bottom: 30px;
}
.ttl2:after{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 17px;
	background: url(../images/line_ttl1.png) no-repeat center bottom;
	background-size: 479px 17px;
}
.ttl2-line{
	color: #333;
	font-size: 22px;
	line-height: 24px;
	letter-spacing: .15em;
	padding-left: .5em;
	margin-bottom: 20px;
	vertical-align: middle;
	border-left: 3px solid #6cb82d;
	position: relative;
}
.ttl3{
	font-size: 20px;
	letter-spacing: .15em;
	padding-bottom: 20px;
}

/* font-style */
.lead-16{
	line-height: 1.9em;
	letter-spacing: .1em;
}

/* block */
.block{
	padding-bottom: 20px;
}
.block-lg{
	padding-bottom: 50px;
}

/* grid */
.grid{
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	margin: -30px;
}
.grid-xs{
	margin: -10px;
}
.grid-el{
	padding: 30px;
	box-sizing: border-box;
}
.grid-xs .grid-el{
	padding: 10px;
}
.grid-2 .grid-el{
	width: 50%;
}
.grid-3 .grid-el{
	width: 33.333334%;
}
.grid-4 .grid-el{
	width: 25%;
}
.grid-5 .grid-el{
	width: 20%;
}
.grid-6 .grid-el{
	width: 16.666667%;
}

/* table */
.nowrap{
	white-space: nowrap;
}
.table-style-1 table{
	border-top: 1px solid #e3e3e3;
	border-right: 1px solid #e3e3e3;
}
.table-style-1 table th,
.table-style-1 table td{
	padding: 20px;
	border-bottom: 1px solid #e3e3e3;
	border-left: 1px solid #e3e3e3;
	vertical-align: middle;
}
.table-style-1 table th{
	letter-spacing: .15em;
	background-color: rgba(204,204,204,0.15);
}
.table-style-1 table td{
	letter-spacing: .07em;
}

/* btn */
.btn{
	display: inline-block;
	margin: 10px;
	letter-spacing: .15em;
	color: #fff;
	background-color: #c69c6d;
	border: 1px solid #c69c6d;
	border-radius: 50px;
	padding: 8px 20px;
	-webkit-transition:all 0.3s;
	-moz-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}
@media screen and (min-width: 769px) {
	.btn:hover{
		text-decoration: none;
		color: #c69c6d;
		background-color: #fff;
	}
}

/****************************************************

	max-width:1280px

*****************************************************/
@media screen and (max-width: 1280px) {
	.inner{
		width: auto;
		max-width: inherit;
	}
}

/****************************************************

	max-width:980px

*****************************************************/
@media screen and (max-width: 980px) {
	.inner-xs{
		width: auto;
		max-width: inherit;
	}
}

/****************************************************

	max-width:768px

*****************************************************/
@media screen and (max-width: 768px) {
	/* header
	---------------------------------------------------------- */
	.head-inner{
		padding-top: 15px;
		padding-bottom: 0;
	}
	.head-inner .inner {
		padding-top: 0;
	}
	.head-logo{
		width: 80%;
		height: auto;
		max-width: 376px;
		max-height: 56px;
		position: inherit;
		top: inherit;
		left: inherit;
		right: inherit;
		margin-bottom: 15px;
	}
	#btn-menu{
		height: 40px;
		margin-left: -15px;
		margin-right: -15px;
		background: #f2f2f2;
		text-align: center;
		position: relative;
		-webkit-transition:all 0.3s;
		-moz-transition: all 0.3s;
		-o-transition: all 0.3s;
		transition: all 0.3s;
	}
	#btn-menu:before{
		content: "メニューを開く";
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		color: #666;
		font-size: 14px;
		letter-spacing: .2em;
		line-height: 40px;
	}
	#btn-menu.open:before{
		content: "メニューを閉じる";
	}
	.g-nav{
		padding-top: 10px;
		padding-bottom: 10px;
		display: none;
	}
	.g-nav ul{
		display: block;
		height: auto;
		width: auto;
		max-width: inherit;
		float: none;
	}
	.g-nav li{
		width: 100%;
	}
	.g-nav li a{
		display: inline-block;
		padding: 10px;
	}
	.g-nav li.instagram a {
		padding: 29px 0 0;
		margin: 10px;
	}

	/* footer
	---------------------------------------------------------- */
	.foot-top{
		padding-bottom: 0;
		padding-top: 50px;
	}
	.foot-top .grid-el{
		text-align: center;
	}
	.foot-nav ul {
		align-items: center;
		flex-direction: column;
	}
	.foot-nav li{
		padding-bottom: 10px;
	}
	.foot-nav li:last-child{
		padding-bottom: 0;
	}

	/* content
	---------------------------------------------------------- */
	.inner,
	.inner-xs{
		padding-left: 15px;
		padding-right: 15px;
	}
	.view-pc{
		display: none;
	}
	.view-sp{
		display: block;
	}

	/* section */
	.section-ttl h1{
		font-size: 28px;
	}
	
	/* grid */
	.grid{
		margin: -30px -30px 30px;
	}
	.grid-xs{
		margin: -10px -10px 10px;
	}
	.grid-2 .grid-el,
	.grid-3 .grid-el{
		float: none;
		width: auto;
		padding: 30px 30px 0;
	}
	.grid-4 .grid-el{
		width: 50%;
	}
	.grid-5 .grid-el{
		width: 50%;
	}
	.grid-6 .grid-el{
		width: 50%;
	}

	/* table */
	.table-style-1 table th,
	.table-style-1 table td{
		width: 100%;
		display: block;
		box-sizing: border-box;
		text-align: left;
		padding: 15px;
	}
}