@charset "UTF-8";

li{
	list-style: none;
}
/* CSS Document */
.pc{
	display: inherit;
}
.sp{
	display: none;
}
.none{
	display: none;
}
@media screen and (max-width: 767px) {
	.pc{
		display: none;
	}
	.sp{
		display: inherit;
	}
	.img100{
		width: 100%;
	}
}

.house_main{
	background: url("../img/house/main_bg.png") no-repeat #fff;
	background-size: cover;
	background-position: bottom;
	padding: 150px 0 0;
}
.house_main_sp{
	background: url("../img/house/main_bg.png") no-repeat #fff;
	background-size: cover;
	background-position: bottom;
	padding: 80px 0 0;
}
@media screen and (max-width: 767px) {
	.house_main_sp img{
		width: 100%;
	}
}

.house_main h1{
	text-align: center;
	font-size: 32px;
	color: #fff;
	margin-top: 40px;
}
.house_main h1 img{
	margin-bottom: 20px;
}
.house_main_text{
	color: #fff;
	font-size: 14px;
	line-height: 200%;
	width: 614px;
	border-top: 1px solid #fff;
	padding-top: 20px;
	margin-top: 20px;
}
.house_flex{
	display: flex;
	justify-content: center;
}
.house_flex_right{
	margin-top: -60px;
	margin-left: 60px;
}

.house_main_sp h1{
	color: #fff;
	font-size: 22px;
	text-align: center;
}
.house_main_sp h1 img{
	width: 70%;
}
.house_main_sp div{
	text-align: center;
}
.house_main_sp div img{
	width: 70%;
	max-width: 280px;
}
.house_main_sp div+h1{
	margin-top: -20px;
	padding-bottom: 50px;
}
.house_main_sp p{
	color: #fff;
	font-size: 13px;
	padding: 30px;
	line-height: 180%;
}


/* about */

.about{
	background: #273e97;
	padding: 70px 0 70px;
	color: #fff;
}
.about .content_wrap{
	width: 1000px;
}
@media screen and (max-width: 767px) {
	.about .content_wrap{
		width: 90%;
	}
}
.about h2 img{
	vertical-align: baseline;
	margin-right: 20px;
}
.about h2{
	font-size: 24px;
	font-weight: 700;
	color: #fff;
}
@media screen and (max-width: 767px) {
	.about h2 img{
		vertical-align: baseline;
		margin: 0 auto 15px;
		display: block;
		width: 98px;
	}
	.about h2{
		font-size: 18px;
	}
}
.about h3{
	font-size: 20px;
	margin-top: 40px;
}
.about_box{
	background-color: #fff;
	border-radius: 20px;
	padding: 20px;
	margin-top: 40px;
}
.about_box h4{
	background-color: #273e97;
	padding: 10px;
	border-radius: 30px;
	font-size: 23px;
	width: 492px;
	box-sizing: border-box;
	margin: 0 auto 20px;
}
.about_flex{
	display: flex;
	justify-content: center;
	width: 840px;
	margin: 0 auto;
}
.about_flex_left{
	width: 100px;
	margin-right: 30px;
}
.about_flex_left img{
	width: 100%;
}
.about_flex_right{
	display: flex;
	flex-wrap: wrap;
	width: 660px;
	justify-content: space-between;
}
.about_flex_right--column{
	flex-direction: column;
	height: 150px;
}
@media screen and (max-width: 767px) {
	.about h3{
		text-align: left;
	}
	.about_box h4{
		width: 100%;
		font-size: 14px;
	}
	.about_flex{
		width: 100%;
	}
}

