#top {
	position: relative;
	width: 100%;
	min-height: 550px;
}
#top figure img {
	position: absolute;
	top: 0;
	left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#top .top_wrap {
	position: absolute;
	top: 55%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 96%;
	padding: 30px 10px 10px;
	max-width: 1200px;
	/* background: url('../img/top-background.png') no-repeat;
	background-size: cover; */
	border-radius: 10px;
}
#top .top_wrap .bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
#top .top_wrap .logo {
	position: absolute;
	top: -30px;
	left: 50%;
	width: 30%;
	max-width: 160px;
	transform: translate(-50%, -50%);
	z-index: 2;
}
#top .top_wrap .tag1 {
	position: absolute;
	/* top: 10px;
	left: 20px; */
	left: -3%;
	bottom: -2%;
	width: 14%;
	transform: rotate(-20deg);
	z-index: 0;
}
#top .top_wrap .tag2 {
	position: absolute;
	right: -1%;
	bottom: -8%;
	width: 16%;
	transform: rotate(-40deg);
	z-index: 2;
}
#top .top_wrap .pop1 {
	position: absolute;
	top: 0;
	left: -1%;
	width: 30%;
	max-width: 100%;
	transform: translateY(-50%) rotate(-20deg);
	z-index: 2;
}
#top .top_wrap .pop2 {
	position: absolute;
	top: -10%;
	right: 0%;
	width: 35%;
	max-width: 100%;
	transform: translateY(-50%);
	z-index: 2;
}
#top .top_wrap .chara {
	position: absolute;
	top: 0%;
	right: 7%;
	width: 13%;
	z-index: 2;
}
#top .cont {
	position: relative;
	padding: 0 2%;
}
#top .title {
	position: relative;
	padding: .5em 0 .25em;
	color: #D71718;
	font-size: 	calc(8px + 4.4vw);
	font-weight: bold;
	text-align: center;
	text-shadow: 2px 2px #ccc;
	z-index: 4;
}
#top .text {
	padding: 0 0 1em;
	color: #333;
	font-size: calc(12px + .8vw);
	font-weight: bold;
	text-align: center;
}
#top .img_wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	max-width: 1000px;
	margin: 0 auto;
}
#top .img_wrap li {
	width: 16%;
	padding: 5px;
	text-align: center;
}
#top .img_wrap li img {
	border-radius: 10px;
	box-shadow: 0 1px 2px rgba(100, 100, 100, .3), 0 4px 12px rgba(100, 100, 100, .3);
}
#top .img_wrap li p {
	display: inline-block;
	position: relative;
	top: -12px;
	border-radius: 20px;
	padding: 4px 8px;
	font-size: 10px;
	background-color: #fff;
}
#top .bann {
	position: absolute;
	left: 50%;
	bottom: 1%;
	transform: translateX(-50%);
	max-width: calc(100% - 20px);
}
#main .cont .main_title {
	margin: 3% 0;
	/* font-size: 40px; */
	font-size: calc(8px + 2.4vw);
	display: flex;
	justify-content: center;
	align-items: center;
}
#main .cont.feature .col3 {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 3% 0;
}
#main .cont.feature .col3 li {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 30%;
	padding: 4% 1%;
	border: 4px solid #D71718;
	border-radius: 10px;
	background-color: #fff;
	color: #D71718;
	/* font-size: calc(12px + .8vw); */
	/* font-size: 40px; */
	font-size: 	calc(8px + 1.6vw);
	font-weight: bold;
	text-align: center;
	line-height: 1.3333;
	box-shadow: 0 1px 2px rgba(100, 100, 100, .3), 0 4px 12px rgba(100, 100, 100, .3);
}
#main .cont.feature .col3 li + li::before,
#main .cont.feature .col3 li + li::after {
	content: '';
	position: absolute;
	top: 50%;
	left: -10%;
	transform: translate(-50%, -50%);
	display: block;
	width: 9%;
	height: 3%;
	background-color: #D71718;
}
#main .cont.feature .col3 li + li::after {
	transform: translate(-50%, -50%) rotate(90deg);
}
#main .cont.feature .col3 li span {
	display: block;
	text-align: center;
	/* font-size: 24px; */
	font-size: 	calc(8px + 1vw);
	font-weight: bold;
}
#main .cont.feature .main_text {
	margin: 2% 0;
	padding: 2% 3%;
	border-radius: 10px;
	border: 1px solid #333;
}
@media screen and (max-width: 660px) {
	#top .bann {
		width: 300px;
	}
	#top .top_wrap .logo {
		max-width: 100px;
		top: -10px;
	}
	#top .top_wrap .pop2 {
		top: -5%;
	}
	#top .top_wrap .chara {
		top: -2%;
		right: 1%;
		width: 20%;
	}
	#main .cont.feature .col3 li {
		margin: 0 auto 3%;
		padding: 12% 1%;
		width: 70%;
	}
	#main .cont.feature .col3 li + li::before,
	#main .cont.feature .col3 li + li::after {
		content: none;
	}
}
#main .cont.about {
	position: relative;
	background-color: #f5f5f5;
}
#main .cont.about .cont {
	margin: 2% 0;
	padding: 2% 3%;
	background-color: #fff;
	border-radius: 10px;
	box-shadow: 0 1px 2px rgba(100, 100, 100, .3), 0 4px 12px rgba(100, 100, 100, .3);
}
#main .cont.about .main_sub_title {
	display: flex;
	justify-content: center;
	margin: 2% 0;
	/* font-size: 32px; */
	font-size: 	calc(8px + 1.6vw);
	font-weight: bold;
}
#main .cont.about .main_text {
	margin: 2% 0;
}
#main .cont.about .about_item {
	position: relative;
}
#main .cont.about .about_item .icon {
	position: absolute;
	top: -4%;
	right: 0;
	display: block;
	width: 25%;
	min-width: 200px;
}
#footer .inner {
	padding-bottom: 80px;
}
#fix_footer {
	position: fixed;
	left: 0;
	bottom: 0;
	width: 100%;
	/* background-color: rgba(0,0,0,.3); */
}
#fix_footer p {
	position: relative;
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
	padding: 10px;
}
#fix_footer .close {
	position: absolute;
	top: -2%;
	right: -1%;
	display: block;
	width: 40px;
	height: 40px;
	background-color: #fff;
	border-radius: 50%;
	border: 1px solid #333;
}
#fix_footer .close::before,
#fix_footer .close::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 27%;
	transform: translate(-50%, -50%);
	display: block;
	width: 20px;
	height: 1px;
	background-color: #333;
	transform: rotate(45deg);
}
#fix_footer .close::after {
	transform: rotate(-45deg);
}
#fix_footer p a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 120px;
	border: 2px solid #fff;
	background-color: #D71718;
	color: #fff;
	font-size: calc(8px + 2.4vw);
	font-weight: bold;
	text-align: center;
	border-radius: 10px;
	transition:
		background-color .2s,
		color .2s
	;
}
#fix_footer p a.hover {
	background-color: #fff;
	color: #D71718;
}
@media screen and (min-width: 1200px) {
}
@media screen and (max-width: 660px) {
	#main .cont .main_title {
		font-size: 18px;
	}
	#main .cont.about .main_sub_title {
		margin-top: 4%;
		font-size: 16px;
	}
	#main .cont.about .about_item .icon {
		position: static;
		margin: 0 auto;
	}
	#top .img_wrap li {
		width: 33%;
	}
	#fix_footer .close {
		right: 2%;
		width: 24px;
		height: 24px;
	}
	#fix_footer .close::before,
	#fix_footer .close::after {
		width: 10px;
	}
	#fix_footer p a {
		height: 60px;
	}
}