@charset "utf-8";

html,
body,
div,
span,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
b,
i,
fieldset,
form,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
dialog,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
}

body {
	background-color: #fff;
}

article,
aside,
dialog,
figure,
footer,
header,
hgroup,
nav,
section {
	display: block
}

ul {
	list-style: none
}

/*========================================

BASIC

=======================================*/

html,
body {
	width: 100%;
}

body {
	font-size: 16px;
	font-family: '小塚ゴシック Pro', 'Kozuka Gothic Pro', 'メイリオ', 'Meiryo', sans-serif;
	overflow-wrap: break-word;
}

a {
	color: #0067AA;
	text-decoration: none
}

a:hover {
	color: #FF3300;
}

/* COMMON
=======================================*/
body {
	min-width: 1280px;
}

/* #wrapper */
#wrapper {
	margin: 0 auto;
}

/* #header */
#header {
	width: 100%;
	padding: 0;
	margin: 0;
	height: 65px;
}

#header p {
	display: inline;
	font-size: 24px;
	color: #016FCF;
	font-weight: 500;
	vertical-align: top;
	line-height: 65px;
}

#header img {
	margin: 0 auto;
}

h1 {
	margin: 0 auto;
	padding: 10px 0 10px 0px;
	font-size: 30px;
	font-weight: 500;
	line-height: 45px;
	text-align: center;
	color: #007bc3;

}

#header h1 img {
	vertical-align: bottom;
	margin-right: 10px;
	width: 45px;
}

/* #トップバナー */
#main {
	width: 100%;
	padding: 0;
	margin: 0;
	background-color: #eee;
	display: flex;
	position: relative;
}

#main img {
	width: 100%;
}

#main picture {}

#main h2 {
	position: absolute;
	top: -4px;
	left: 0;
}

.slids {
	width: 100%;
	margin: 0 auto;
	position: relative;
	margin-bottom: -7px;
}

.slids ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.slids ul:before,
.slids ul:after {
	content: "";
	clear: both;
	display: block;
}

.slids ul li {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	animation-iteration-count: infinite;
	animation-duration: 24s;
}


.slids ul li:nth-child(1) {
	animation-name: slids;
	animation-delay: -3s;
}

.slids ul li:nth-child(2) {
	animation-name: slids;
	animation-delay: 5s;
	opacity: 0;
}

.slids ul li:nth-child(3) {
	animation-name: slids;
	animation-delay: 13s;
	opacity: 0;
}


@keyframes slids {
	0% {
		opacity: 0;
	}

	20.83% {
		opacity: 1;
	}

	33.33% {
		opacity: 1;
	}

	45.83% {
		opacity: 0;
	}

	100% {
		opacity: 0;
	}
}



#special {
	width: 100%;
	padding: 10px 0px 20px 0px;
	/*background-color:#eee;*/
}

#special img {
	width: 100%;
}

#special h2,
#shop_list h2 {
	font-size: 30px;
	font-weight: 400;
	text-align: center;
	background-color: #eee;
	padding: 20px 0px 20px 0px;
}

#shop_list {
	width: 100%;
	padding: 0px 0px 20px 0px;
	background-color: #fff;
	text-align: center;
}

#shop_list ul {
	display: inline-block;
	text-align: center;
	margin-bottom: 30px;
	padding: 0;
}

#shop_list li {
	float: left;
	padding-right: 10px;
}

#shop_list li {
	font-size: 28px;
	color: #006DCD;
}

#shop_list li a {
	font-size: 20px;
	color: #000;
}

#shop_list li a:hover {
	color: #ff3300;
}

.shops {
	width: 1200px;
	margin: 0 auto;
	text-align: left;
	clear: both;
}

.shops::after {
	clear: both;
}

.hasen {
	clear: both;
	display: block;
	height: 20px;
}

.shops img {
	/*width:575px;
	height:359px;*/
	content-visibility: auto;
	contain-intrinsic-size: 100px;
}

.shops_detail {
	display: block;
	float: right;
	margin-right: 10px;
	width: 545px;
	padding: 20px 0px 20px 20px;
	background-image: url(../img/shops_back.png);
	background-repeat: no-repeat;
}

.subs {
	font-size: 20px;
	padding-bottom: 5px;
	line-height: 28px;
	word-break: break-all;
}

.shops_detail dl {
	margin: 0;
	clear: both;
}

.shops_detail dt {
	width: 70px;
	float: left;
}

.shops_detail dd {
	font-size: 20px;
	/* 24px */
	padding-bottom: 5px;
	line-height: 36px;
	word-break: break-all;
	vertical-align: middle;
	margin-left: 75px;
}

.snames {
	font-size: 32px;
	/* 36px */
	padding-bottom: 20px;
	line-height: 36px;
}

.sname1 {
	font-size: 20px;
	/* 36px */
	padding-right: 10px;
	line-height: 24px;
}

.sname2 {
	font-size: 20px;
	/* 36px */
	padding-left: 10px;
	line-height: 24px;
}

.icons {
	font-size: 14px;
	/* 14px */
	width: 60px;
	line-height: 25px;
	display: inline-block;
	border: 1px solid #000;
	padding: 1px 2px;
	vertical-align: middle;
	margin-right: 5px;
	text-align: center;
}

