@charset "UTF-8";
/*----------------------------------------------
 reset styles
----------------------------------------------*/
main { margin:0; padding:0; border:0; outline:0; font-size:100%; vertical-align:baseline; background:transparent; display:block; } 

/*----------------------------------------------
 formatting styles
----------------------------------------------*/
html {
	font-size: 62.5%;
	box-sizing: border-box;
}
*, *:before, *:after {
  box-sizing: inherit;
}
body {
	font-family: "Hiragino Kaku Gothic ProN","メイリオ",Meiryo,"ＭＳ Ｐゴシック",sans-serif;
	font-size: 1.3em;/* =13px */
	line-height: 1.6;
	color: #ffffff;
	text-align: center;
}
body:after {
	content: "";
	display: block;
	position: fixed;
	left: 0;
	top: 0;
	z-index: -1;
	width: 100vw;
	height: 100vh;
	background: url(../img/bg.jpg) 0 center no-repeat;
	background-size: cover;
}
@media screen and (max-width:767px) {
	body {
		word-break: break-all;
		-webkit-text-size-adjust: 100%;
	}
	body:after {
		background-position: 35% center;
	}
	th, td {
		word-break: break-all;
	}
}
a {
	color: inherit;
	text-decoration: none;
}
img {
	border-style: none;
	line-height: 1.0;
}
.hidden {
	display: none;
}
@media screen and (min-width:768px) {
	a:hover {
		text-decoration: underline;
	}
	a:hover img {
		opacity: 0.7;
	}
}

/*----------------------------------------------
 clearfix
----------------------------------------------*/
.clearfix:after {
    content:"";
    display:block;
    clear:both;
}

/* ----------------------------------------------
header
----------------------------------------------*/
header {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	z-index: 10;
}
header > .inner {
	padding: 20px;
}
header > .inner:after {
	content: "";
	display: block;
	clear: both;
}
header .logo {
	float: left;
}
header nav {
	float: right;
}
nav li {
	display: inline-block;
	margin-left: 2em;
}

@media screen and (max-width:767px) {
	header {
		background-color: rgba(255, 255, 255, 0.9);
		color: #333333;
		position: fixed;
	}
	header > .inner {
		padding: 0;
	}
	header .logo {
		float: none;
		display: none;
		margin-top: 25px;
	}
	header .logo img {
		display: none;
	}
	header .logo a {
		display: block;
		background: url(../img/logo02.png) center 0 no-repeat;
		background-size: auto 100%;
		width: 100%;
		height: 20px;
	}
	header nav {
		float: none;
	}
	nav ul {
		display: none;
		padding: 30px 0 20px;
	}
	nav li {
		display: list-item;
		margin-left: 0;
	}
	nav li + li {
		margin-top: 20px;
	}
	header .btnMenu {
		display: block;
		position: absolute;
		right: 15px;
		top: 15px;
		width: 25px;
		height: 22px;
	}
	header .btnMenu .line {
		display: block;
		height: 2px;
		background-color: #fff;
		position: relative;
		top: 10px;
		transition: all 0.2s linear 0s;
	}
	header .btnMenu .line:before {
		content: "";
		display: block;
		height: 2px;
		width: 100%;
		background-color: #fff;
		position: absolute;
		top: -9px;
		transition: all 0.4s linear 0s;
	}
	header .btnMenu .line:after {
		content: "";
		display: block;
		height: 2px;
		width: 100%;
		background-color: #fff;
		position: absolute;
		top: 9px;
		transition: all 0.4s linear 0s;
	}
	.open .btnMenu .line {
		background-color: transparent;
	}
	.open .btnMenu .line:before {
		background-color: #333333;
		top: 0;
		-webkit-transform:rotate(135deg);
		transform:rotate(135deg);
	}
	.open .btnMenu .line:after {
		background-color: #333333;
		top: 0;
		-webkit-transform:rotate(-135deg);
		transform:rotate(-135deg);
	}
}

/* ----------------------------------------------
main
----------------------------------------------*/
main {
	position: relative;
	width: 100%;
	height: 100vh;
}
.mainbox {
	width: 770px;
	margin: 0 auto;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}
.mainbox > .inner:after {
	content: "";
	display: block;
	clear: both;
}
.img01 {
	float: right;
	list-style: none;
	background: url(../img/sp-bg.png) 0 0 no-repeat;
	background-size: 280px auto;
	width: 280px;
	overflow: hidden;
	position: relative;
}
.img01:after {
	content: "";
	display: block;
	padding-top: 200%;
}
.img01 li {
	display: none;
	position: absolute;
	left: 18px;
	top: 15px;
	width: 245px;
}
.img01 .active {
	display: list-item;
}
.img01 li img {
	width: 100%;
}
.textbox {
	list-style: none;
	font-size: 3.1rem;
	width: 410px;
	float: left;
	margin-top: 100px;
	position: relative;
}
.textbox:after {
	content: "";
	display: block;
	padding-top: 3.2em;
}
.textbox li {
	display: none;
	position: absolute;
	left: 50%;
	top: 0;
	width: 100%;
	margin-left: -205px;
}
.textbox .active {
	display: list-item;
}
.mainbox .logo {
	width: 410px;
	float: left;
	margin: 40px 0;
}
.store {
	width: 410px;
	float: left;
	list-style: none;
	letter-spacing: -0.5em;
}
.store li {
	display: inline-block;
	letter-spacing: 0;
}
.store li + li {
	margin-left: 20px;
}
.caution {
	width: 410px;
	float: left;
	margin-top: 38px;
}

