@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;700&display=swap');
bbr,address,article,aside,audio,b,blockquote,body,canvas,caption,cite,code,dd,del,details,dfn,div,dl,dt,em,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,p,pre,q,samp,section,small,span,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,ul,var,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:0 0}body{line-height:1}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}nav ul{list-style:none}blockquote,q{quotes:none}blockquote:after,blockquote:before,q:after,q:before{content:'';content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:0 0}ins{background-color:#ff9;color:#000;text-decoration:none}mark{background-color:#ff9;color:#000;font-style:italic;font-weight:700}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}input,select{vertical-align:middle}.clearfix::after {content: "";display: block;clear: both;}

html{
	font-size:62.5%;
}
*{
	max-height:99999px;
}
body{
	font-family: "Noto Sans JP",'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro','メイリオ', 'Meiryo', '游ゴシック', 'Yu Gothic', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	-webkit-text-size-adjust: 100%;
	font-size:1.6rem;
	color: #222;
	background: #fff;
	font-weight: 400;
	line-height: 1.75;
	font-feature-settings: "palt";
	letter-spacing: 2px;
}
img,video{
	vertical-align:bottom;
	max-width: 100%;
}
li{
	list-style:none;
}
a{
	text-decoration:none;
	color:#222;
}
a:hover{
	opacity:0.6;
}
#wrap{
	overflow:hidden;
}
.relative{
	position:relative;
}
.absolute{
	position:absolute;
}
.inline{
	display:inline-block;
}
.left{
	float:left;
}
.right{
	float:right;
}
.pc{
	display:block;
}
.sp{
	display:none;
}
.in{
	width:1200px;
	margin:0 auto;
	position: relative;
	z-index: 3;
}
.in_in{
	width:1000px;
	margin:0 auto;
	position: relative;
	z-index: 3;
}
.flex{
	display: flex;
}
.flex_w{
	flex-wrap: wrap;
}
.palt{
	font-feature-settings: "palt";
}
.en{
	font-family: 'Roboto', sans-serif;
}
.min{
	font-family: "Shippori Mincho", serif;
}
@media screen and (max-width: 750px) {
	body{
		font-size: 1.4rem;
	}
	#wrap{
		width: 100vw;
	}
	.pc{
		display:none;
	}
	.sp{
		display:block;
	}
	.in,.in_in{
	width: 90%;
	margin: 0 auto;
	}
	.flex_w_sp{
		flex-wrap: wrap;
	}
}


#main{
	position: relative;
}
#main:before{
	content: "";
	width: 50%;
	height: 100%;
	position: absolute;
	background-image: -moz-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -webkit-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -ms-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	left: 0;
	top: 0;
}
#main:after {
	content: "";
	width: 50%;
	height: 100%;
	position: absolute;
	background-image: -moz-linear-gradient(45deg, rgb(231, 229, 75) 0%, rgb(213, 211, 46) 100%);
	background-image: -webkit-linear-gradient(45deg, rgb(231, 229, 75) 0%, rgb(213, 211, 46) 100%);
	background-image: -ms-linear-gradient(45deg, rgb(231, 229, 75) 0%, rgb(213, 211, 46) 100%);
	right: 0;
	top: 0;
}
#main .fv_point{
    position: absolute;
    bottom: -80px;
}
@media screen and (max-width: 750px) {
	#main .in{
		width: 100%;
	}
	#main .fv_point {
		position: absolute;
		bottom: -50px;
	}
}

.cta{
	background: url(../images/red_bg@x2.jpg);
	background-size: cover;
	background-position: center;
	padding: 50px 0;
	text-align: center;
}
.cta.fv_u_cta{
	padding-top: 120px;
}
.cta h2{
	margin-bottom: 20px;
}
@media screen and (max-width: 750px) {
	.cta.fv_u_cta{
		padding-top: 80px;
	}
}

.sec_ttl{
	text-align: center;
	margin-bottom: 60px;
}
@media screen and (max-width: 750px) {
	.sec_ttl{
		margin-bottom: 40px;
	}
}