.small {
	font-size: 14px;
}

.button {
	margin-top: 10px;
	width: 400px;
	text-align: center;
	background-color: #016FCF;
	border: 2px solid #ccc;
	border-radius: 5px;
}

.button a {
	position: relative;
	display: block;
	padding: 10px 0px;
	font-size: 20px;
	color: #fff;
	vertical-align: middle;
}

.button:hover {
	background-color: #FFF;
}

.button a:hover {
	color: #016FCF;
}

.button a::after {
	content: '';
	display: block;
	width: 10px;
	height: 10px;
	border: 1px solid #fff;
	border-width: 2px 2px 0 0;
	position: absolute;
	transform: rotate(45deg);
	top: 25px;
	right: 24px;
}



/* #トップバナー */
#mains {
	width: 100%;
	padding: 0;
	margin: 0;
	background-color: #eee;
}

#mains h2 {
	font-size: 36px;
	/* 36px */
	font-weight: normal;
}


.shopname {
	padding-top: 25px;
	text-align: center;
}

#main_s {
	width: 1000px;
	margin: 0 auto;
	background-color: #fff;
}

.shops_detail_s {
	display: block;
	padding: 2% 2% 0% 0%;
	background-repeat: no-repeat;
}

#main_s img {
	width: 100%;
	margin: 0;
	padding: 0;
}

#main_s .subs {
	font-size: 24px;
	/* 24px */
	font-weight: 300;
	padding-bottom: 3px;
}

#main_s .snames {
	font-size: 36px;
	/* 36px */
	padding-bottom: 10px;
}

.honbun {
	font-weight: 300;
	font-size: 20px;
	width: 90%;
	margin: 0 auto;
	color: #333;
	margin-top: 0px;
	background-color: #fff;
	text-align: center;
	padding: 30px 0px 40px 0px;
}

.detail {
	clear: both;
	width: 85%;
	margin: 0 auto;
	/*background-color:#eee;*/
	padding: 20px 30px 30px 30px;
	border: solid 2px #eee;
}

.detail h3 {
	font-weight: 400;
	font-size: 30px;
	color: #333;
	text-align: center;
}

.detail dt {
	width: 70px;
	float: left;
}

.detail dd {
	margin-left: 5px;
	display: inline-block;
	font-size: 20px;
	/* 24px */
	font-weight: 300;
	line-height: 36px;
}

.detail dl {
	margin-block-start: 0.4em;
	margin-block-end: 0.4em;
}

#main_s .detail .subs {
	font-size: 20px;
	/* 24px */
	font-weight: 300;
	padding-left: 3px;
	padding-bottom: 3px;
}

#tab_box {
	width: 910px;
	margin: 0 auto;
	margin-top: 10px;
}

.tab {
	float: left;
	width: 227px;
	box-sizing: border-box;
	display: inline-block;
	border-left: solid 1px #000000;
	text-align: center;
	font-weight: 300;
	font-size: 20px;
	height: 50px;
	margin-bottom: 30px;
	color: #aaa;
	padding-top: 0;
}

.tabs {
	font-size: 12px;
	color: #aaa;
}

.tab_right {
	border-right: solid 1px #000000;
}

.photos {
	width: 914px;
	margin: 0 auto;
	margin-bottom: 20px;
}

.photos h3 {
	font-weight: normal;
	font-size: 30px;
	text-align: center;
	margin-bottom: 10px;
}

.photos p {
	font-weight: normal;
	font-size: 18px;
	text-align: left;
	margin-bottom: 20px;
}

.flex {
	display: flex;
	-webkit-flex-wrap: wrap;
	/* Safari etc. */
	-ms-flex-wrap: wrap;
	/* IE10        */
	flex-wrap: wrap;
}

#mains .photos a img {
	width: 100%;
	/*	width:447px;*/
	/*	height:279px;*/
	margin-right: 0px;

	float: left;
}

#mains .photos a:nth-child(odd) {
	margin-right: 18px;
}

#mains .photos a {
	width: calc((100% - 18px) / 2);
	margin-bottom: 18px;
	overflow: hidden;
}

#mains .photos img {
	transition: 1s all;
}

#mains .photos img:hover {
	transform: scale(1.2, 1.2);
	transition: 1s all;
}

#mains .button {
	width: 400px;
	margin: 0 auto;
	margin-top: 20px;
	margin-bottom: 20px;
	font-size: 14px;
	padding: 8px;
}


/* Amex Offersについて */

#about {
	width: calc(100% - 10px);
	background-color: #0067AA;
	font-size: 36px;
	font-weight: 500;
	color: #fff;
	text-align: center;
	vertical-align: middle;
	padding: 5px;
	margin-bottom: 60px;
}

#about p {
	font-size: 24px;
	line-height: 48px;
}

.step {
	font-size: 16px;
	display: inline-block;
	border: 1px solid #fff;
	padding: 2px 4px;
	vertical-align: middle;
	margin-right: 5px;
	margin-bottom: 5px;
	text-align: center;
	line-height: 24px;
}

