body {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	background-color: #e8e9f2;
	font-family: "游ゴシック Medium", "Yu Gothic Medium", sans-serif;
}

header {
	height: 10.7vw;
	width: 100%;
	background-color: rgba(255, 255, 255, 0.8);
	display: flex;
	flex-wrap: wrap;
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	z-index: 5;
}

table {
	margin-left: auto;
	margin-right: auto;
}

h1 {
	font-size: 2.2vw;
	letter-spacing: 0.42vw;
}

h2 {
	font-size: 1.7vw;
	letter-spacing: 0.42vw;
}

p {
	font-size: 0.85vw;
}

h3 {
	font-size: 1.19vw;
}

h5 {
	font-size: 13.8vw;
	color: #EFF3FF;
}

h6 {
	font-size: 2.04vw;
	letter-spacing: 0.42vw;
	color: #FFFFFF;
}

h7 {
	font-size: 1.5vw;
	letter-spacing: 0.25vw;
	line-height: 1.7vw;
	color: #111111;
}

h1,
h2,
h3,
p {
	width: 100%;
}

h1,
h2 {
	color: #0040FF;
	width: 100%;
}

em {
	font-size: 4.23vw;
	font-weight: bold;
}

a {
	text-decoration: none;
}

small {
	font-size: 2.3vw;
}

.yazirusi {
	display: flex;
	justify-content: center;
}

.yazirusi::after {
	content: '';
	width: 19.5vw;
	height: 1vw;
	border-bottom: solid 2px #0040FF;
	border-right: solid 2px #0040FF;
	transform: skew(45deg);
	z-index: 1;
}

.yazirusiro {
	display: flex;
	height: 4.26vw;
	margin: 3.2vw 0 6.9vw 0;
	justify-content: center;
}

.yazirusiro::after {
	content: '';
	width: 6.45vw;
	height: 0.8vw;
	border-bottom: solid 2px #0040FF;
	border-right: solid 2px #0040FF;
	transform: rotate(90deg) skew(40deg);
	z-index: 1;
}

.sp {
	display: none;
}

.pc {
	display: inline;
}

.border_hr {
	display: flex;
	flex-wrap: nowrap;
	width: 90vw;
}

.hr1 {
	border-top: 3px solid #444444;
	width: 5vw;
}

.hr2 {
	border-top: 3px solid #0040FF;
	width: 20vw;
}

.hr3 {
	border-top: 3px solid #999999;
	width: 65vw;
}

header #header_top {
	width: 100%;
	height: 5.9vw;
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
}

header #header_top h4{
	font-size: 1.5vw;
}

header #header_top img {
	height: 3.3vw;
	margin-left: 1.7vw;
}

header #header_top .container {
	background-color: #0040FF;
	color: #FFFFFF;
	height: 5.9vw;
	width: 14.9vw;
	justify-content: center;
	align-items: center;
	position: absolute;
}

header #header_top .container a {
	height: 5.9vw;
	width: 14.9vw;
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	position: absolute;
	color: white;
}

header #header_top .container:nth-child(2) {
	right: 0;
}

header #header_top .container:nth-child(3) {
	right: 14.9vw;
	margin-right: 0.1vw;
}

header #header_top .container:nth-child(4) {
	right: 29.9vw;
	margin-right: 0.1vw;
}

header #header_top .container img {
	height: 2.13vw;
	margin: 0.55vw 0.55vw 0 0;
	transform: rotate(20deg);
}

header #header_bottom {
	width: 100%;
	height: 4vw;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

header #header_bottom ul {
	width: 75vw;
	margin-right: 1vw;
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-around;
}

header #header_bottom ul li button {
	color: #0040FF;
	font-size: 1.28vw;
	font-family: "游ゴシック Medium", "Yu Gothic Medium", sans-serif;
}

#scroll-to-top-btn {
	position: fixed;
	bottom: 0;
	right: 0;
	height: 70px;
	width: 70px;
	color: #FFF;
	font-size: 16px;
	line-height: 20px;
	background-color: #0040FF;
	border-radius: 10px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}

#scroll-to-top-btn img {
	height: 15px;
	width: 26px;
	margin-left: 30%;
	margin-right: 30%;
	object-fit: contain;
}

main {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

main section {
	width: 100vw;
	margin: 1.1vw 0;
	padding-top: 17.3vw;
	display: flex;
	flex-wrap: wrap;
	text-align: center;
	justify-content: center;
}

main section h2 {
	font-weight:900;
	margin-bottom: 0.55vw;
}

main section h1 {
	font-weight:900;
	margin-bottom: 1.1vw;
}

main #MV {
	position: relative;
	display: flex;
	justify-content: flex-end;
	align-items: end;
	flex-wrap: nowrap;
}

