@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Caveat&family=Noto+Sans+SC:wght@400&display=swap');

/* =======================================

	lp-ryouritsu Elements

======================================= */

header {
	background: transparent;
	box-shadow: none;
}
header .contact {
	position: fixed;
	top: -28px;
	right: -24px;
	z-index: 99;
}
header .contact .btn_basic {
	margin: 0 0 0 auto;
	width: 170px;
	height: 170px;
	line-height: 1.6;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
}
header .contact .btn_basic::before,
header .contact .btn_basic::after {
	border-radius: 85px;
}
header .contact .btn_basic span {
	display: inline-block;
	padding: 40px 0 0;
	background: transparent url(/biz/lp-ryouritsu/img/ico_mail.svg) center 10px no-repeat;
}

footer .footer_nav {
	padding: 70px 0;
	color: #fff;
	text-align: center;
}
footer .footer_logo {
	margin: 0 auto;
}
footer .footer_logo small {
	display: block;
	margin: 20px auto 0;
}

.upper {
	text-transform: uppercase;
}
.marker {
	background: linear-gradient(transparent 70%, rgba(86, 189, 244, 0.5) 0%) repeat scroll 0 0;
}
.check {
	display: inline-block;
	overflow: visible;
	position: relative;
}
.check::before {
	content: "";
	width: 100%;
	height: 3.4em;
	position: absolute;
	top: 50%;
	left: 0;
	margin-top: -1.7em;
	background: transparent url(/biz/lp-ryouritsu/img/check01.svg) center center no-repeat;
	background-size: 97%;
}
.check.t02::before {
	width: 120%;
	left: -10%;
	background: transparent url(/biz/lp-ryouritsu/img/check02.svg) center center no-repeat;
	background-size: 100%;
}
.check.t03::before {
	background: transparent url(/biz/lp-ryouritsu/img/check03.svg) center center no-repeat;
	background-size: 100%;
}

.headline {
	text-align: center;
	margin: 0 0 80px;
}
.headline h3 {
	font-family: 'Caveat', cursive;
	font-size: 9.4rem;
	line-height: 1.2;
	transform: rotate(-10deg);
	margin-bottom: 20px;
}
.headline p {
	display: inline-block;
	font-size: 2.2rem;
	font-weight: bold;
	position: relative;
}
.headline p::before,
.headline p::after {
	content: "";
	position: absolute;
	bottom: 0;
	width: calc(50% - 12px);
	border-bottom: 1px solid #999;
}
.headline p::before {
	left: 0;
}
.headline p::after {
	right: 0;
}
.headline p span::before {
	content: "";
	position: absolute;
	display: block;
	width: 18px;
	height: 18px;
	border: 1px solid #999;
	border-top: none;
	border-left: none;
	left: calc(50% - 9px);
	bottom: -9px;
	transform: rotate(45deg);
}

@media only screen and (max-width: 768px) {
	header {
		position: absolute;
	}
	header .contact {
		top: -20px;
		right: -18px;	
	}
	header .contact .btn_basic {
		width: 104px;
		height: 104px;
	}
	header .contact .btn_basic span {
		font-size: 1rem;
		padding: 30px 10px 0 0;
		background-size: 20px auto;
	}
}


/* ------------------------------------
	main_visual
------------------------------------ */
.main_visual {
	margin-top: -98px;
	margin-bottom: 40px;
	z-index: 0;
	background: #fff url(/biz/lp-ryouritsu/img/main_visual.jpg) center top no-repeat;
	background-size: 100%;
	width: 100%;
	min-width: 1040px;
	height: 63vw;
	min-height: 656px;
	position: relative;
	padding: 0 0 60px;
}
.main_visual .inner .main_text {
	width: 580px;
	padding-top: 110px;
}
.main_visual .inner h2 {
	margin: 0 0 35px;
}
.main_visual .inner h2 span {
	font-size: 1.8rem;
	color: #001976;
	font-weight: bold;
}
.main_visual .inner h2 img {
	padding: 6px 0;
}
.main_visual .inner .btn_area {
	margin: 40px 0 0;
}
.main_visual .inner p {
	padding: 0 1em;
}
.main_visual .inner .copy {
	padding: 0;
	font-size: 2rem;
	font-weight: bold;
	margin-top: 30px;
}
@media only screen and (min-width: 1040px) {
	.main_visual .inner .main_text {
		padding-top: 12vw;
	}
}
@media only screen and (min-width: 769px) {
	.main_visual .inner .btn_basic {
		width: 206px;
		margin-left: auto;
	}
}

