@charset "UTF-8";
/* pageTit */
#pageTit {
	position: absolute;
	z-index: 3;
	top: 40px;
	left: 1.5%;
}
#pageTit h1 {
	margin: 0;
	font-size: 100%;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}
@media screen and (max-width: 800px) {
	#pageTit {
		top: 1.5%;
		left: 0.5%;
	}
	#pageTit h1 {
		font-size: 70%;
	}
}
@media screen and (max-width: 600px) {
	#pageTit {
		left: 0;
	}
}
@media screen and (max-width: 600px) {
	#pageTit {
		top: 10px;
		left: 5%;
	}
	#pageTit h1 {
		-ms-writing-mode: inherit;
		writing-mode: inherit;
	}
}
/* topWrapper */
#topWrapper {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 5% 0;
}
@media screen and (max-width: 800px) {
	#topWrapper {
		padding: 5% 5% 0;
	}
}
@media screen and (max-width: 600px) {
	#topWrapper {
		padding: 40px 5% 0;
	}
}
/* topArea */
#topArea {
	background-color: #f3f2e8;
	padding-bottom: 40px;
}
/* mainArea */
#mainArea {
	position: relative;
}
/* mainBlock */
#mainBlock {
	position: relative;
	z-index: 2;
}
#topLogo {
	width: 55%;
	padding: 3% 0 34% 3%;
}
@media screen and (max-width: 600px) {
	#topLogo {
		width: 84%;
		padding: 6% 0 46% 8%;
	}
}
/* bg01 */
#bg01 {
	position: absolute;
	width: 100%;
	z-index: 1;
	top: 0;
	left: 0;
}
#bg01 img {
	padding: 22% 0 0 7%;
	width: 50%;
}
@media screen and (max-width: 600px) {
	#bg01 {
		left: -20%;
	}
	#bg01 img {
		padding: 26% 0 0 0;
		width: 80%;
	}
}
/* slideArea */
#slideArea {
	position: absolute;
	width: 100%;
	margin: 7% auto 0;
	z-index: 0;
	top: 0;
	left: 0;
}
#slideBox {
	width: 50%;
	padding: 0 3% 0 47%;
}
@media screen and (max-width: 600px) {
	#slideBox {
		width: 70%;
		padding: 48% 0 0 40%;
	}
}
/* conceptArea */
#conceptArea {
	position: relative;
	z-index: 2;
}
/* copyBox */
.copyBox {
	position: relative;
	z-index: 1;
	float: left;
	width: 22%;
	padding: 0 4% 4% 7%
}
@media screen and (max-width: 600px) {
	.copyBox {
		float: none;
		width: 26%;
		padding: 0 4% 4% 7%;
	}
}
/* conceptBox */
.conceptBox {
	position: relative;
	z-index: 3;
	float: right;
	width: 60%;
	padding: 2% 3% 2% 0;
}
@media screen and (max-width: 600px) {
	.conceptBox {
		float: none;
		width: 86%;
		padding: 0 0 2% 0;
		margin: 0 auto;
	}
}
.conceptBox h2 {
	font-size: 400%;
	line-height: 100%;
	margin: 0;
}
@media screen and (max-width: 1100px) {
	.conceptBox h2 {
		font-size: 300%;
	}
}
@media screen and (max-width: 900px) {
	.conceptBox h2 {
		font-size: 200%;
	}
}
.conceptBox h2 span {
	padding-left: 1%;
}
.conceptBox h3 {
	font-size: 140%;
}
@media screen and (max-width: 900px) {
	.conceptBox h3 {
		font-size: 100%;
	}
}
@media screen and (max-width: 600px) {
	.conceptBox h3 {
		font-size: 80%;
	}
}
.conceptBox p {
	text-align: justify;
	line-height: 180%;
}
/* bg02 */
#bg02 {
	position: absolute;
	width: 100%;
	z-index: 1;
	top: 0;
	left: 0;
}
#bg02 img {
	padding: 18% 0 0 50%;
	width: 46%;
}
@media screen and (max-width: 1000px) {
	#bg02 img {
		padding: 24% 0 0 40%;
	}
}
@media screen and (max-width: 800px) {
	#bg02 img {
		padding: 34% 0 0 0;
		width: 55%;
		margin: 0 auto;
	}
}
@media screen and (max-width: 700px) {
	#bg02 img {
		padding: 44% 0 0 0;
	}
}
@media screen and (max-width: 600px) {
	#bg02 {
		position: relative;
		width: 100%;
		z-index: 1;
		top: inherit;
		left: inherit;
	}
	#bg02 img {
		width: 70%;
		margin: 0 auto;
		;
		padding: 0;
	}
}
/* ruleArea */
#ruleArea {
	position: relative;
	z-index: 2;
}
/* ruleBox */
.ruleBox {
	position: relative;
	z-index: 3;
	width: 86%;
	margin: 0 auto;
	padding: 0 0 6%;
}
@media screen and (max-width: 800px) {
	.ruleBox {
		padding: 30% 0 6%;
	}
}
@media screen and (max-width: 600px) {
	.ruleBox {
		width: 86%;
		padding: 5% 0 2%;
	}
}
.ruleBox h2 {
	font-size: 400%;
	line-height: 100%;
	margin: 0;
}
@media screen and (max-width: 1100px) {
	.ruleBox h2 {
		font-size: 300%;
	}
}
@media screen and (max-width: 900px) {
	.ruleBox h2 {
		font-size: 200%;
	}
}
.ruleBox h2 span {
	padding-left: 1%;
}
.ruleBox h3 {
	font-size: 140%;
}
@media screen and (max-width: 900px) {
	.ruleBox h3 {
		font-size: 100%;
	}
}
@media screen and (max-width: 600px) {
	.ruleBox h3 {
		font-size: 80%;
	}
}
.ruleBox dl {
	border-bottom: dotted 1px;
	padding: 10px 0;
}
.ruleBox dt {
	padding: 0 1em;
	font-weight: bold;
}
.ruleBox dd {
	padding: 5px 1em 0;
	line-height: 180%;
}
@media screen and (max-width: 600px) {
	.ruleBox dt {
		padding: 0;
	}
	.ruleBox dd {
		padding: 5px 0 0;
	}
}
.ruleBox dd.mini {
	font-size: 85%;
}
.ruleBox dd span {
	color: #9a071b;
	padding: 0 0.5em;
}
.ruleBox dd.tel {
	font-size: 130%;
}
.ruleBox dd span.webfontL {
	font-size: 130%;
}
@media screen and (max-width: 600px) {
	.ruleBox dd span.webfontL {
		font-size: 110%;
	}
}
/* newsArea */
#newsArea {
	position: relative;
	z-index: 0;
	padding: 10% 0 0;
}
@media screen and (max-width: 600px) {
	#newsArea {
		padding-top: 48%;
	}
}
@media screen and (max-width: 600px) {
	#newsArea {
		padding-top: 45%;
	}
}
/* newsTit */
.newsTit {
	position: relative;
	color: #f3f2e8;
	padding: 3%;
}
.newsTit h2 {
	position: relative;
	z-index: 3;
	font-size: 400%;
	line-height: 100%;
	margin: 0;
}
@media screen and (max-width: 1100px) {
	.newsTit h2 {
		font-size: 300%;
	}
}
@media screen and (max-width: 900px) {
	.newsTit h2 {
		font-size: 180%;
	}
}
.newsTit h2 span {
	padding-left: 1%;
}
.newsTit h3 {
	position: relative;
	z-index: 3;
	font-size: 140%;
	line-height: 100%;
	margin: 0;
	padding-top: 2%;
}
@media screen and (max-width: 900px) {
	.newsTit h3 {
		font-size: 100%;
	}
}
@media screen and (max-width: 600px) {
	.newsTit h3 {
		font-size: 80%;
	}
}
/* bg_barL*/
/* bg_bar_block01*/
.bg_bar_blockL01 {
	display: block;
	float: left;
	height: 100%;
}
@keyframes expand {
	from {
		width: 0%;
	}
	to {
		width: 100%;
	}
}
/* bg_barL_grad01 */
.bg_barL_grad01 {
	position: absolute;
	z-index: 1;
	top: 0;
	left: -6%;
	width: 100%;
	height: 100%;
	opacity: 0;
}
@media screen and (max-width: 600px) {
	.bg_barL_grad01 {
		height: 100%;
	}
}
/* bg_bar_animeL */
.bg_bar_animeL {
	width: 0%;
	animation: expand 1.5s ease forwards;
	opacity: 1;
	transition: 0.5s;
}
.bg_barL {
	width: 55%;
	background-color: #9a071b;
}
@media screen and (max-width: 600px) {
	.bg_barL {
		width: 80%;
	}
}
/* slideArea2 */
#slideArea2 {
	position: absolute;
	width: 37%;
	margin: -20% 0 0 56%;
	z-index: 0;
	top: 0;
	left: 0;
	border-radius: 1000px;
	overflow: hidden;
}
@media screen and (max-width: 600px) {
	#slideArea2 {
		width: 50%;
		margin: -40% 0 0;
		z-index: 0;
		top: 0;
		left: inherit;
		right: -6%;
	}
}
/* newsBox */
.newsBox {
	position: relative;
	z-index: 2;
	width: 42%;
	float: left;
	margin: 0 0 0 5%;
	padding: 5% 0 0 0;
}
@media screen and (max-width: 600px) {
	.newsBox {
		width: 86%;
		float: none;
		padding: 4% 0 0 0;
		margin: 0 auto;
	}
}
/* bannerBlock */
.bannerBlock {
	position: relative;
	z-index: 2;
	width: 42%;
	float: right;
	margin: 0 5% 0 0;
	padding: 5% 0 0 0;
}
@media screen and (max-width: 600px) {
	.bannerBlock {
		width: 86%;
		float: none;
		padding: 4% 0 0 0;
		margin: 0 auto;
	}
}
.bannerOn {
	padding-bottom: 4%;
}
.bannerBlock h2.banner {
	margin: 0;
}
/* snsBox */
.snsBox {
	position: relative;
	z-index: 2;
	width: 42%;
	float: right;
	margin: 0;
	padding: 5% 5% 5% 0;
}
@media screen and (max-width: 600px) {
	.snsBox {
		width: 100%;
		float: none;
		padding: 4% 0 0 0;
		margin: 0 auto;
	}
}
.facebook_wrap {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
}
.fb-page, .fb-page span, .facebook_wrap iframe {
	width: 100% !important;
	height: 500px !important;
}
/* bannerArea */
#bannerArea {
	width: 90%;
	margin: 0 auto;
	padding: 6% 0 0;
	border-bottom: dotted #ccc 1px;
}
@media screen and (max-width: 600px) {
	#bannerArea {
		border-bottom: none;
	}
}
/* bannerBox */
.bannerBox {
	float: left;
	width: 47.5%;
	padding: 0 2.5% 3% 0;
}
.bannerBox:nth-child(even) {
	float: right;
	width: 47.5%;
	padding: 0 0 3% 2.5%;
}
@media screen and (max-width: 600px) {
	.bannerBox {
		float: none;
		width: 100%;
		padding: 4% 0 0 0;
	}
	.bannerBox:nth-child(even) {
		float: none;
		width: 100%;
		padding: 4% 0 0 0;
	}
}
.bannerBox h2 {
	padding: 0 0 4% 0;
	margin: 0;
}
@media screen and (max-width: 600px) {
	.bannerBox h2 {
		padding: 0 0 4% 0;
	}
}
/* topics */
.topics {
	padding-bottom: 4%;
}
.topics .day {
	font-size: 60%;
	font-weight: bold;
}
.topics .instagramBox {
	width: 70px;
}
@media screen and (max-width: 600px) {
	.topics .instagramBox {
		width: 50px;
	}
}
.topics a {
	display: block;
}
.topics a:hover {
	display: block;
	color: #0068b7;
	transition: 0.2s;
}
.topics h2 {
	font-size: 100%;
	font-weight: bold;
}
.topics h2 span {
	font-size: 80%;
	color: #9a071b;
}
/* btn */
.btn {
	position: absolute;
	z-index: 4;
	top: 20px;
	right: 4%;
	line-height: 100%;
}
.btn a {
	border: solid 2px #9a071b;
	background-color: #fff;
	padding: 20px;
	color: #9a071b;
	display: block;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}