main #MV img {
	width: 99.1vw;
	object-fit: contain;
	object-position: 0 -20vw;
}

main #MV .top_text_pc {
	position: absolute;
	top: 2%;
	left: 2%;
}

main #MV h3 {
	font-size: 3vw;
	letter-spacing: 0.3em;
	line-height: 2;
	font-weight: bold;
	color: #FFF;
	font-family: "Hiragino Sans", sans-serif;
	text-shadow:
	1px 1px 1px #000,
	-1px -1px 1px #000,
	-1px 1px 1px #000,
	1px -1px 1px #000,
	0 0 5px #000,
	0 0 10px #000;
	/*　ベンダープレフィックスのない指定方法 */
}

/* main #MV .top_text_pc1 {
	text-shadow: 2px 2px 0px rgb(0, 0, 0), 4px 4px 0px rgb(8, 0, 161), 0px 0px 3px rgba(0, 0, 0, 0.4);
}

main #MV .top_text_pc2 {
	text-shadow: 2px 2px 0px rgb(0, 0, 0), 4px 4px 0px rgb(8, 0, 161), 0px 0px 3px rgba(0, 0, 0, 0.4);
} */

main #POINTS {
	width: 100vw;
	text-align: center;
}

main #POINTS .left_pos_textspace h1 {
	font-size: 2.55vw;
	margin-bottom: 26px;
	font-weight: 900;
}

main #POINTS .left_pos_textspace .left_pos_text h2 {
	text-align: center;
	width: auto;
}

main #POINTS .left_pos_textspace h3 {
	font-size: 1.5vw;
	letter-spacing: 0.42vw;
	line-height: 3.2vw;
}

main #POINTS .left_pos_textspace .left_pos_text {
	display: flex;
	flex-wrap: nowrap;
	margin-bottom: 0.55vw;
}

/* point */
main #POINTS .point-coler {
	color: #0040FF;
	font-weight: 900;
	font-size: 2vw;
}

main #POINTS .point-contents {
	padding: 10% 0 0 0;
}

main #POINTS .point-contents-box {
	padding: 5%;
}

main #POINTS .point-contents-text {
	font-size: 1.5vw;
	letter-spacing: 0.42vw;
	line-height: 5vw;
}

main #POINTS .point-contents-coler {
	color: #0040FF;
	font-size: 2.5vw;
	padding-bottom: 3%;
	font-weight: 900;
}

main #POINTS .point-contents-bold {
	color: #0040FF;
	letter-spacing: 0.42vw;
	font-weight: 900;
	font-size: 2vw;
	line-height: 3vw;
}

/*  */

main #TOUGHT img {
	width: 28.2vw;
	height: 20vw;
}

main #TOUGHT p {
	font-size: 1.5vw;
	letter-spacing: 0.42vw;
	line-height: 4rem;
	margin-bottom: 4.2vw;
}

main #TOUGHT h3 {
	font-size: 2.55vw;
	margin-bottom: 4vw;
	font-weight: 900;
	color: #0040FF;
}

main #TOUGHT .container{
	width: 80%;
}

main #SERVICE .base {
	width: 84vw;
	height: 37vw;
	margin-bottom: 9vw;
	position: relative;
}

main #SERVICE .base2 {
	height: 38vw;
}

main #SERVICE .base4 {
	height: 38vw;
}

main #SERVICE .base .bg1 {
	width: 82vw;
	height: 25vw;
	position: absolute;
}

main #SERVICE .base .bg1_1 {
	background-color: #b1c5ff;
	bottom: 0;
}

main #SERVICE .base .bg1_2 {
	height: 26vw;
	background-color: #878d9f;
	right: 0;
	bottom: 0;
}

main #SERVICE .base .bg1_3 {
	background-color: #929cbb;
	bottom: 0;
}

main #SERVICE .base .bg1_4 {
	height: 26vw;
	background-color: #5e6884;
	bottom: 0;
	right: 0;
}

main #SERVICE .base .bg1_5 {
	background-color: #b2b6c2;
	bottom: 0;
}

main #SERVICE .base .bgimg {
	width: 40vw;
	height: 31.2vw;
	position: absolute;
	object-fit: cover;
}

main #SERVICE .base .bgimg1 {
	right: 0;
}

main #SERVICE .base .bgimg2 {
	width: 40vw;
	height: 32vw;
	left: 0;
}

main #SERVICE .base .bgimg3 {
	width: 25vw;
	height: 15vw;
	top: 8%;
	left: 14%;
}