#trouble{
	padding: 70px 0 0;
}
#trouble .trouble_lis_w{
	justify-content: center;
}
#trouble .trouble_lis_w li{
	width: 48%;
	box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.1);
	background: #fafafa;
	margin: 0 1%;
	box-sizing: border-box;
	padding: 15px;
	text-align: center;
	font-weight: 600;
	margin-bottom: 2%;
	position: relative;
}
#trouble .trouble_lis_w li:before{
	content: "";
	width: 20px;
	height: 20px;
	border-top: 6px solid #f55c40;
	border-left: 6px solid #f55c40;
	display: block;
	position: absolute;
	left: 0;
	top: 0;
}
#trouble .trouble_lis_w li:after {
	content: "";
	width: 20px;
	height: 20px;
	border-bottom: 6px solid #f55c40;
	border-right: 6px solid #f55c40;
	display: block;
	position: absolute;
	right: 0;
	bottom: 0;
}
#trouble .imgarea{
	text-align: center;
	margin-top: -35px;
	position: relative;
	z-index: 2;
}
@media screen and (max-width: 750px) {
	#trouble{
		padding: 50px 0 0;
	}
	#trouble .trouble_lis_w li{
		width: 100%;
		line-height: 1.5;
		min-height: 75px;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	#trouble .imgarea{
		margin-top: -15px;
	}
	#trouble .imgarea img{
		width: 60%;
	}
}

#hardship{
	padding: 0 0 70px;
}
#hardship .hardship_h{
	background-image: -moz-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -webkit-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -ms-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	padding: 50px 0 120px;
	text-align: center;
}
#hardship .hardship_c{
	position: relative;
	z-index: 2;
	margin-top: -70px;
}
#hardship .hardship_c_w{
	justify-content: space-between;
}
#hardship .caution{
	text-align: right;
	font-weight: 600;
	font-size: 1.4rem;
}
@media screen and (max-width: 750px) {
	#hardship .caution{
		letter-spacing: -1px;
		font-size: 1.0rem;
	}
}

.hollow_out{
	background: url(../images/hollow_out_bg@x2.png);
	background-size: cover;
	background-position: center;
	padding: 50px 0;
	text-align: center;
}
@media screen and (max-width: 750px) {}

.hollow_out{
	background: url(../images/hollow_out_bg@x2.png);
	background-size: cover;
	background-position: center;
	padding: 50px 0;
	text-align: center;
}
@media screen and (max-width: 750px) {}

.pardon{
	background: #e9e9e9;
	text-align: center;
}
@media screen and (max-width: 750px) {}

.nolisk {
	background: url(../images/red_bg@x2.jpg);
	background-size: cover;
	background-position: center;
	text-align: center;
	padding: 50px 0;
}
@media screen and (max-width: 750px) {}

#point{
	padding: 70px 0;
}
#point h2{
	text-align: center;
	margin-bottom: 120px;
}
.points_i{
	position: relative;
	margin-bottom: 100px;
}
.points_i:nth-last-of-type(1){
	margin-bottom: 0;
}
.points_i .txtarea{
	background-image: -moz-linear-gradient(45deg, rgb(255, 99, 71) 0%, rgb(225, 76, 49) 100%);
	background-image: -webkit-linear-gradient(45deg, rgb(255, 99, 71) 0%, rgb(225, 76, 49) 100%);
	background-image: -ms-linear-gradient(45deg, rgb(255, 99, 71) 0%, rgb(225, 76, 49) 100%);
	width: 65%;
	padding: 50px 180px 50px 50px;
	box-sizing: border-box;
	position: relative;
	min-height: 380px;
}
.points_i:nth-of-type(2n) .txtarea{
	padding: 70px 40px 50px 160px;
	box-sizing: border-box;
	margin-left: auto;
}
.points_i .txtarea .sub_ttl{
	font-size: 1.8rem;
	font-weight: bold;
	letter-spacing: 5px;
	margin-bottom: 5px;
}
.points_i .txtarea .sub_tt_w{
	margin-bottom: 25px;
	align-items: center;
	padding-bottom: 25px;
	border-bottom: 1px solid #fff;
}
.points_i .txtarea h3{
	font-size: 2.4rem;
	font-weight: bold;
	color: #fff;
	margin-top: 10px;
}
.points_i .txtarea .txt{
	line-height: 2;
	color: #fff;
}
.points_i .imgarea{
	position: absolute;
  right: 0;
  top: -40px;
}
.points_i .imgarea.active{
	top: -40px;
}
.points_i:nth-of-type(2n) .imgarea{
	position: absolute;
  right: auto;
	left: 0;
}