.about_item{
	display: flex;
	color: #333;
	width: 320px;
	padding: 10px 0;
}
.about_item--mg3{
	margin-top:40px;
}
@media screen and (max-width: 767px) {
	.about_flex_right--column{
		flex-direction: row;
		height: inherit;
	}
	.about_item--mg3{
		margin-top: 0;
	}
}
.about_item_text{
	color: #333;
	font-size: 16px;
	font-weight: 700;
	text-align: left;
	display: flex;
	align-items: center;
}
.about_item_img{
	width: 100px;
	justify-content: center;
	display: flex;
	align-items: center;
}
.about_item_text strong{
	color: #273e97;
}
.about_flex+.about_flex{
	border-top:1px solid #333;
	padding-top: 25px;
	margin-top: 25px;
}
.about_text{
	font-size: 20px;
	color: #333;
}
.about_img{
	width: 800px;
	margin: 40px auto 0;
	padding-bottom: 20px;
}
.about_img img{
	width: 100%;
}
@media screen and (max-width: 767px) {
	.about_item{
		width: 100%;
	}
	.about_img{
		width: 100%;
	}
	.about_img img{
		width: 100%;
	}
	.about_flex_left{
		width: 22%;
		border-right: 1px solid #333;
		padding-right: 3%;
		margin-right: 5%;
		display: flex;
		align-items: center;
	}
	.about_flex_right{
		width: 70%;
	}
	.about_item_img{
		width: 20%;
	}
	.about_item_img img{
		width: 100%;
	}
	.about_item_text{
		display: block;
		width: 70%;
		margin-left: 10%;
		font-size: 13px;
	}
	img.about_item_img_1{
		width: 80%;
		margin-top: -5px;
	}
	.about_flex+.about_flex{
		border-top: none;
		padding-top: 5px;
	}
	.about_text{
		font-size: 15px;
		text-align: left;
		font-weight: 700;
	}
}

/* ソリューション */

.solution{
	background: url("../img/house/solution_bg.jpg") no-repeat;
	padding: 70px 0 70px;
	color: #fff;
	background-attachment: fixed;
	background-size: cover;
}
.solution .content_wrap{
	width: 888px;
}
@media screen and (max-width: 767px) {
	.solution .content_wrap{
		width: 90%;
	}
}
.solution h2 img{
	vertical-align: baseline;
	margin-right: 20px;
}
.solution h2{
	font-size: 24px;
	font-weight: 700;
	color: #fff;
}
@media screen and (max-width: 767px) {
	.solution h2 img{
		vertical-align: baseline;
		margin: 0 auto 15px;
		display: block;
		width: 98px;
	}
	.solution h2{
		font-size: 18px;
	}
}
.solution h3{
	font-size: 20px;
	margin-top: 40px;
	margin-bottom: 50px;
}
.solution_flex{
	display: flex;
	justify-content: space-between;
}
.solution_box{
	background-color: #fff;
	box-sizing: border-box;
	border-radius: 20px;
	margin-bottom: 60px;
}
.solution_box p{
	color: #000;
	font-size: 15px;
	margin: 10px 0;
}
.solution_flex .solution_box{
	width: 280px;
	padding: 20px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
}
.solution_flex .solution_box div a{
	background-color: #09206e;
	padding: 10px;
	border-radius: 10px;
	color: #fff;
	font-size: 18px;
	font-weight: 600;
	display: block;
}

.solution_box h4{
	font-size: 24px;
	font-weight: 700;
	line-height: 100%;
	margin-bottom: 20px;
	color: #333;
}
.solution_box h4 span{
	font-size: 14px;
	font-weight: 400;
	display: inline-block;
	background: #333;
	color: #fff;
	padding: 5px 30px 7px;
	border-radius: 20px;
	line-height: 100%;
	vertical-align: middle;
	margin-top: -4px;
	margin-right: 0px;
}
.solution_box h4 span.mb{
	margin-bottom: 20px;
}

.solution_box--large{
	padding: 40px;
}
.solution_box--large img{
	width: 100%;
}
.solution_box--large h4 span{
	margin-right: 20px;
}
.solution_box--large p{
	font-weight: 700;
	padding-bottom: 20px;
	font-size: 18px;
	margin: 0;
}
.solution_box--large div p{
	font-weight: 400;
	padding-top: 20px;
	padding-bottom: 20px;
	font-size: 12px;
}

@media screen and (max-width: 767px) {
	.solution_box--large h4 span{
		display: block;
		width: 80px;
		margin: 0 auto 25px;
		padding: 7px;
		font-size: 14px;
	}
	.scroll{
		overflow:scroll;
		white-space: nowrap;
	}
	.solution_box--large .scroll img{
		width: 808px;
	}
}
.solution_2_flex{
	display: flex;
}
.solution_2_th{
	width: 100px;
	color: #fff;
	background-color: #09206e;
	font-size: 16px;
	margin-left: 30px;
	margin-right: 10px;
	border-radius: 3px;
	margin-top: 10px;
}
.solution_2_td{
	color: #000;
	font-size: 16px;
	margin-top: 10px;
}