.btn:hover a {
	border: solid 2px #9a071b;
	background-color: #9a071b;
	transition: .3S;
	-webkit-transition: .3s;
	color: #fff;
}
@media screen and (max-width: 800px) {
	.btn {
		position: fixed;
		z-index: 4;
		top: inherit;
		right: inherit;
		bottom: 0;
		left: 0;
		line-height: 120%;
		font-size: 70%;
		font-weight: bold;
	}
	.btn a {
		padding: 20px 10px;
		-ms-writing-mode: inherit;
		writing-mode: inherit;
	}
}
/* takeoutArea */
#takeoutArea {
	position: relative;
	z-index: 3;
	padding-top: 1%;
}
@media screen and (max-width: 1100px) {
	#takeoutArea {
		padding-top: 7%;
	}
}
@media screen and (max-width: 900px) {
	#takeoutArea {
		padding-top: 4%;
	}
}
@media screen and (max-width: 800px) {
	#takeoutArea {
		padding-top: 8%;
	}
}
/* takeoutBox */
#takeoutBox {
	float: left;
	width: 52%;
	padding: 2% 6%;
}
@media screen and (max-width: 800px) {
	#takeoutBox {
		float: none;
		width: 80%;
		padding: 6%;
		margin: 0 auto;
		background-color: #fff;
		box-shadow: 0 0 5px 0 rgba(0, 0, 0, .2);
	}
}
#takeoutBox h2 {
	font-size: 400%;
	line-height: 100%;
	margin: 0;
}
@media screen and (max-width: 1100px) {
	#takeoutBox h2 {
		font-size: 300%;
	}
}
@media screen and (max-width: 900px) {
	#takeoutBox h2 {
		font-size: 200%;
	}
}
#takeoutBox h2 span {
	padding-left: 1%;
}
#takeoutBox h3 {
	font-size: 140%;
}
@media screen and (max-width: 900px) {
	#takeoutBox h3 {
		font-size: 100%;
	}
}
@media screen and (max-width: 800px) {
	#takeoutBox h3 {
		font-size: 80%;
		padding-bottom: 2%;
	}
}
#takeoutBox h5 {
	margin-top: 35px;
	padding: 0 2%;
	color: #fff;
	background-color: #000;
	-webkit-border-radius: 2px;
	-moz-border-radius: 2px;
	border-radius: 2px;
}
/* takeoutMenu */
#takeoutMenu {
	border: solid 2px;
	background-color: #fff;
	padding: 0 4% 20px;
}
.takeout {
	padding: 25px 0 0;
}
.takeout h4 {
	font-size: 100%;
	line-height: 130%;
	margin: 0;
}
#takeoutBox .takeout h5 {
	border-top: dotted 1px;
	padding: 2% 0 0 0;
	font-size: 90%;
	line-height: 140%;
	margin: 0;
	color: #000;
	background: none;
	-webkit-border-radius: 0;
	-moz-border-radius: 0;
	border-radius: 0;
}
.takeout ol {
	font-size: 80%;
	line-height: 160%;
	padding: 5px 0 0 10px;
	margin: 0;
}
.takeout p {
	padding-top: 5px;
	font-size: 80%;
}
.takeout p.leftLine {
	font-weight: bold;
}
#takeoutBox p.point {
	color: #9a071b;
	font-weight: bold;
	padding: 2% 0;
}
#takeoutBox dl {
	font-weight: bold;
}
#takeoutBox dt {
	padding: 2% 0;
	font-weight: bold;
	font-size: 80%;
}
#takeoutBox dd {
	font-size: 120%;
}
@media screen and (max-width: 500px) {
	#takeoutBox dt {
		padding: 4% 0;
		font-weight: bold;
		font-size: 80%;
	}
	#takeoutBox dd {
		font-size: 100%;
	}
}
.telBox {
	padding-top: 3%;
}
/* facebookBox */
#facebookBox {
	float: right;
	width: 33%;
	max-width: 500px;
	padding: 2% 3% 0 0;
}
@media screen and (max-width: 800px) {
	#facebookBox {
		float: none;
		width: 86%;
		padding: 8% 0 0 0;
		margin: 0 auto;
	}
}
.fbLogo {
	width: 40px;
	margin: 0 auto;
	padding-bottom: 4%;
}
/* opening */
.shutter {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	background-color: #9a071b;
	z-index: 1000;
	-webkit-animation: byeShutter 2.4s forwards;
	animation: byeShutter 2.4s forwards;
}
.logo {
	position: absolute;
	width: 30%;
	top: 24%;
	left: 0;
	right: 0;
	margin: auto;
	-webkit-animation: logo 0.8s forwards;
	animation: logo 0.8s forwards;
	animation-delay: 0.2s;
}
@media screen and (max-width: 600px) {
	.logo {
		width: 50%;
		top: 28%;
	}
}
@keyframes byeShutter {
	70% {
		opacity: 1;
	}
	100% {
		display: none;
		opacity: 0;
		z-index: -1;
	}
}
@keyframes logo {
	0% {
		opacity: 1;
	}
	50% {
		transform: rotate(0deg);
	}
	100% {
		transform: scale(0.8);
	}
}
/* popup
================================================== */
.lock {
	overflow: hidden;
}
.modal-content {
	position: relative;
	display: none;
	width: 60%;
	max-height: 80%;
	margin: 30px;
	padding: 20px;
	background: #fff;
	overflow: auto;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border: solid 2px #9a071b;
}
.modal-overlay {
	z-index: 10500;
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 120%;
	background-color: rgba(0, 0, 0, 0.45);
}
.modal-wrap {
	z-index: 10600;
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
}
.modal-open {}
.modal-open:hover {
	cursor: pointer;
}
@media (max-width: 960px) {
	.modal-content {
		width: 90%;
		margin: 0;
	}
}
@media (max-width: 600px) {
	.modal-content {
		width: 80%;
		margin: 0;
	}
}
/* modalBox
================================================== */
.modalBox {
	max-width: 800px;
	margin: 0 auto;
}
.modalBox h2 {
	font-size: 140%;
	padding-bottom: 15px;
	line-height: 140%;
	border-bottom: solid #333 1px;
}
.modalBox h2 span.sTxt {
	font-weight: bold;
	font-size: 70%;
}
.modalBox h3 {
	font-size: 100%;
	padding: 0 0 15px;
	margin: 0;
	font-weight: bold;
	line-height: 160%;
}
.modalBox p {
	margin-bottom: 1em;
	line-height: 160%;
}
.modalBox p.leftBorder {
	border-left: solid 5px #999;
	padding-left: 1em;
}
.modalBox .red {
	color: #9a071b;
}
.modalBox .sTxt {
	font-size: 70%;
}
.modalBox .bold {
	font-weight: bold;
}
.modalBox .kakomi{
	padding: 30px 5% 15px;
	margin-bottom: 5%;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border: solid 2px #9a071b;
}
.modalImg img {
	width: 100%;
}
.closeBtn {
	padding-top: 20px;
	float: right;
	width: 100px;
	display: block;
}
.closeBtn img {
	width: 100%;
}
@media (max-width: 800px) {
	.closeBtn {
		width: 60px;
	}
}
@media (max-width: 639px) {
	.modalBox h2 {
		font-size: 100%;
	}
	.modalBox p.closeBtn {
		padding: 20px 0 0;
	}
}
.imgArea {
	padding: 0 0 15px;
}
.imgArea figure {
	float: left;
	width: 33.3%;
}
.imgAreaS {
	padding: 0 0 15px;
}