@media screen and (max-width: 750px) {
	#point{
		padding: 50px 0;
	}
	#point h2 {
		text-align: center;
		margin-bottom: 90px;
	}
	.points_i,.points_i:nth-last-of-type(1){
		margin-bottom: 250px;
	}
	.points_i .imgarea,
	.points_i:nth-of-type(2n) .imgarea{
		position: absolute;
    right: -6%;
		left: auto;
    top: -40px;
    width: 105vw;
	}
	.points_i .imgarea.active,
	.points_i:nth-of-type(2n) .imgarea.active{
		top: 0px;
	}
	.points_i .txtarea,
	.points_i:nth-of-type(2n) .txtarea{
    width: 100%;
    padding: 30px;
		padding-top: 50px;
    z-index: 2;
    position: relative;
    top: 200px;
	}
	.points_i .txtarea .num{
		left: 50%;
		transform: translate(-50%,0);
		font-size: 6.0rem;
	}
	.points_i .txtarea .sub_tt_w{
		flex-wrap: wrap;
	}
	.points_i .txtarea .sub_tt_w .ico{
		width: 100%;
		text-align: center;
	}
	.points_i .txtarea .sub_ttl{
    font-size: 1.4rem;
    letter-spacing: 3px;
	}
	.points_i .txtarea h3{
		font-size: 2.0rem;
		text-align: center;
	}
	.points_i .txtarea .txt{
		line-height: 2;
	}
	.points .more_us h3{
		color: #fff;
    font-size: 2.0rem;
    letter-spacing: 3px;
	}
}

#case{
	padding: 70px 0;
	background: url(../images/w_bg@x2.jpg);
	background-size: cover;
	background-position: center;
}
#case .lead_txt{
	text-align: center;
	font-weight: 600;
	margin-bottom: 50px;
}
.slick-track {
  display: flex;
}
.slick-slide {
  height: auto !important;
}
#case .case_i_w{
	padding: 0 10px;
}
#case .case_i{
	background: #fff;
	padding: 40px;
	height: 100%;
}

#case .case_i .imgarea{
	flex-shrink: 0;
	margin-right: 30px;
	width: 35%;
}
#case .case_i .txtarea{}
#case .case_i .txtarea h3{
	color: #ee563b;
	font-weight: 700;
	font-size: 2.6rem;
	letter-spacing: -1px;
	margin-bottom: 10px;
}
#case .case_i .txtarea .user_meta_w{
	margin-bottom: 25px;
}
#case .case_i .txtarea .user_meta_w .txt{
	margin-bottom: 10px;
}
#case .case_i .txtarea .user_meta_w .user_meta_i{
	margin-right: 20px;
}
#case .case_i .txtarea .user_meta_w dt{
	width: 80px;
	background-image: -moz-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -webkit-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -ms-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	color: #fff;
	text-align: center;
	margin-right: 10px;
}
@media screen and (max-width: 750px) {
	#case .case_i{
		display: block;
		padding: 25px;
	}
	#case .case_i .imgarea{
		flex-shrink: unset;
		margin-right: 0;
		width: 100%;
		height: auto;
	}
	#case .case_i .txtarea .user_meta_w .user_meta_i{
		margin-bottom: 5px;
	}
	#case .case_i .txtarea .user_meta_w dt{
		flex-shrink: 0;
	}
}

#introduction{
	padding: 70px 0;
}
#introduction .introduction_i{
	border: 1px solid #d7d7d7;
	padding: 25px;
	margin-bottom: 20px;
}
#introduction .introduction_i .imgarea{
	flex-shrink: 0;
	width: 40%;
	margin-right: 20px;
}
#introduction .introduction_i .txtarea dl{

}
#introduction .introduction_i .txtarea .introduction_i_txt{
	width: 50%;
	margin-bottom: 10px;
}
#introduction .introduction_i .txtarea .introduction_i_txt.w100 {
	width: 100%;
}
#introduction .introduction_i .txtarea dt {
	min-width: 100px;
	background-image: -moz-linear-gradient(45deg, rgb(255, 99, 71) 0%, rgb(225, 76, 49) 100%);
	background-image: -webkit-linear-gradient(45deg, rgb(255, 99, 71) 0%, rgb(225, 76, 49) 100%);
	background-image: -ms-linear-gradient(45deg, rgb(255, 99, 71) 0%, rgb(225, 76, 49) 100%);
	color: #fff;
	text-align: center;
	margin-right: 10px;
}
@media screen and (max-width: 750px) {
	#introduction .introduction_i .imgarea{
		width: 100%;
		margin-right: 0;
		margin-bottom: 30px;
	}
		#introduction .introduction_i .txtarea .introduction_i_txt {
			width: 100%;
			margin-bottom: 6px;
		}
}