main #SERVICE .base .bgimg4 {
	width: 25vw;
	height: 17vw;
	left: 0;
	top: 45%;
}

main #SERVICE .base .bgimg5 {
	width: 45vw;
	height: 32vw;
	right: 0;
}

main #SERVICE .base .bgimg6 {
	width: 40vw;
	height: 32vw;
	right: 0;
}

main #SERVICE .base .bg2 {
	position: absolute;
	background-color: #0040FF;
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
}

main #SERVICE .base .bg2_1 {
	width: 45vw;
	height: 24vw;
	left: 6%;
	top: 12%;
}

main #SERVICE .base .bg2_2 {
	width: 45vw;
	height: 24vw;
	right: 6%;
	top: 12%;
}

main #SERVICE .base .bg2_3 {
	width: 45vw;
	height: 24vw;
	left: 6%;
	top: 12%;
}

main #SERVICE .base .bg2_4 {
	width: 45vw;
	height: 24vw;
	right: 6%;
	top: 12%;
}

main #SERVICE .base .bg2_5 {
	width: 45vw;
	height: 24vw;
	left: 6%;
	top: 4.5%;
}

main #SERVICE .base div p {
	font-size: 1.34vw;
	color: #FFFFFF;
	line-height: 3.05vw;
	letter-spacing: 0.25vw;
	margin-top: 1vw;
	text-align: left;
}

main #SERVICE .base div h6 {
	text-align: left;
	letter-spacing: 0.2vw;
	line-height: 2.1vw;
}

main #SERVICE .base div h6 small {
	font-size: 1.7vw;
}

main #SERVICE .base div h5 {
	padding-right: 0.5vw;
}

main #MODEL {
	width: 90vw;
	display: flex;
	justify-content: center;
}

main #MODEL h4 {
	width: 100vw;
	text-align: left;
	font-size: 2.55vw;
	margin: 1.05vw 0 6.39vw 0;
	vertical-align: middle;
}

main #MODEL .space {
	height: 26.6vw;
	width: 80%;
	margin-bottom: 20.9vw;
	position: relative;
}

/*
main #MODEL .space .car_bg{
	width: 50%;
	height: 37vw;
	padding-top: 50px;
	background-color: #C4BEA6;
	position: absolute;
	right: 0;
}
*/
main #MODEL .space .car_name {
	width: 100%;
	height: 15%;
	background-color: #FFFFFF;
	position: absolute;
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	z-index: 2;
}

main #MODEL .space .car_name h3 {
	width: auto;
	font-size: 2vw;
	letter-spacing: 0.2vw;
	margin-left: 2vw;
	margin-right: 0.5vw;
}

main #MODEL .space .car_name h6 {
	color: #666666;
	font-size: 1.4vw;
	letter-spacing: 0.2vw;
}

main #MODEL .space img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 15%;
	left: 0;
}

main #MODEL .space .detail {
	width: 100%;
	height: 25%;
	background-color: #FFFFFF;
	position: absolute;
	bottom: -10.5vw;
	display: flex;
	flex-wrap: wrap;
	text-align: center;
	align-items: center;
}

main #MODEL .space .detail hr {
	position: absolute;
	top: 60%;
}

main #MODEL .space .detail .hr4 {
	border-top: 3px solid #0040FF;
	width: 2vw;
	margin-left: 1vw;
	height: 0;
	right: 46%;
}

main #MODEL .space .detail .hr5 {
	border-top: 3px solid #111111;
	width: 3.5vw;
	margin-left: 1vw;
	height: 0;
	left: 52%;
}

main #MODEL .space .detail .special-margin1 {
	margin-right: 6vw;
}

main #MODEL .space .detail .special-margin2 {
	margin-right: 3.7vw;
}

main #MODEL .space .detail .special-margin3 {
	margin-right: 4.6vw;
}

main #MODEL .space .detail p {
	font-size: 2vw;
	width: auto;
	margin-left: 2vw;
}

main #MODEL .space .detail p em {
	font-size: 2vw;
	color: #0040FF;
	padding-right: 1vw;
}

main #MODEL .space .detail button {
	width: 3vw;
	height: 3vw;
	margin-left: 2vw;
}

main #MODEL .space .detail button img {
	width: 3vw;
	height: 3vw;
	position: initial;
}

main #MODEL .space .detail button .revarse {
	transform: rotate(180deg);
}

main #MODEL .space h5 {
	position: absolute;
	font-size: 4vw;
	color: #252525;
	top: 107%;
	left: 1.8%;
	-webkit-text-stroke: 1px #FFF;
	z-index: 3;
}