#caution {
	width: 770px;
	margin: 0 auto;
	padding: 15px;
	font-size: 14px;
	line-height: 140%;
	background-color: #eee;
	margin-bottom: 20px;
}

.ct {
	font-weight: bold;
	text-align: center;
	padding-bottom: 10px;
}

/* 詳細 */

.copy {
	font-size: 16px;
	padding-top: 0px;
	padding-bottom: 20px;
	font-weight: normal;
}

.shop_detail {
	width: calc(100% - 8vw);
	margin: 0 auto;
	border-top-width: 2px;
	border-top-style: solid;
	border-top-color: #006FCF;
	padding: 4vw 0 4vw 0;
}

.shop_detail img {
	margin: 20px 0 20px 0;
	width: 100%;
}

.mains img {
	width: 100%;
}



.gotop {
	margin: 0 auto;
	margin-top: 20px;
	width: 50%;
	background: #006FCF;
	text-align: center;
	padding: 8px;
	border-radius: 4px;
}

.gotop a {
	color: #fff;
}

/* パンくず */
#plist {
	width: 100%;
	height: 30px;
	margin: 0 auto;
	font-size: 12px;
	line-height: 30px;
}

#plist ul {
	margin: 0px;
	padding: 0px;
}

#plist a {
	color: #0067AA;
	text-decoration: none;
	margin-left: 10px;
}

#plist li {
	float: left;
}

.fairlist {
	margin: 20px 0px 0px 0px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #ddd;
	padding-bottom: 10px;
}

.fairlisti img {
	width: 100%;
}

.view {
	width: 100%;
}

.view a {
	font-size: 20px;
}

.view p {
	padding-top: 10px;
}

.view_s img {
	vertical-align: middle;
	margin-right: 10px;
}

.view_s {
	color: #666;
}

.tourl {
	margin-top: 10px;
	text-align: center;
}

.all {
	text-align: center;
	padding: 15px;
}



.scheck {
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #ccc;
	padding: 10px;
	line-height: 20px;
	font-size: 16px;
}

label {
	padding-top: 10px;
	line-height: 25px;
	font-size: 16px;
}

.scheck label,
.kodawari label {
	font-size: 16px;
}


.find {
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #ccc;
	line-height: 20px;
	font-size: 16px;
	height: 20px;
	background-color: #eee;
	text-align: center;
	padding: 10px 10px 10px 10px;
	background-image: url(/neoimg/but.png);
	background-repeat: no-repeat;
	background-position: 50px 12px;
}

/* .footer */
#foote {
	margin: 0 auto;
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #ddd;
	padding: 10px;
	text-align: center;
	height: 30px;
}

.clear {
	clear: both;
}

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

.tabout {
	font-size: 12px;
	font-weight: normal;
	margin-top: 10px;
}

.mb50 {
	margin-bottom: 50px;
}

.mb30 {
	margin-bottom: 30px;
}

.mt30 {
	margin-top: 30px;
}

.mr0 {
	margin-right: 0px;
}

.pc {
	display: inline !important;
}

.spc {
	display: none !important;
}

.up-arrow {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background-color: #006DCD;
	cursor: pointer;
	border: none;
	outline: none;
	font-size: 0;
	position: absolute;
	z-index: 3;
	filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));
}

.up-arrow::before {
	content: '';
	display: block;
	width: 8px;
	height: 8px;
	border: 1px solid #fff;
	border-width: 2px 2px 0 0;
	position: absolute;
	top: 20px;
	left: 18px;
	transform: rotate(-45deg);
}

.pagetop {
	text-align: right;
	margin: 0 70px 48px 0;
	clear: both;
}

/*========================================

SCROLL

=======================================*/

.scroll_up {
	transition: 0.8s ease-in-out;
	transform: translateY(30px);
	opacity: 0;
}

.scroll_up.on {
	transform: translateY(0);
	opacity: 1.0;
}

/*========================================

FOR TABLET

=======================================*/

@media print,
screen and (max-width:1279px) {

	body {
		min-width: 767px;
	}

	.shops {
		width: 748px;
	}

	.shops img {
		width: 364px;
		height: auto;
	}

	.shops_detail {
		width: 344px;
		padding: 0px;
		background-image: none;
	}

	.subs {
		font-size: 16px;
		line-height: 28px;
	}

	.shops_detail dt {
		width: 50px;
	}

	.shops_detail dd {
		font-size: 16px;
		line-height: 24px;
		padding-top: 5px;
	}

	.snames {
		font-size: 24px;
		line-height: 28px;
		padding-bottom: 10px;
	}

	.icons {
		font-size: 12px;
	}

	.button {
		width: 240px;
	}

	.button a {
		font-size: 16px;
	}

	.button a::after {
		width:8px;
		height:8px;
		top: 21px;
		right: 24px;
	}
	
	/* SHOUSAI */

	#main_s {
		width: 100%;
	}

	#tab_box {
		width: 90%;
	}

	.tab {
		width: 50%;
	}

	.photos {
		width: 100%;
	}

	#tab-list2 {
		border-right: solid 1px #000000;
	}

	.tab {
		margin-bottom: 20px;
	}


}