#flow{
	padding: 80px 0;
	background-image: -moz-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -webkit-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -ms-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
}
#flow .flow_i {
	margin-bottom: 65px;
	padding: 30px;
	position: relative;
	align-items: center;
	background: #fff;
}
#flow .flow_i:after {
	content: "";
	display: block;
	width: 30px;
	height: 30px;
	border-bottom: 2px solid #fff;
	border-right: 2px solid #fff;
	position: absolute;
	top: calc(100% + 10px);
	z-index: 99;
	left: 50%;
	transform: translate(-50%, 0px) rotate(45deg);
}
#flow .flow_i:nth-last-of-type(1):after {
	display: none;
}
#flow .flow_i:nth-last-of-type(1) {
	margin-bottom: 0;
}
#flow .flow_i .icon {
	padding-right: 20px;
	margin-right: 20px;
	flex-shrink: 0;
	text-align: center;
}
#flow .flow_i .flow_sub_ttl_w {
	margin-bottom: 20px;
	align-items: center;
}
#flow .flow_i .flow_sub_ttl_w .num {
	color: #f1583d;
	letter-spacing: 1px;
	line-height: 1;
	margin-right: 15px;
	border-radius: 100px;
	font-size: 2.0rem;
	font-weight: 700;
}
#flow .flow_i .flow_sub_ttl_w .num span{
	border-bottom: 2px solid #f1583d;
	display: inline-block;
	padding-bottom: 5px;
}
#flow .flow_i .flow_sub_ttl_w h3 {
	font-size: 2.0rem;
	font-weight: 700;
	line-height: 1;
	color: #f1583d;
}
#flow .flow_i p{
	letter-spacing: 2px;
}
@media screen and (max-width: 768px) {
	#flow {
		padding: 70px 0;
	}
	#flow .flow_i{
		padding: 7.5%;
		flex-wrap: wrap;
	}
	#flow .flow_i .icon{
		width: 100%;
        text-align: center;
        margin-bottom: 7.5%;
        margin-right: 0;
        padding-right: 0;
	}
	#flow .flow_i .txtarea{
		width: 100%;
	}
	#flow .flow_i p{
		text-align: center;
	}
	#flow .flow_i .flow_sub_ttl_w{
		display: block;
		text-align: center;
	}
	#flow .flow_i .flow_sub_ttl_w .num{
		font-size: 1.8rem;
		margin-right: 0;
		margin-bottom: 10px;
	}
	#flow .flow_i .flow_sub_ttl_w h3{
		font-size: 1.8rem;
	}
}

#faq{
	padding: 70px 0;
}
#faq h2{
	font-size: 4.0rem;
	font-weight: 700;
	text-align: center;
	margin-bottom: 50px;
}
.faq_i{
	background: #feeeeb;
	padding: 10px 20px;
	margin-bottom: 10px;
}
.faq_i .flex{
	align-items: center;
}
.faq_i .ico{
	font-size: 2.4rem;
	color: #f1583d;
	margin-right: 20px;
	flex-shrink: 0;
}
.faq_i dt,.faq_i dd{
	padding: 10px;
	position: relative;
}
.faq_i dt::after{
	content: "";
	display: block;
	width: 10px;
	height: 10px;
	border-left: 1px solid #f1583d;
	border-bottom: 1px solid #f1583d;
	position: absolute;
	top: 50%;
	right: 20px;
	transform: translate(0,-50%) rotate(-45deg);
}
.faq_i dd{
	border-top: 1px solid #f1583d;
	display: none;
}
.faq_i h3{
	font-size: 1.8rem;
	color: #f1583d;
}
@media screen and (max-width: 750px) {
	.faq_i{
		padding: 10px 20px 10px 10px;
	}
	.faq_i dt::after{
		right: 0;
	}
	.faq_i .ico{
		font-size: 2.8rem;
	}
	.faq_i h3{
		font-size: 1.6rem;
	}
}