@media only screen and (max-width: 768px) {
	.main_visual {
		margin-top: 0;
		background: #fff url(/biz/lp-ryouritsu/img/main_visual_sp.jpg) left top no-repeat;
		background-size: 100%;
		min-width: 0;
		height: auto;
		min-height: 0;
	}
	.main_visual .inner .main_text {
		width: 100%;
		padding-top: 93vw;
	}
	.main_visual .inner h2 > * {
		background: #fff;
	}
	.main_visual .inner h2 span {
		font-size: 1.4rem;
	}
	.main_visual .inner h2 img {
		width: auto;
		height: 9vw;
		padding: 2px;
	}
}


/* ------------------------------------
	sec_point
------------------------------------ */
.sec_point .headline {
	color: #001976;
}
.sec_point .headline p::before,
.sec_point .headline p::after,
.sec_point .headline p span::before {
	border-color: #56BDF4;
}

.sec_point section {
	border-radius: 10px;
	box-shadow: 0 0 32px rgba(177, 183, 201, .16);
	position: relative;
	padding: 0 0 100px;
	margin: 0 0 70px;
}

.sec_point .num {
	color: #001976;
	font-family: 'Caveat', cursive;
	font-size: 6.8rem;
	line-height: 1.2;
	position: absolute;
	top: -.6em;
	left: 50%;
	margin-left: -40px;
}
.sec_point .num span {
	display: inline-block;
	transform: rotate(-10deg);
	margin-right: 10px;
}

.sec_point .point_header {
	border-radius: 10px;
	overflow: hidden;
	border-radius: 10px 10px 0 0;
	margin: 0 0 60px;
}

