@charset "utf-8";
/* CSS Document */

body#index {
	background-color: #fff;
	background: url(../images/vanilland_index_bg.jpg) no-repeat center top;
	background-attachment: fixed;
}

.l-main {
	margin: 0 auto;
	width: 1100px;
	padding: 0 20px;
	background-color: rgb(255 255 255 / 80%);
}

.header__text {
	padding: 10px;
	width: 100%;
	height: 20px;
}

.header__text h1 {
	font-size: 12px;
	font-weight: normal;
	line-height: 20px;
	text-align: center;
}

.l-main_inner {
	padding-top: 0;	
}
body#index .l-main .logo {
	margin: 0 auto 40px;
	width: 470px;
	height: 94px;
}
body#index .l-main .logo h1 {
	width: 100%;
	height: 100%;
}

body#index .l-main .logo h1 img {
	display: block;
	max-width: 100%;
}

.thumbList {
	width: 100%;
}

.thumbList ul {
	margin-bottom: 30px;
	display: flex;
	justify-content: center;
}

.thumbList ul li {
	width: 440px;
}

.thumbList ul li:first-child {
	margin-right: 20px;
}

.thumbList ul li a {
	display: block;
	width: 100%;
	height: 100%;
}
.thumbList ul li:nth-child(2) .thumbList__photo {
	position: relative;
}

.thumbList ul li:nth-child(2) .thumbList__photo:before {
	margin: auto;
	content: "";
	position: absolute;
	width: 80px;
	height: 50px;
	border-radius: 10px;
	background-color: #DA1725;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.thumbList ul li:nth-child(2) .thumbList__photo:after {
	margin: auto;
	content: "";
	position: absolute;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 13px 0 13px 22px;
	border-color: transparent transparent transparent #ffffff;
	top: 0;
	left: 4px;
	right: 0;
	bottom: 0;
}

.thumbList ul li .thumbList__photo img {
	display: block;
	max-width: 100%;
}

.thumbList ul li .thumbList__text {
	width: 100%;
	height: 40px;
	color: #000;
	font-size: 16px;
	font-weight: bold;
	line-height: 40px;
	text-align: center;
}

.enterList {
	margin: 0 auto 40px;
	padding: 25px 40px;
	width: 820px;
	/*background-color: #F5F5F5;*/
	background-color: #FFF;
}

.enterList .enterList__title {
	margin-bottom: 25px;
	
}

.enterList .enterList__title h2 {
	font-size: 26px;
	line-height: 26px;
	text-align: center;
}

.enterList ul {
	display: flex;
	flex-flow: row wrap;
}

.enterList ul li {
	margin-right: 20px;
	width: calc((100% - 20px)/2);
	height: 90px;
}

.enterList ul li:nth-child(2n) {
	margin-right: 0;
}

.enterList ul li:nth-child(n+3) {
	margin-top: 20px;
}

.enterList ul li.ctg1 a {
	background-color: #FB0F0F;
}

.enterList ul li.ctg2 a {
	background-color: #006FA7;
}

.enterList ul li.ctg3 a {
	background-color: #F39400;
}

.enterList ul li.ctg4 a {
	background-color: #00953F;
}

.enterList ul li a {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #fff;
	font-size: 22px;
	font-weight: bold;
}

.enterList ul li a span {
	display: block;
	font-size: 16px;
	font-weight: bold;
}

.bannerList {
	margin-bottom: 40px;
	width: 100%;
}

.bannerList ul {
	width: 100%;
	display: flex;
	justify-content: center;
}

.bannerList ul li {
	width: 440px;
}

.bannerList ul li:first-child {
	margin-right: 20px;
}

.bannerList ul li a {
	display: block;
	width: 100%;
	height: 100%;
}

.bannerList ul li a img {
	display: block;
	max-width: 100%;
}

.shopList {
	padding-bottom: 50px;
	margin-bottom: 0;
	width: 100%;
}

.shopList ul {
	width: 100%;
	display: flex;
	justify-content: center;
}

.shopList ul li {
	padding: 10px;
	width: 285px;
	border: 1px solid #8b8b8b;
}

.shopList ul li:nth-child(n+2) {
	margin-left: 20px;
}

.shopList ul li .shopList__photo {
	margin-bottom: 10px;
}

.shopList ul li .shopList__photo img {
	display: block;
	max-width: 100%;
}

.shopList ul li .shopList__name {
	margin-bottom: 8px;
	font-size: 32px;
	font-weight: bold;
	line-height: 40px;
}

.shopList ul li .shopList__address {
	margin-bottom: 8px;
	font-size: 26px;
	font-weight: bold;
}

.shopList ul li .shopList__tel {
	font-size: 28px;
	font-weight: bold;
	line-height: 28px;
}

.shopList ul li .shopList__tel span {
	position: relative;
	padding-left: 26px;
}

.shopList ul li .shopList__tel span:before {
	margin: auto;
	content: "";
	position: absolute;
	width: 18px;
	height: 27px;
	background-image: url(../images/icon_tel@2x.png);
	background-size: contain;
	top: 1px;
	left: 0;
	bottom: 0;
}

.indexModal {
	position: fixed;
	padding: 40px;
	width: 100%;
	height: 100vh;
	background-color: rgba(0,0,0,0.6);
	top: 0;
	left:0;
	right: 0;
	bottom: 0;
	box-sizing: border-box;
}

.indexModal__box {
	padding: 65px 40px;
	margin: auto;
	position: absolute;
	width: calc(100% - 80px);
	min-width: 688px;
	max-width: 1100px;
	height: 700px;
	background-color: #fff;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	box-sizing: border-box;
}

.indexModal__box-inner {
	position: relative;
	margin: 0 auto;
	width: 604px;
}

.indexModal__box-inner h1 {
	margin-bottom: 40px;
	font-size: 12px;
	font-weight: normal;
	text-align: center;
}

.indexModal__box-inner .logo {
	margin: 0 auto 50px;
	width: 470px;
	height: 94px;
}

.indexModal__box-inner .logo h1 {
	width: 100%;
	height: 100%;
}

.indexModal__box-inner .logo h1 img {
	display: block;
	max-width: 100%;
}

.enter-btn {
	margin: 0 auto 50px;
	width: 320px;
	height: 70px;
}
.enter-btn a {
	display: block;
	width: 100%;
	height: 100%;
	background-color:#FC4FA6;
	color:#fff;
	font-size: 24px;
	line-height: 70px;
	text-align: center;
	cursor: pointer;
	font-weight: bold;
}

.enter-text {
	height: 260px;
	overflow:auto;
}

.enter-text p {
	height: 100%;
	font-size: 12px;
	line-height: 18px;
	overflow: auto;
}