#form{
	padding: 80px 0 80px;
	position: relative;
	background: #f0f0f0;
    padding: 80px 0;
}
#form h2 {
	font-size: 4.0rem;
	font-weight: 700;
	text-align: center;
	margin-bottom: 50px;
}
.form_w{
	box-shadow: 0 0 5px 1px rgba(0,0,0,0.1);
	border-radius: 10px;
	box-sizing: border-box;
	padding: 40px;
	background: #fff;
	position: relative;
}
.form_w table{
	width: 100%;
}
.form_w th{
	font-weight: 400;
	width: 30%;
	text-align: left;
	vertical-align: top;
}
.form_w th span{
	color:#f1583d;
	margin-left: 10px;
}
.form_w td{
	padding: 10px;
	vertical-align: top;
}
.form_w td input[type=text],
.form_w td input[type=tel],
.form_w td input[type=email]{
	width: 100%;
	border: 1px solid #888;
	height: 40px;
	padding: 5px;
	box-sizing: border-box;
}
.form_w td textarea{
	width: 100%;
	border: 1px solid #888;
	height: 100px;
	padding: 5px;
}
.with-validate {
	display : block;
	position : relative;
}
.with-validate label.error {
	display : inline-block;
	position : absolute;
	z-index : 5;
	left : -5px;
	bottom : 100%;
	margin-bottom : 10px;
	background : #c3272a;
	color : #fff;
	padding : 5px 10px;
	font-size : 12px;
	border-radius : 4px;
}
.with-validate label.error::before {
	content : '';
	background-color : transparent;
	position : absolute;
	top : 100%;
	margin : 0;
	left : 20px;
	width : 0;
	height : 0;
	border-width : 10px;
	border-style : solid;
	border-color : #c3272a transparent transparent;
}
.form_w .btn-area{
	text-align: center;
	margin-top: 30px;
}
input[type="submit"] {
  appearance: none;
  -webkit-appearance: none;
  }
.form_w input[type=submit]{
	width: 50%;
	border: none;
}
input[type="submit"]:hover{
	opacity: 0.6;
}
.form_w input[type=radio]{
	margin: 0;
    vertical-align: middle;
}
.form_w td,.form_w th{
	vertical-align:middle;
}
.form_w input[type=submit] {
	background-image: -moz-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -webkit-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
	background-image: -ms-linear-gradient( 45deg, rgb(255,99,71) 0%, rgb(225,76,49) 100%);
		color: #fff;
    padding: 15px 50px 15px 30px;
    border-radius: 100px;
    color: #fff;
    text-align: center;
    display: inline-block;
    position: relative;
    box-sizing: border-box;
}
@media screen and (max-width: 750px) {
	.form_w{
		padding: 5%;
	}
	.form_w.in_in{
		width: 100%;
	}
	.form_w td,.form_w th{
		display: block;
		width: 100%;
		padding: 10px;
		box-sizing: border-box;
	}
	.form_w input[type=submit]{
		width: 100%;
		border: none;
	}
}

#company{
	padding: 60px 0;
}
#company h2 {
	font-size: 4.0rem;
	font-weight: 700;
	text-align: center;
	margin-bottom: 50px;
}
#company .sec_ttl_w::before,
#company .sec_ttl_w::after{
	display: none;
}

#company table{
	border-radius: 10px;
	margin:40px auto 0;
	border-bottom: 2px solid #e8e8e8;
	width: 100%;
}

#company table th{
	text-align: left;
	font-weight: 600;
	padding: 20px 20px;
	border-top: 2px solid #e8e8e8;
	width: 25%;
}

#company table td{
	border-top: 2px solid #e8e8e8;
	text-align: left;
	padding: 20px 20px;
}

@media screen and (max-width: 750px){
	#company{
		padding: 20px 0;
	}

	#company table{
		width: 100%;

	}

	#company table th,
	#company table td{
		display: block;
		width: 100%;
		box-sizing: border-box;
	}

	#company table th{
		border-bottom: 0px;
		padding-bottom: 15px;
	}

	#company table td{
		border-top: 0px;
		padding-top: 0;
	}
}

.fixed_foot{
	display: none;
}

@media screen and (max-width: 750px){
	.fixed_foot{
		display: block;
		background: #fff;
		position: fixed;
		width: 100%;
		bottom: 0;
		z-index: 999;
		box-sizing: border-box;
	}
	.fixed_foot .btns{
		margin-left: 0;
	}
	.fixed_foot a{
		position: relative;
		text-align: center;
		padding: 1%;
	}
}

footer{
	text-align: center;
	padding: 15px;
}