main #PRICE {
	background-color: #EFF3FF;
	width: 100%;
}

main #PRICE p {
	width: 66vw;
	display: flex;
	text-align: left;
	line-height: 2.17vw;
	margin-bottom: 13vw;
}

main #PRICE .yazirusiro {
	width: 100%;
}

/*******************************************************/
/*******************************************************/
/*******************************************************/
main #PRICE .scroll {
	width: 70.2vw;
	table-layout: fixed;
	border-collapse: collapse;
	font-size: 1.2vw;
	letter-spacing: 0.15vw;
	line-height: 1.7vw;
}

main #PRICE .use_morgue {
	width: 70.2vw;
	/*table-layout: fixed;*/
	border-collapse: collapse;
	font-size: 1.2vw;
	letter-spacing: 0.15vw;
	line-height: 1.7vw;
}

main #PRICE .scroll-wrap .scroll tbody tr th,
main #PRICE .scroll tbody tr td {
	border: 2px solid #EFF3FF;
	height: 1.5vw;
	padding: 0.5vw;
	vertical-align: middle;
}

main #PRICE .scroll-wrap .scroll tbody tr th {
	background-color: #0040FF;
	text-align: center;
	color: #FFFFFF;
}

main #PRICE .scroll-wrap .scroll tbody tr .white {
	background-color: #ebefff;
	color: #0040FF;
}

main #PRICE .scroll-wrap .scroll tbody tr td {
	background-color: #FFFFFF;
	text-align: center;
}

main #PRICE .scroll tbody tr .tbl_center {
	text-align: center;
	height: 4vw;
	font-size: 1vw;
	letter-spacing: 0.15vw;
}

main #PRICE .plan tbody tr th,
main #PRICE .plan tbody tr td {
	height: 4.5vw;
	text-align: center;
}

main #PRICE .use_morgue tbody tr th,
main #PRICE .use_morgue tbody tr td {
	border: 2px solid #EFF3FF;
	height: 4vw;
	padding: 1vw;
	text-align: center;
	vertical-align: middle;
}

main #PRICE .use_morgue tbody tr th {
	background-color: #0040FF;
	color: #FFFFFF;
}

main #PRICE .use_morgue tbody tr td {
	background-color: #FFFFFF;
	text-align: left;
}

main #PRICE .use_morgue tbody th {
	min-width: 15vw;
}

/*******************************************************/
/*******************************************************/
/*******************************************************/
main #PRICE h3 {
	font-size: 1.7vw;
	letter-spacing: 0.25vw;
	margin-bottom: 6.05vw;
}

main #PRICE .morgue {
	width: 60.5vw;
	margin-bottom: 13vw;
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
}

main #PRICE .morgue img {
	width: 29vw;
	margin-bottom: 1vw;
}

main #PRICE .use_storage-room tbody tr th,
main #PRICE .use_storage-room tbody tr td {
	width: 40vw;
	text-align: center;
	letter-spacing: 0.2vw;
	line-height: 1.2rem;
}

main #PROFILE {
	margin-bottom: 13.1vw;
}

main #PROFILE table {
	width: 60vw;
}

main #PROFILE table tr {
	border-top: 2px solid #E0DFDD;
	text-align: left;
}

main #PROFILE table tr:last-child {
	border-bottom: 2px solid #E0DFDD;
}

main #PROFILE table tr th,
main #PROFILE table tr td {
	padding: 1.23vw 1vw;
	font-size: 1.3vw;
	line-height: 2.2vw;
	letter-spacing: 0.05vw;
	vertical-align: middle;
}

main #PROFILE table tr th p {
	font-size: 1.3vw;
	line-height: 2.2vw;
	letter-spacing: 0.05vw;
	font-weight: bold;
	width: 12vw;
}

main #PROFILE table tr .special_center p {
	font-size: 1.2vw;
	line-height: 2.2vw;
	letter-spacing: 0.05vw;
	width: 39vw;
}

main #PROFILE table tr th {
	font-weight: bold;
	width: 12vw;
}

footer {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	background-color: #FFFFFF;
	text-align: center;
}

footer .footer_MV {
	width: 100%;
	height: 40vw;
	object-fit: cover;
	object-position: 0 100%;
	margin-bottom: 6.1vw;
}

footer .footer_logo {
	width: 40vw;
	object-fit: cover;
	margin-bottom: 1.1vw;
}

footer address {
	width: 100%;
	font-size: 1.19vw;
	margin-bottom: 3.75vw;
}

#footer_view {
	display: none;
}

html {
	scroll-behavior: smooth;
}

:target {
	scroll-margin-top: 12vw;
}