.bottombox .btnHikken {
	margin: 0 auto;
	font-size: 2.2rem;
}
.btnHikken a {
	display: block;
	width: 290px;
	position: fixed;
	right: 20px;
	bottom: 0;
	padding: 12px 0;
	background-color: rgba(0, 0, 0, 0.6);
	border-color: rgba(64, 64, 65, 0.6);
	border-style: solid;
	border-width: 1px 1px 0;
	border-radius: 8px 8px 0 0;
}
.btnHikken a span {
	display: inline-block;
	background: url(../img/arrow-up.png) right center no-repeat;
	background-size: 20px auto;
	padding-right: 30px;
}
.bottombox .box01 {
	background-color: rgba(0, 0, 0, 0.6);
	position: fixed;
	left: 0;
	bottom: 0;
	width: 100%;
	padding: 15px 0;
	text-align: center;
}
.bottombox .inner {
	padding: 0 10px;
	position: relative;
	font-size: 1.8rem;
	margin: 0 auto;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}
.bottombox .inner > * {
	-webkit-flex: 0 1 auto;
	flex: 0 1 auto;
}
.bottombox .text {
	text-align: left;
	padding-left: 20px;
	padding-right: 20px;
}
.bottombox .text .midashi,.bottombox .text span > span {
	display: none;
}
.bottombox .img {
	width: 272px;
	align-self: stretch;
	line-height: 1;
	position: relative;
}
.bottombox .img > p {
	display: block;
	position: absolute;
	height: 136px;
	left: 0;
	bottom: 0;
}
.bottombox .img > p + p {
	margin-left: 10px;
	left: auto;
	right: 0;
}
.bottombox .img img {
	width: auto;
	height: 100%;
}
.bottombox .btnMore {
	font-size: 2.2rem;
	font-weight: bold;
	white-space: nowrap;
}
.bottombox .btnMore a {
	display: block;
	background-color: #ffaa00;
	border-radius: 4px;
	padding: 12px 30px;
	text-decoration: none;
}
.bottombox .btnClose {
	position: absolute;
	right: 10px;
	top: 15px;
	cursor: pointer;
}
@media screen and (min-width:768px) {
	.btnHikken a:hover {
		background-color: rgba(0, 0, 0, 1.0);
		border-color: rgba(64, 64, 65, 1.0);
	}
	.bottombox .box01 a:hover {
		opacity: 0.8;
	}
}
@media screen and (max-width:767px) {
	.mainbox {
		width: 100%;
		max-height: 100%;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		top: 50%;
		transform: translate(-50%,-50%);
	}
	.mainbox > .inner {
		display: -webkit-flex;
		display: flex;
		-webkit-flex-direction: column;
		flex-direction: column;
	}
	.img01 {
		float: none;
		width: 132px;
		background-size: 100% auto;
		margin: 0 auto 15px;
	}
	.img01 li {
		width: 115px;
		left: 9px;
		top: 8px;
	}
	.textbox {
		float: none;
		width: 100%;
		font-size: 100%;
		margin: 10px 0;
		-webkit-order: -1;
		order: -1;
	}
	.textbox li {
		margin-left: -50%;
	}
	.mainbox .logo {
		float: none;
		width: auto;
		margin: 20px 10px 0;
		-webkit-order: -2;
		order: -2;
	}
	.mainbox .logo img {
		width: 166px;
	}
	.store {
		float: none;
		width: auto;
		margin: 0px 10px;
	}
	.store li {
		max-width: 200px;
		width: 49%;
		vertical-align: middle;
	}
	.store li + li {
		margin-left: 2%;
	}
	.store li img {
		width: 100%;
		height: auto;
	}
	.caution {
		float: none;
		width: auto;
		margin: 10px 10px 0;
		padding-bottom: 50px;
	}
	
	.bottombox .btnHikken {
		width: auto;
		font-size: 1.4rem;
	}
	.btnHikken a {
		margin-left: 0;
		right: 15px;
		width: auto;
		padding: 8px 15px;
	}
	.btnHikken a span {
		background-size: auto 0.9em;
		padding-right: 25px;
	}
	.bottombox .box01 {
		background-color: rgba(0, 0, 0, 0.8);
		height: 100%;
		z-index: 10;
		text-align: center;
	}
	.bottombox .inner {
		width: 100%;
		max-height: 100%;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		position: absolute;
		left: 50%;
		top: 50%;
		display: -webkit-flex;
		display: flex;
		-webkit-flex-direction: column;
		flex-direction: column;
		transform: translate(-50%, -50%);
	}
	.bottombox .text {
		padding: 15px 0 0;
		display: block;
		line-height: 2.0;
		text-align: center;
		-webkit-order: -1;
		order: -1;
	}
	.bottombox .text br {
		display: none;
	}
	.bottombox .text span {
		display: block;
	}
	.bottombox .text span > span {
		display: inline-block;
	}
	.bottombox .text .midashi {
		display: block;
		margin-bottom: 20px;
		font-size: 1.8rem;
		font-weight: bold;
		letter-spacing: 1px;
	}
	.bottombox .img {
		position: static;
		display: block;
		width: 300px;
		margin: 40px auto;
	}
	.bottombox .img p {
		position: static;
		display: inline-block;
	}
	.bottombox .box01 a {
		float: none;
		display: inline-block;
		font-size: 1.6rem;
		margin-bottom: 20px;
	}
}