/**/
.content_wrap{
	width: 1080px;
	margin: 0 auto;
	text-align: center;
}
@media screen and (max-width: 767px) {
	.content_wrap{
		width: 100%;
	}
	.solution_2_th{
		width: 25%;
		margin-left: 0;
		padding: 0;
		font-size: 14px;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.solution_2_td{
		font-size: 14px;
		text-align: left;
		width: 70%;
	}
	.solution_box--large p{
		font-size: 15px;
	}
	.solution_box--large div p{
		text-align: left;
	}
}


/* adv */
.adv_top_hr img{
	width: 100%;
	margin-top: -1px;
}
.adv{
	background: #273e97;
	padding: 0 0 75px;
}
.adv h2{
	color: #fff;
	font-size: 24px;
	font-weight: 700;
	padding: 70px 0 20px;
}
.adv h2 img{
	vertical-align: baseline;
	margin-right: 20px;
}

.adv_content{
	width: 680px;
	margin: 0 auto;
	padding: 20px 0 40px;
}
@media screen and (max-width: 767px) {
	.adv{
		padding-bottom: 45px;
	}
	.adv_content{
		width: 90%;
	}
	.adv_content--margin0{
		padding-bottom:10px;
	}
}
.adv_icon_flex{
	justify-content: space-between;
}
.adv_icon_flex>div{
	background-color: #fff;
	width: 216px;
	box-sizing: border-box;
	padding: 15px 10px;
	border-radius: 10px;
}
.adv_icon_flex--4column>div{
	width: 158px;
}
.adv_icon_flex>div.box{
	background-color: inherit;
	width: 216px;
	height: 10px;
}
.adv_icon_flex h4{
	color: #09206e;
	font-size: 18px;
	margin: 10px 0;
}
.adv_icon_flex h4.group1{
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 15px 0 0;
}
.adv_icon_flex h4.group2{
	height: 52px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.adv_icon_flex p{
	font-size: 14px !important;
	text-align: left;
	padding: 0 5px;
}
@media screen and (max-width: 767px) {
	.adv_icon_flex>div{
		width: 100%;
		padding: 30px 30px;
		margin-bottom: 20px;
	}
	.adv_icon_flex h4{
		font-size: 16px;
	}
	.adv_icon_flex h4.group1{
		height: inherit;
	}
	.adv_icon_flex h4.group2{
		height: inherit;
	}
}

.adv_content h3{
	color: #fff;
	background-color: #09206e;
	font-size: 20px;
	box-sizing: border-box;
	width: 392px;
	border-radius: 20px;
	text-align: center;
	padding: 5px 0;
	margin: 20px 0;
}
.adv_hr{
	height: 1px;
	background-color: #231815;
	margin-top: 20px;
}
@media screen and (max-width: 767px) {
	.adv h2{
		font-size: 18px;
	}
	.adv h2 img{
		width: 265px;
		display: block;
		margin: 0 auto 15px;
	}
	.adv_content h3{
		width: 100%;
		box-sizing: border-box;
		font-size: 15px;
	}
	.sp_adv_content_img img{
		width: 100%;
		margin-top: 20px;
	}
	.adv_hr{
		background-color: #ccc;
		margin-top: 0px;
	}
}

.adv_content--1 h4{
	font-size: 24px;
	text-align: left;
}
.adv_content--1 h4 strong{
	color: #09206e;
}
.adv_content_flex{
	display: flex;
	margin: 20px 0;
}
.adv_content_flex_left{
	background-color: #fff;
	border:1px solid #333;
	border-radius: 10px;
	padding: 10px;
	font-size: 16px;
	display: flex;
	align-items: center;
	margin-right: 20px;
	width: 6.2em;
	box-sizing: border-box;
	text-align: center;
	justify-content: center;
}
.adv_layout_flex{
	display: flex;
	justify-content: space-between;
}
@media screen and (max-width: 767px) {
	.adv_content--1 h4{
		font-size: 18px;
		text-align: center;
	}
	.adv_layout_flex{
		flex-wrap: wrap;
	}
	.adv_content_flex{
		flex-wrap: wrap;
		
	}
	.adv_content_flex_left{
		width: 100%;
		margin: 0 0 20px;
		font-size: 12px;
		padding: 5px 0;
		background-color: inherit;
	}
}
.adv_layout_flex_2 img{
	margin-top: 20px;
}
.adv_content_flex_right h5{
	font-size: 16px;
	margin: 0 0 2px;
	text-align: left;
}
.adv_content_flex_right p{
	font-size: 13px;
	line-height: 150%;
	text-align: left;
}
.adv_content_flex_right p+h5{
	margin-top: 20px;
}
@media screen and (max-width: 767px) {
	.adv_content_flex_right h5{
		font-size: 14px;
	}
	.adv_content_flex_right p{
		padding-left: 20px;
	}
}
.adv_text{
	font-size: 18px;
	font-weight: 700;
}
.adv_arrow{
	margin: 20px 0 -5px;
}
.adv_arrow2{
	margin: 25px 0 20px;
}
.adv_content2_flex{
	display: flex;
	justify-content: space-between;
	width: 680px;
}
.adv_content2_flex>div{
	display: flex;
	align-items: center;
}
.adv_content_flex2{
	display: flex;
	width: 680px;
	justify-content: space-between;
	align-items: center;
	margin-top: 20px;
}
@media screen and (max-width: 767px) {
	.adv_text{
		font-size: 16px;
	}
	.adv_content_flex2{
		width: 100%;
		flex-wrap: wrap;
		justify-content: center;
	}
	.adv_arrow{
		margin-bottom: 20px;
	}
}

.adv_item{
	background-color: #f4f5fa;
	border-radius: 10px;
}
.adv_title{
	font-size: 20px;
	color: #273e97;
	background: url("../img/house/adv_icon_pos.png") no-repeat center left 40px #fff;
	background-size: 48px 45px;
	padding: 20px 0 20px 110px;
	text-align: left;
	border-radius: 10px;
}
.adv_title--2{
	background-image: url("../img/house/adv_li_2.png");
	background-size: 52px 45px;
}
.adv_title--3{
	background-image: url("../img/house/adv_icon_user.png");
	background-size: 48px 47px;
}
@media screen and (max-width: 767px) {
	.adv_title{
		font-size: 18px;
		background-position: center left 20px;
		padding-left: 80px;
		background-size: 48px 45px;
	}
	.adv_title--2{
	}
	.adv_title--3{
		background-size: 48px 47px;
	}
	.adv_content2_flex{
		flex-wrap:wrap;
		width: 100%;
	}
	.adv_content2_flex img{
		width: 100%;
		margin-top: 20px;
	}
}

.adv_icon_flex{
	display: flex;
}
@media screen and (max-width: 767px) {
	.adv_icon_flex{
		flex-wrap: wrap;
	}
}




/* アコーディオン */
.accordion {
margin: 3em auto;
/* max-width: 54vw; */
	max-width: 800px;
}
@media screen and (max-width: 767px) {
	.accordion {
		margin: 3em auto;
		max-width:inherit;
		padding-left: 5%;
		padding-right: 5%;
	}
}
.accordion .toggle {
display: none;
}
.accordion .option {
position: relative;
margin-bottom: 1em;
}
.accordion .title,
.accordion .content {
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
transform: translateZ(0);
transition: all 0.3s;
}
.accordion .title {
display: block;
font-weight: bold;
}
.accordion .title::after,
.accordion .title::before {
content: "";
position: absolute;
right: 1.25em;
top: 1.25em;
width: 3px;
height: 1em;
background-color: #273e97;
transition: all 0.3s;
}
.accordion .title::after {
transform: rotate(90deg);
}
.accordion .content {
max-height: 0;
overflow: hidden;
box-sizing: border-box;
}
.accordion .content p {
margin: 0;
/* padding: 0.5em 1em 1em;
font-size: 0.9em; */
line-height: 1.5;
}
.accordion .toggle:checked + .title + .content {
max-height: 2400px;
transition: all 0.5s;
}
.accordion .toggle:checked + .title::before {
transform: rotate(90deg) !important;
}

/* support */
.support{
	background-color: #e9ecf5;
	padding: 70px 0;
	color: #273e97;
}
.support .content_wrap{
	width: 912px;
}
.support h2{
	color: #273e97;
	font-size: 24px;
	font-weight: 700;
	padding: 0px 0 20px;
}
.support h2 img{
	vertical-align: baseline;
	margin-right: 20px;
}
.support_text{
	font-size: 20px;
	font-weight: 700;
}
@media screen and (max-width: 767px) {
	.support .content_wrap{
		width: 90%;
	}
	.support h2{
		font-size: 18px;
	}
	.support h2 img{
		width: 135px;
		display: block;
		margin: 0 auto 15px;
	}
	.support_text{
		font-size: 19px;
	}
}
.support_flex{
	display: flex;
	background: #fff;
	border-radius: 20px;
	padding: 20px;
	box-sizing: border-box;
	margin: 30px auto;
	flex-wrap: wrap;
	justify-content: space-between;
}
.support_th{
	background: #273e97;
	color: #fff;
	font-size: 20px;
	width: 15%;
	border-radius: 10px;
	align-items: center;
	display: flex;
	justify-content: center;
}
.support_td{
	width: 40%;
	box-sizing: border-box;
	border-radius: 7px;
	padding: 15px;
	border:1px solid #5d6eb1;
	text-align: left;
}
.support_td--large{
	width: 82.5%;
}
.support_td--large img{
	width: 100%;
}
.support_hr{
	height: 20px;
	width: 100%;
}
.support_td_title{
	background: #5d6eb1;
	color: #fff;
	border-radius: 7px;
	padding: 7px;
	font-size: 18px;
	line-height: 100%;
	text-align: center;
}
.support_td_text{
	font-size: 14px;
	padding: 15px;
}
.support_td_text h4{
	font-size: 18px;
}
.support_td_text p{
	color: #000;
	margin-top: 5px;
}
.support_th--last{
	background-color: #5d6eb1;
}
@media screen and (max-width: 767px) {
	.support_flex{
		flex-wrap: wrap;
	}
	.support_th{
		width: 100%;
		font-size: 15px;
		padding: 5px 0;
	}
	.support_td{
		width: 100%;
		padding: 10px;
		margin-top: 15px;
	}
	.support_td_title{
		font-size: 14px;
	}
	.support_td_text h4{
		font-size: 14px;
	}
	.support_td--large{
		border: none;
	}
	.support_th--last{
		margin-top:20px;
	}
}




/* flow */
.flow{
	background-color: #273e97;
	padding: 70px 0;
	color: #fff;
}
.flow .content_wrap{
	width: 912px;
}
.flow h2{
	color: #fff;
	font-size: 24px;
	font-weight: 700;
	padding: 0px 0 20px;
}
.flow h2 img{
	vertical-align: baseline;
	margin-right: 20px;
}

@media screen and (max-width: 767px) {
	.flow .content_wrap{
		width: 90%;
	}
	.flow h2{
		font-size: 18px;
	}
	.flow h2 img{
		width: 71px;
		display: block;
		margin: 0 auto 15px;
	}
}

.flow_flex{
	display: flex;
	justify-content: center;
	padding:10px 0 30px;
}
.flow_flex_left{
	font-size: 28px;
	margin-right: 40px;
	font-weight: 700;
}
.flow_flex_right{
	font-size: 16px;
	text-align: left;
}
.flow_flex_right li:before{
	content:"・　";
}
@media screen and (max-width: 767px) {
	.flow_flex{
		flex-wrap: wrap;
	}
	.flow_flex_right{
		width: 90%;
		margin: 0 auto 20px;
	}
	.flow_flex_right li:before{
		display: inline-block;
		margin-left: -1.5em;
	}
	.flow_flex_right li{
		margin-left: 1em;
	}
	.flow_flex_left{
		margin: 0 auto 20px;
	}
	.sp_flow_img img{
		width: 100%;
	}
}