.sec_point .point_img {
	background: linear-gradient(to bottom right, #eff1ff 0%, #f4fffa 100%);
	order: 2;
	text-align: center;
}
.sec_point .point_img img {
	mix-blend-mode: multiply;
}

.sec_point .point_header .hd_text {
	flex: 1;
	padding: 0 80px;
	font-size: 2rem;
}

.sec_point .point_header .e_head {
	color: #8D8D8D;
	margin: 0 0 .5em;
}
.sec_point .point_header h4 {
	font-size: 1.4em;
	font-weight: bold;
}

.sec_point section > p {
	margin: 0 80px;
}

.sec_point .point02 .point_img {
	background: linear-gradient(to top left, #eff1ff 0%, #f4fffa 100%);
}

@media only screen and (min-width: 769px) {
	.sec_point .point_header {
		display: flex;
		align-items: center;
		justify-content: space-between;
	}
	.sec_point .point01 .num {
		left: 70px;
	}

	.sec_point .point02 .num {
		left: auto;
		right: 40px;
	}
	.sec_point .point02 .point_img {
		order: 0;
	}

	.sec_point .point03 {
		text-align: center;
	}
	.sec_point .point03 .num {
	}
	.sec_point .point03 .point_header {
		display: block;
	}
	.sec_point .point03 .hd_text {
		padding-top: 40px;
		font-size: 2.4rem;
	}
}

@media only screen and (max-width: 768px) {
	.sec_point .point_img {
		margin: 0 0 40px;
	}
	.sec_point .point_header {
		margin: 0 0 40px;
	}
	.sec_point section {
		padding: 0 0 60px;
	}
	.sec_point .point_header .hd_text {
		font-size: 1.4rem;
		text-align: center;
		padding: 0 5%;
	}
	.sec_point .point_header h4 {
		text-align: left;
	}
	.sec_point section > p {
		margin: 0 5%;
	}

}

/* ------------------------------------
	sec_goal
------------------------------------ */
.sec_goal {
	position: relative;
	background-image: url(/biz/lp-ryouritsu/img/goal_bg.png);
	background-position: top center;
	background-size: 140%;
	text-align: center;
	margin-top: 200px;
	padding: 0 0 120px;
}
.sec_goal::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	background: linear-gradient(120deg, #E6E9FF 0%,  #EEFFF7 52%);
}

.sec_goal .marker {
	background: linear-gradient(transparent 70%, rgba(255, 213, 72, .5) 0%) repeat scroll 0 0;
}

.sec_goal .headline {
	color: #FF8900;
}
.sec_goal .headline p::before,
.sec_goal .headline p::after,
.sec_goal .headline p span::before {
	border-color: #FFB100;
}

.goal_img {
	margin-top: -115px;
	max-width: 100%;
}

.sec_goal section {
	margin: 0 0 80px;
}

.sec_goal h4 {
	font-size: 3.6rem;
	font-weight: bold;
	margin: 0 0 1.3em;
}

.sec_goal h5 {
	font-size: 2.4rem;
	font-weight: bold;
}
.sec_goal h5 span {
	display: block;
	font-size: 2rem;
}
.sec_goal .content > *:first-child h5 span {
	color: #49C757;
}
.sec_goal .content > *:last-child h5 span {
	color: #56BDF4;
}
.sec_goal .content p {
	text-align: left;
}

.sec_goal .goal01 {
	padding: 0 0 80px;
	position: relative;
}
.sec_goal .goal01::after {
	content: "";
	width: 60px;
	height: 0;
	border-bottom: 2px solid #EFEFEF;
	position: absolute;
	left: 50%;
	bottom: 0;
	margin-left: -30px;
}

.sec_goal .goal01 .content {
	background: #fff;
	border-radius: 10px;
	margin: 40px 0 0;
	display: flex;
	padding: 60px 80px;
	justify-content: space-between;
	position: relative;
}
.sec_goal .goal01 .content::before,
.sec_goal .goal01 .content::after {
	content: "";
	width: 76px;
	height: 2px;
	background: #A8A8A8;
	position: absolute;
	left: 50%;
	top: 50%;
	margin-left: -38px;
	margin-top: -27px;
}
.sec_goal .goal01 .content::before {
	transform: rotate(45deg);
}
.sec_goal .goal01 .content::after {
	transform: rotate(-45deg);
}

.sec_goal .goal01 .content > * {
	width: 350px;
}
.sec_goal .goal01 img {
	margin: 20px 0;
}

.sec_goal .goal02 .content {
	display: flex;
	justify-content: space-between;
}
.sec_goal .goal02 .content > * {
	width: 510px;
	position: relative;
}
.sec_goal .goal02 .content > *::before {
	content: "";
	display: block;
	width: 34px;
	height: 34px;
	border-radius: 17px;
	background: #999 url(/biz/lp-ryouritsu/img/ico_checkbox.png) center center no-repeat;
	position: absolute;
	top: -15px;
	left: 50%;
	margin-left: -17px;
	z-index: 2;
}
.sec_goal .goal02 .content > *:first-child::before {
	background-color: #49C757;
}
.sec_goal .goal02 .content > *:last-child::before {
	background-color: #56BDF4;
}

.sec_goal .goal02_body {
	background: #fff;
	border: 2px solid #EFEFEF;
	border-radius: 10px 10px 0 0;
	padding: 50px 0;
	margin: 0 0 60px;
	height: 340px;
	position: relative;
}
.sec_goal .goal02_body::before,
.sec_goal .goal02_body::after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 28px 255px 0 255px;
	position: absolute;
	left: 0;
}
.sec_goal .goal02_body::before {
	border-color: #fff transparent transparent transparent;
	bottom: -28px;
	z-index: 1;
}
.sec_goal .goal02_body::after {
	border-color: #EFEFEF transparent transparent transparent;
	bottom: -30px;
}
.sec_goal .goal02 ul {
	display: inline-block;
	margin-top: 40px;
	text-align: left;
}
.sec_goal .goal02 ul li {
	position: relative;
	padding-left: 1em;
}
.sec_goal .goal02 ul li::before {
	content: "";
	display: block;
	width: 5px;
	height: 5px;
	border-radius: 5px;
	background: #000;
	position: absolute;
	left: 0.2em;
	top: 50%;
	margin-top: -2px;
}
.sec_goal .goal02 .content > *:first-child ul li::before {
	background: #49C757;
}
.sec_goal .goal02 .content > *:last-child ul li::before {
	background: #56BDF4;
}

.sec_goal .goal02 .content p {
	font-weight: bold;
	padding: 0 2em;
}


.sec_goal .contact {
	border-top: 2px solid #EFEFEF;
	padding: 80px 0 0;
}
.sec_goal .contact .btn_basic {
	line-height: 1.6;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
	position: relative;
}

.sec_goal .contact .btn_basic::before,
.sec_goal .contact .btn_basic::after {
	top: 0;
	border-radius: 75px;
}
.sec_goal .contact .btn_basic small {
	display: block;
	font-size: 1.6rem;
	opacity: .5;
}
.sec_goal .contact .btn_basic > span::after {
	content: "";
	width: 54px;
	height: 42px;
	display: inline-block;
	background: transparent url(/biz/lp-ryouritsu/img/ico_mail.svg) center center no-repeat;
	background-size: contain;
	position: absolute;
	left: 70px;
	top: 50%;
	margin-top: -22px;
}

@media only screen and (min-width: 769px) {
	.sec_goal .contact .btn_basic {
		margin: 0 auto;
		width: 720px;
		height: 150px;
	}
	.sec_goal .contact .btn_basic .arrow {
		width: 87px;
		height: auto;
		right: -40px;
	}
	.sec_goal .contact .btn_basic > span:before {
		height: 3px;
		margin-top: -1.5px;
		width: 36px;
	}
	.sec_goal .contact .btn_basic > span {
		text-align: left;
		font-size: 2.4rem;
		padding-left: 50px;
	}

}
@media only screen and (max-width: 768px) {
	.sec_goal {
		margin-top: 30%;
	}
	.goal_img {
		margin-top: -20%;
		max-width: 80%;
	}
	.sec_goal h4 {
		font-size: 2rem;
	}

	.sec_goal p {
		text-align: left;
	}
	.sec_goal .goal01 .content {
		display: block;
		padding: 40px 5%;
	}
	.sec_goal .goal01 .content > * {
		width: 100%;
	}
	.sec_goal .goal01 .content > *:last-child {
		margin-top: 80px;
	}

	.sec_goal .goal02 .content {
		display: block;
	}
	.sec_goal .goal02 .content > * {
		width: 92vw;
		margin: 80px auto 0;
	}
	.sec_goal .goal02_body::before,
	.sec_goal .goal02_body::after {
		border-width: 28px 46vw 0 46vw;
	}
	.sec_goal .goal02_body {
		height: auto;
	}

	.sec_goal .contact .btn_basic {
		height: 150px;
		line-height: 1.6;
	}
	.sec_goal .contact .btn_basic::before,
	.sec_goal .contact .btn_basic::after {
		top: 0;
		border-radius: 75px;
	}
	.sec_goal .contact .btn_basic > span {
		text-align: left;
		font-size: 1.6rem;
		padding: 30px 5% 0;
	}
	.sec_goal .contact .btn_basic > span::after {
		width: 40px;
		left: 50%;
		top: 10px;
		margin-top: 0;
		margin-left: -20px;
	}
	.sec_goal .contact .btn_basic small {
		display: block;
		text-align: center;
	}

}
