/* ==================================================
	base
================================================== */

.main_content img {
	height: auto;
}

/* ----------------------------------------
	color
---------------------------------------- */
:root {
	--color100:#4759f5;
	--color90:#5969f6;
	--color80:#6c7af7;
	--color70:#7e8af8;
	--color60:#919bf9;
	--color50:#a3acfa;
	--color40:#b5bdfb;
	--color30:#c7cdfc;
	--color20:#dadefd;
	--color10:#eceefe;
}

.bg100 { background-color: var(--color100) !important; }
.bg70 { background-color: var(--color70) !important; }
.bg40 { background-color: var(--color40) !important; }
.bg20 { background-color: var(--color20) !important; }
.bg10 { background-color: var(--color10) !important; }


.bg_e6e6e6 { background-color: #e6e6e6 !important; }
.bg_f4f4F4 { background-color: #f4f4F4; }

.bol_color60_s {
    border-left: 1px solid var(--color60)
}

.fc_color100 {
	color: var(--color100)
}


/* ==================================================
	common
================================================== */

/* ----------------------------------------
	cont_wrap
---------------------------------------- */

@media screen and (min-width: 1024px) {
	.cont_wrap {
		padding-top: 60px;
	}
}

/* ----------------------------------------
	inner_wrap
---------------------------------------- */

.inner_wrap { padding: 40px 20px; }

@media screen and (min-width: 768px) {
	.inner_wrap { padding: 40px 30px; }
}

@media screen and (min-width: 1024px) {
	.inner_wrap { padding: 60px 30px; }
}

/* ----------------------------------------
	p
---------------------------------------- */

.main_content div + p,
.main_content ul + p,
.main_content ol + p,
.main_content img + p {
	margin-top: 1em;
}



/* ----------------------------------------
	a
---------------------------------------- */

.content a {
	color: #000;
	text-decoration: underline;
}
.content a:hover {
	text-decoration: none;
}



/* ----------------------------------------
	title
---------------------------------------- */

.title {
	padding: 25px 20px;
	border-bottom: 1px solid #000;
}

@media screen and (min-width: 768px) {
	.title {
		padding-right: 30px;
		padding-left: 30px;
	}
}


/* ==================================================
	local_navi
================================================== */

@media screen and (max-width: 1023px) {
	.local_navi_trigger {
		display: flex;
		align-items: center;
		min-height: 62px;
	}
	.local_navi_trigger::before {
		color: #000;
	}
	.local_navi_trigger h2 {
		padding: 10px 0;
		font-size: 20px;
		font-weight: normal;
		line-height: 1.2;
	}
	.local_navi_menu > h2 {
		display: none;
	}
	.local_navi_menu_level1 > li {
		background: #fff;
		border-color: #e8e8e8;
	}
	.local_navi_menu_level1 > li a {
		color: #000;
	}
	.local_navi_menu_level1 > li a br {
		display: none;
	}
	.local_navi_menu_level1 > li > a:not(:only-child) {
		border-color: #e8e8e8;
	}
	.local_navi_menu_level1 > li.local_navi_level2_open {
		background: #fff;
	}
	.local_navi_menu_level2 > li {
		background: rgba(243,243,243,1);
		border-top: none;
	}
	.local_navi_level2_trigger::after {
		color: #000;
	}
}

@media screen and (min-width: 1024px) {
	.local_navi {
		right: 50%;
		left: 50%;
		width: 100vw;
		margin-right: -50vw;
		margin-left: -50vw;
		padding: 0 20px;
		background: #fff;
	}
	.local_navi .local_navi_menu {
		display: flex !important;
		justify-content: space-between;
		align-items: center;
		max-width: 1220px;
		margin: 0 auto;
	}
	.local_navi_menu a {
		color: #000;
	}
	.local_navi_menu > h2,
	.local_navi_menu > h2 a {
		color: #000;
		font-size: 20px;
		font-weight: normal;
		line-height: 1;
		text-decoration: none;
		margin: 0;
	}
	.local_navi_menu > h2 a:hover {
		text-decoration: underline;
	}
	.local_navi_menu_level1 {
		display: flex;
		justify-content: space-between;
	}
	.local_navi_menu_level1 > li:nth-of-type(n+2) {
		margin-left: 30px;
	}
	.local_navi_menu_level1 > li.main_menu {
		height: 70px;
	}
	.local_navi_menu_level1 > li.main_menu > a {
		display: flex;
		justify-content: center;
		align-items: center;
		position: relative;
		width: 100%;
		height: 100%;
		color: #000;
		line-height: 1.4;
	}
	.local_navi_menu_level1 > li.current::after,
	.local_navi_menu_level1 > li.main_menu > a:hover::after {
		display: block;
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 4px;
		background: #165dba;
	}

	/* level2 -------------------- */
	.local_navi_menu_level2_area {
		top: 100%;
		left: -20px;
	}
	.local_navi_menu_level2 {
		min-width: 300px;
		background: #fff;
		border: 1px solid #e8e8e8;
		box-shadow: 0 12px 12px 0 rgb(0 0 0 / 20%);
	}
	.local_navi_menu_level2 li a {
		display: block;
		padding: 10px 20px;
		text-align: left;
		transition: .2s;
		white-space: nowrap;
	}
	.local_navi_menu_level2 li a:hover {
		color: #165dba;
		text-decoration: none;
		background: #e6fcff; /*rgba(44,48,56,.05)*/
	}
}




/* ==================================================
	main
================================================== */

.main {
	background: linear-gradient(171deg, rgba(255, 255, 255, 1) 30%, rgba(71, 89, 245, 0.15) 80%);
	height: auto;
	padding-bottom: 3rem;
	position: relative;
}
.main .img_area img {
	object-fit: contain;
    width: 100%;
    height: 100%;
    object-position: right bottom;
}
.main .text_area {
	max-width: 1220px;
	margin-right: auto;
	margin-left: auto;
}
.main h1 {
	margin-bottom: 15px;
	font-size: 7.5rem;
	font-weight: normal;
	line-height: 1.2;
}
@media screen and (max-width: 767px) {
	/* .main {
		height: 350px;
    } */
	.main .img_area {
		height: 300px;
	}
	.main .img_area img {
		object-position: center bottom;
	}
	.main .card {
		width: 100%;
		padding: 2rem 3rem 0;
	}
	.main h1 {
		font-size: 3.5rem;
	}
}
@media screen and (min-width: 768px) {
	/* .main {
		height: 350px;
	} */
	.main .img_area {
		height: 330px;
	}
	.main .inner {
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
		width: 100%;
		padding: 0 20px;
	}
	.main .card {
		width: 450px;
		padding: 20px;
	}
	.main h1 {
		font-size: 4.5rem;
	}
}
@media screen and (min-width: 1024px) {
	.main .img_area {
		height: 450px;
	}
	.main .card {
		width: 610px;
		padding: 30px;
	}
	.main h1 {
		font-size: 7rem;
	}
}
@media screen and (min-width: 1220px) {
	.main .card {
		margin-left: 100px;
	}
}



/* ==================================================
	inquiry_service
================================================== */

#inquiry_service {
	margin-top: 0;
}



/* ==================================================
	cons_list
================================================== */

.cons_list {
	margin: 0 -10px;
}
.cons_list > li h4 {
	color:  var(--color100);
}
.cons_list > li {
	margin-top: 20px;
	padding: 0 10px;
}
.cons_list .inner {
	height: 100%;
	/* border: 1px solid var(--color100); */
	border-radius: 10px;
}
.cons_list .title_area {
	background-color: #fff;
    border-radius: 10px 10px 0px 0px;
	padding: 20px;
}
.cons_list .title_area h3 {
	margin-top: 10px;
}
/* .cons_list .img_area {
	border-top: 1px solid var(--color100);
} */
.cons_list .text_area {
	padding: 20px;
}
.cons_list .text_area * + .list_basic {
	margin-top: 20px;
}

@media screen and (min-width: 768px) {
	.cons_list {
		display: flex;
		flex-wrap: wrap;
	}
	.cons_list > li {
		width: 50%;
	}
}

@media screen and (min-width: 1024px) {
	.cons_list  > li {
		width: 33.33333%;
	}
	.cons_list._2  > li {
		width: 50%;
	}
}

#visid .button.primary, .img_area a.button.primary {
    background: #f6f6ff;
	border-radius: 0 0 10px 10px;
}
#visid .button.primary:hover, .img_area a.button.primary:hover {
    background: #eceefe;
	border-radius: 0 0 10px 10px;
}




/* ==================================================
	check
================================================== */

ul.check li {
	position: relative;
	padding-left: 40px;
	margin-top: 30px;
}
ul.check li:first-of-type {
	margin-top: 0;
}
ul.check li p {
	margin-top: 0;
}
ul.check li h4::after {
	content: "";
	display: block;
	position: absolute;
	top: 5px;
	left: 0;
	width: 25px;
	height: 15px;
	border-left: 5px solid var(--color100);
	border-bottom: 5px solid var(--color100);
	transform: rotate(-45deg);
}
ul.check li h4:nth-child(n+2) {
	margin-top: .5em;
}