@charset "utf-8";
@font-face {
	font-family: 'Oswald';
	-ms-font-feature-settings: "normal";
	src:
		url('../font/Oswald-Medium.ttf') format('ttf'),
		url('../font/Oswald-Medium.woff') format('woff');
/*	font-weight: bold;*/
	font-style: normal;
	font-display: swap;
}
.oswald{
	font-family: 'Oswald',sans-serif!important;
	-ms-font-feature-settings: "normal";
}
.col-red{
	color: #0043F8;
}
.sca1{
	position: relative;
}
/*----- cf7 -----*/
.screen-reader-response{
	display: none!important;
}
/*----- temp -----*/

[class*="__sec"]{
	padding: 120px 0 140px;
	position: relative;
}
[class*="__sec"]:not(.works__sec):not(.company__sec):not(.contact-temp__sec){
	display: flex;
	width: 100%;
	height: auto;
	min-width: 100%;
	min-height: 100%;
	background-size: cover;
	background-position: center;
	align-items: center;
	position: static;
}
.sec__head{
	margin-bottom: 96px;
	position: relative;
	z-index: 1;
}
.sec__title{
	margin-bottom: 36px;
	font-family: 'Oswald',sans-serif!important;
	-ms-font-feature-settings: "normal";
	font-size: 4.3em;
	font-weight: 800;
}
.sec__title-sub{
	padding-bottom: 27px;
	font-size: 2em;
	font-weight: bold;
	letter-spacing: 0.04em;
	position: relative;
}
.sec__text{
	margin-top: 54px;
	font-size: 2em;
	font-weight: bold;
	line-height: 1.8;
	letter-spacing: 0.03em;
	position: relative;
}
.sec__title-sub::after,
.contact-temp__sec .sec__text::before{
	content: "";
	display: inline-block;
	width: 36px;
	height: 4px;
	background-color: #0043F8;
	position: absolute;
	left: 0;
}
.sec__title-sub::after{
	bottom: 0;
}
.contact-temp__sec .sec__text::before{
	top: 0;
}
.sec__title + .sec__text{
	margin-top: 0
}
.sec__title-bg{
	font-family: 'Oswald',sans-serif!important;
	-ms-font-feature-settings: "normal";
	font-size: 22.3em;
	font-weight: 800;
	position: absolute;
	top: -62px;
	left: -60px;
	white-space: nowrap;
	opacity: 0.03;
	pointer-events: none;
}
	
/*----- header -----*/
header {
	display: flex;
	width: 100%;
	padding: 24px 40px;
	position: fixed;
	justify-content: space-between;
	align-items: center;
	z-index: 99;
	transition: 0.4s background-color;
}
h1 small {
	display: block;
	font-size: 1.1em;
	margin-bottom: 13px;
}
.header__logo {
	width: 280px;
}
.contact3__list {
	display: flex;
}
.contact3__item:first-of-type, .contact3__item a {
	display: flex;
	justify-content: center;
	align-items: center;
	min-width: 126px;
	height: 40px;
	padding: 3px 20px 0;
	border: 1px solid #fff;
	font-weight: bold;
}
.contact3__item:not(:last-of-type) {
	margin-right: 24px;
}
.contact3__item .tel__contenet {
	margin-left: 8px;
}
.contact3__item .phone__img {
	width: 25px;
	height:25px;
}
.contact3__item .tel__num {
	font-size: 1.6em;
	font-weight: normal;
	letter-spacing: 0.04em;
}
.contact3__item .tel__text {
	font-weight: bold;
	letter-spacing: 0.064em;
}
.contact3__item a {
	font-size: 1.5em;
	transition: 0.4s;
}
.contact3__item a:hover {
	background-color: #fff;
	color: #061A24;
}
/*----- fv -----*/
.fv__sec {
	min-height: 100vh!important;
	height: 100vh!important;
	background-image: url("../img/lp1/fv-pc.png");
	position: relative;
}
.fv-bg{
	width: 100%;
	height: 100%;
	position: absolute;
	left:0;
	top: 0;
	background-image: linear-gradient(270deg,rgb(0,0,0) 100%, rgba(255,255,255,0) 0%);
	background-repeat: no-repeat;
	background-position: right;
	background-size: 100% 100%;
	transition: 0.4s ease-in;
}
.fv__sec .wrap{
	overflow: hidden;
	position: relative;
	z-index: 5;
	mix-blend-mode: difference;
}
.catchcopy__wrap{
	margin-bottom: 47px;
}
.fv__sec .catchcopy{
	font-size: 78px;
	line-height: 1.3;
	font-weight: 600;
	letter-spacing:  0.078em;
	mix-blend-mode: difference; 
	white-space: nowrap;
}
.catchcopy > span{
	margin-left: -1000px;
	transition: 1s;
}
.catchcopy > span.active{
	margin-left: 0;
}
.catchcopy-sub{
	margin-top: 24px;
	font-size: 1.8em;
	font-weight: bold;
	letter-spacing: 0.1em;
}
.catchcopy__list{
	margin-bottom:21px;
}
.catchcopy__item{
	display: flex;
	justify-content: center;
	align-items: center;
	height: 33px;
	padding: 0 6px;
	border: 1px solid #fff;
	font-size: 2em;
}
.catchcopy__item:not(:last-of-type) {
	margin-right: 15px;
}
.catchcopy__text{
	font-size: 1.5em;
	font-weight: bold;
	letter-spacing: 0.02em;
}
.catchcopy-sub,
.catchcopy__list,
.catchcopy__text{
	opacity: 0;
	transition: 1s;
}
.catchcopy-sub.active,
.catchcopy__list.active,
.catchcopy__text.active{
	opacity: 1;
}
/*----- toowner -----*/

.toowner__sec{
	background-color: #101112;
}
.toowner__sec .sec__title-sub::after{
	display: none;
}
.toowner__bg__thumbnail{
	display: flex;
	width: 56.5625vw;
	min-width: 811px;
	height: 480px;
	position: absolute;
	top: -20px;
	right: -21.875vw;
	justify-content: center;
	align-items: center;
	z-index: -1;
}
.toowner__bg__img{
	width: 100%;
	height: auto;
}
.worry__item{
	display: flex;
	font-size: 1.6em;
	letter-spacing: 0.04em;
	font-weight: bold;
	align-items: center;
}
.worry__item:not(:last-of-type){
	margin-bottom: 22px;
} 
.worry__item::before{
	content: "";
	display: inline-block;
	width:12px;
	height: 2px;
	margin-right: 16px;
	background-color: #0043F8;
}
.arrow__down__img{
	display: block;
	width: 52px;
	margin: 107px auto 70px;
}
.comment__thumbnail{
	width: 450px;
	height: 330px;
	margin-right: 80px;
}
.comment__content{
	display: flex;
	width: 550px;
	min-width: 550px;
	font-weight: bold;
	flex-direction: column;
	justify-content: space-between;
}

.comment__caption{
	font-weight: bold;
	margin-top: -6px;
	font-size: 3.2em;
	line-height: 1.8;
	white-space: nowrap;
}
.bg-white{
	padding: 0 8px;
	position: relative;
	z-index: 1;
	background-image: linear-gradient(90deg,white 100%, rgba(255,255,255,0) 0%);
	background-repeat: no-repeat;
	background-size: 0% 100%;
	transition:background-size  0.4s;
	color: transparent;
}
.bg-white.active{
	background-size: 100% 100%;
	color: #101112;
}

/*.bg-white::after{
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background-color: #FFFFFF;
	top: 0;
	left: -0;
	position: absolute;
	z-index: -1;
}*/
.comment__text{
	display: flex;
	font-size: 1.6em;
	line-height: 2;
	letter-spacing: 0.04em;
	flex-direction: column;
	align-items: stretch;
}
.comment__name{
	margin-top: 30px;
	font-size: 1.25em;
	line-height: 1;
}
/*----- service -----*/
.service__sec {
	background-image: url("../img/lp1/service__bg.png");
}
.service__sec .wrap{
	justify-content: space-between;
}
.service__sec .sec__head{
	width: 457px;
}

.service__img__wrap{
	width:524px;
	flex-wrap: wrap;
}
.service__img{
	width: 252px;
	opacity: 0;
	transition: 0.4s;
}
.service__img:nth-child(2n){
	margin-left: 20px;
}
.service__img:nth-child(2n){
	margin-left: 20px;
}
.service__img:not(:nth-last-child(-n + 2)){
	margin-bottom: 20px;
}
.service__img.active{
	opacity: 1;
}
/*----- contact-temp -----*/
.contact-temp__sec{
	text-align: center;
	background-color:#061A24;
}
.contact-temp__sec .sec__head{
	margin-bottom: 46px;
}
.contact-temp__sec .sec__title{
	margin-bottom: 16px;
}
.contact-temp__sec .sec__text{
	font-size: 2em;
	padding-top: 24px;
}
.contact-temp__sec .sec__text::before{
	right: 0;
	margin: 0 auto;
}
.contact-temp__sec .contact3__list{
	justify-content: center;
}
.contact-temp__sec .contact3__item:first-of-type,
.contact-temp__sec .contact3__item a{
	min-width: 189px;
	height: 64px;
	padding: 0 32px 0;
}
.contact-temp__sec .contact3__item:not(:last-of-type){
	margin-right: 30px;
}
.contact-temp__sec .contact3__item a{
	font-size: 1.8em;
	padding-top: 5px;
}

.contact-temp__sec .phone__img {
	width: 35px;
	height: 35px;
}
.contact-temp__sec .tel__num ,
.contact-temp__sec .tel__text{
	text-align: left;
}

.contact-temp__sec .tel__num {
	margin-bottom: 4px;
	font-size: 2.2em
}
.contact-temp__sec .tel__num .tel__num___img {
	width: 150px;
}
.contact-temp__sec .tel__text {
	font-size: 1.1em;
	letter-spacing: 0.09em;
}
/*----- strength -----*/
.strength__sec {
	background-image: url("../img/lp1/strength__bg.png");
}
.strength__sec .wrap{
	display: flex;
	counter-reset:number;
	flex-direction: column;
}
.strength__wrap{
	display: flex;
	padding-left: 200px;
	flex-direction: column;
	counter-increment:number;
	flex-wrap: wrap;
	position: relative;
	z-index: 1;
}
.strength__wrap:nth-of-type(2n - 1){
	margin-left: auto;
}
.strength__wrap:not(:last-of-type){
	margin-bottom: 102px;
}
.strength__wrap::before{
	content: counter(number);
	font-size: 33em;
	font-family: 'Oswald',sans-serif!important;
	-ms-font-feature-settings: "normal";
	color: #F5F6F7;
	position: absolute;
	top: -46px;
	left: 0;
	opacity: 0.33;
	z-index: -1;
}
.strength__content{
	margin-bottom: 20px;
}
.strength__caption{
	margin:-6px 20px 0 0;
	font-family: 'Oswald',sans-serif!important;
	-ms-font-feature-settings: "normal";
	font-size: 5em;
	font-weight: 800;
}
.strength__text{
	width: 274px;
	font-size: 1.6em;
	letter-spacing: 0.04em;
	line-height: 1.6;
	font-weight: bold;
}
.strength__thumbnail{
	width: 548px;
	height: 278px;
	box-shadow: 20px 20px  40px rgba(41,41,41,0.5);
}
.point__wrap{
	margin-top: 150px;
}
.point__content{
	display: flex;
	position: relative;
	padding: 60px 0;
	border:1px solid #fff;
	border-top: 0;
	align-items: center;
	justify-content: center;
}
.point__content span + br +span{
	margin-left: -8px;
	padding-left: 0;
}
.point__caption{
	display: flex;
	width: calc(100% + 2px);
	align-items: center;
	position: absolute;
	top: -0.5em;
	left: 0;
	font-family: 'Oswald',sans-serif!important;
	-ms-font-feature-settings: "normal";
	font-size: 3.2em;
	letter-spacing: 0.04em;
	white-space: nowrap;
}
.point__caption:before,
.point__caption:after {
	content: "";
	width: 100%;
	height: 1px;
	background-color: #fff;
}

.point__caption:before {
	margin-right: 24px;
}

.point__caption:after {
	margin-left: 24px;
}
.point__text{
	font-size: 2.2em;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.04em;
	line-height: 1.8;
}
/*----- works -----*/
.achievement__wrap{
	display: flex;
	margin-bottom: 120px;
}
.before__wrap{
	width: 264px;
	margin-right: 86px;
}
.after__wrap{
	width: calc(100% - 264px - 86px);
	flex-wrap: wrap;
}
.before__content {
	margin-bottom: 26px;
}
.before__case{
	display: flex;
	width: 62px;
	height: 55px;
	margin-right: 20px;
	align-items: center;
	justify-content: center;
	background-color: #fff;
	font-family: 'Oswald',sans-serif!important;
	-ms-font-feature-settings: "normal";
	font-size: 2.4em;
	font-weight: 800;
	color:#101112;
	flex-direction: column;
	letter-spacing: 0.1em;
}
.before__case span{
	margin-bottom: 4px;
	font-size: 13px;
	font-weight: bold;
}
.before__details{
	flex-wrap: wrap;
	font-size: 1.6em;
	font-weight: bold;
	margin-top: auto;
}
.before__name{
	margin-bottom: 4px;
}
.before__name,
.before__type{
	display: block;
	width:100%;
	height: 1em;
}
.after__thumbnail{
	opacity: 0;
	transition: 0.4s;
	
}
.after__thumbnail.active{
	opacity: 1;
}

.after__thumbnail{
	width: 373px;
	height: 249px;
}
.after__thumbnail:nth-of-type(2),
.after__thumbnail:nth-of-type(3){
	width: 317px;
}
.after__thumbnail{
	width: 373px;
	height: 249px;
}
.after__img{
	height: 100%;
}
.after__thumbnail:nth-of-type(2n){
	margin-left: 40px;
}
.after__thumbnail:nth-last-of-type(-n + 2):not(:nth-of-type(-n + 2)) {
	margin-top: 40px;
}
.achievement__wrap:nth-of-type(1) .after__thumbnail:not(:nth-of-type(1)){
	width: 345px;
	height: 244px;
}
.achievement__wrap:nth-of-type(1) .after__thumbnail:nth-of-type(1){
	width:100%;
	height: 410px;
}
.achievement__wrap:nth-of-type(1) .after__thumbnail:nth-of-type(2n){
	margin: 40px 40px 0 0;
}

.other__wrap{
	padding: 60px;
	text-align: center;
	border: 1px solid #fff;
}
.other__caption{
	margin-bottom: 46px;
	font-size: 2em;
	font-weight: bold;
	letter-spacing: 0.04em;
	line-height: 1.8;
}
.other__content{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.other__thumbnail{
	width: calc(25% - 18px);
	height: 153px;
	margin-bottom: 24px;
	position: relative;
}
.other__thumbnail .other__img{
	position: absolute;
	top: 0;
	left: 0;
	transition:top 0.3s , opacity 0.5s;
	opacity: 0;
}
.other__thumbnail.active .other__img{
	opacity: 1;
}
@media screen and (min-width:769px){
.other__thumbnail:nth-last-of-type(-n + 4){
	margin-bottom: 0;
}
}
/*----- flow -----*/
.flow__sec {
	background-image: url("../img/lp1/flow__bg.png");
}
.flow__sec .sec__head{
	margin-bottom: 24px;
}
.flow__list{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	counter-reset:number2;
}
.flow__item{
	width: calc(33.33333% - 40px);
	counter-increment:number2;
	position: relative;
/*	overflow: hidden;*/
}
.flow__item__area{
	height: 408px;
	padding: 40px 28px;
	background-color: #101112;
	position: absolute;
	left:0;
	top: 100%;
	z-index: 1;
	overflow: hidden;
	transition: 0.6s;
	opacity: 0;
}
.flow__item.active .flow__item__area{
	top: 0;
	opacity: 1;
}
.flow__item__area::after{
	content: counter(number2);
	font-family: 'Oswald',sans-serif!important;
	-ms-font-feature-settings: "normal";
	font-size: 17.4em;
	position: absolute;
	right: 0;
	bottom: -8px;
	z-index: -1;
	opacity: 0.3;
}

.flow__item:nth-child(1) .flow__item__area,
.flow__item:nth-child(4) .flow__item__area{
	margin-top: 80px;
}
.flow__item:nth-child(2) .flow__item__area,
.flow__item:nth-child(5) .flow__item__area{
	margin: 40px 0;
}

.flow__item__area,
.flow__thumbnail{
	box-shadow: 20px  20px 40px rgba(41,41,41,0.5);
}
.flow__thumbnail{
	margin-bottom: 28px;
}
.flow__caption{
	margin-bottom: 16px;
	font-size: 1.8em;
	font-weight: bold;
	letter-spacing: 0.02em;
}
.flow__text{
	font-size: 1.3em;
	line-height: 1.7;
}
/*----- voice -----*/
.voice__sec .voice__wap:not(:last-of-type){
	margin-bottom: 100px;
}
.voice__sec .voice__wap:nth-of-type(2n){
	flex-direction: row-reverse;
}
.voice__thumbnail{
	width: 500px;
	height: 464px;
	margin-right: 80px;
}
.voice__sec .voice__wap:nth-of-type(2n) .voice__thumbnail{
	margin:  0 0 0 80px;
}
.voice__content{
	width:500px;
}
.voice__content{
	letter-spacing: 0.04em;
}
.voice__caption{
	font-size: 2.2em;
	font-weight: bold;
	line-height: 1.8;
	margin-bottom: 56px;
	padding-bottom: 28px;
	border-bottom: 1px solid #fff;
}
.voice__details{
	margin-top: 20px;
	font-size: 14px;
}
.voice__text{
	font-size: 1.5em;
	line-height: 2;
}
/*----- contact -----*/
.contact__sec{
	background-image: url("../img/lp1/contact__bg.png");
}
.contact__sec .sec__head{
	margin-bottom: 54px;
}
.contact2__list{
	display: flex;
	margin-bottom: 72px;
	justify-content: space-between;
}
.contact2__item{
	display: flex;
	width:calc(50% - 40px);
	padding: 40px 0 ;
	text-align: center;
	flex-direction: column;
}
.contact2__item,
.contact__wrap{
	border: 1px solid #fff;
}
.contact2__caption{
	margin-bottom: 32px;
	font-size: 2.1em;
	font-weight: bold;
}
.contact2__item .tel__contenet{
	display: flex;
	flex-direction:column; 
	align-items: center;
}
.contact2__item .tel__num {
	margin-bottom: 16px;
}
.contact2__item .tel__num div{
	display: flex;
	align-items: center;
}
.contact2__item .tel__num___img {
	width: 180px;
}
.contact2__item a{
	margin: auto 0;
}
.contact2__item .phone__img{
	width: 42px;
	height: 42px;
	margin-right: 8px;
}
.contact2__item .tel__text{
	font-size: 1.3em;
	line-height: 1.8;
	text-align: left;
}
.line__img{
	width: 212px;
	transition: 0.4s;
}
.line__img:hover{
	opacity: 0.5;
}
.contact__wrap{
	padding: 60px 70px;
}
.contact__caption{
	margin-bottom: 32px;
	font-size: 2.1em;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.1em;
}
.contact__text{
	margin-bottom: 54px;
	font-size: 1.3em;
	text-align: center;
	letter-spacing: 0.01em;
	line-height: 1.8;
}
.form__wrap{
	display: flex;
	margin-bottom: 40px;
	align-items: center;
}
.form__wrap:last-of-type{
	margin:12px 0 64px;
	align-items: flex-start;
	
}
.form__caption{
	display: flex;
	width:  220px;
	margin-right: 20px;
	justify-content: space-between;
	align-items: center;
	font-size: 1.6em;
	font-weight: bold;
}
.form__wrap:last-of-type .form__caption{
	margin-top: 24px;
}
.form__caption::after{
	content: '必須';
	padding: 4px;
	font-size: 11px;
	border: 1px solid #fff;
}
.fotm__input{
		width:calc(100% - 240px);
	overflow: hidden;
}
.fotm__input input,
.fotm__input textarea{
	width: 100%;
	height: 62px;
	padding: 20px;
	font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, sans-serif;
	background-color: rgba(255,255,255,0.5);
	font-size: 1.6em;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1.8;
}
.fotm__input textarea{
	height: 340px;
	resize: none;
	color: #fff;
}
.form__submit{
	display: flex;
	width: 270px;
	height: 56px;
	margin: 72px auto 0;
	align-items: center;
	justify-content: center;
	font-size: 1.6em;
	letter-spacing: 0.1em;
	font-weight: bold;
	color: #fff;
	background-color: #0043F8;
	cursor: pointer;
	transition:opacity 0.4s;
}
.form__submit:hover{
	opacity: 0.4;
}
span.wpcf7-not-valid-tip {
	margin-top: 8px;
	display: inline-block;
	color: #ff0000;
	font-size: 12px;
	font-weight: bold;
}	
/*----- company -----*/
.company__sec{
	background-color: rgba(23,35,44,0.9);
}
.company__table{
	width: 764px;
	margin:80px 0 0 auto;
}
.company__table tr{
	display: block;
	padding: 36px 0 32px;
	border-top: 1px solid #fff;
	font-size: 1.6em;
	line-height: 1.8;
}
.company__tbody tr:last-of-type{
	border-bottom: 1px solid #fff;
}
.company__table th{
	width: 150px;
	margin-right: 40px;
	font-weight: bold;
	text-align: left;
}
footer{
	padding: 26px 0;
}
.copyright{
	font-family: 'Oswald',sans-serif!important;
	-ms-font-feature-settings: "normal";
	text-align: right;
	letter-spacing: 0.1em;
}
@media screen and (min-width:769px) {
	.sp{
	display: none!important;
}
}
@media screen and (max-width:768px) {
	.sp{
	display: block!important;
	}
	.pc{
		display: none!important;
	}
	
/*----- temp -----*/

[class*="__sec"]{
	padding: 70px 20px;
}
.sec__head{
	margin-bottom: 48px;
}
.sec__title{
	margin-bottom: 18px;
	font-size: 3.6em;
}
.sec__title-sub{
	padding-bottom: 16px;
	font-size:1.4em;
	line-height: 1.8;
}
.sec__text{
	margin-top: 32px;
	font-size: 1.4em;
}
.sec__title-sub::after,
.contact-temp__sec .sec__text::before{
	width: 26px;
	height: 4px;
}
.sec__title-bg{
	font-size: 9.8em;
	top: -10px;
	left: 0vw;
}
	
/*----- header -----*/
header {
	padding: 12px 10px;
}
h1 small {
	display: block;
	font-size: 1em;
	margin-bottom: 6px;
}
.header__logo {
	width: 148px;
}
.contact3__item:first-of-type, .contact3__item a {
	min-width: 80px;
	height: 36px;
	padding: 3px 10px 0;
}
.contact3__item a {
	font-size: 1.5em;
}
.contact3__item a:hover {
	background-color: inherit;
	color: inherit;
}
/*----- fv -----*/
.fv__sec {
	background-image: url("../img/lp1/fv-pc.png");
}

.fv__sec .wrap{
	padding: 0 20px;
	position: relative;
	z-index: 2;
}
.catchcopy__wrap{
	margin-bottom: 36px;
}
.fv__sec .catchcopy{
	font-size:11.7vw;
	letter-spacing: -0.02em;
	white-space: nowrap;
}
.catchcopy-sub{
	margin-top: 14px;
	font-size: 1.4em;
	line-height: 1.8;
}
.catchcopy__list{
	flex-direction: column;
}
.catchcopy__item{
	height: 28px;
	margin-right: auto;
	font-size: 1.7em;
}
.catchcopy__item:not(:last-of-type) {
	margin:0 auto 14px 0;
}
.catchcopy__text{
	font-size: 1.4em;
}
/*----- toowner -----*/

.toowner__bg__thumbnail{
	width: 100vw;
	min-width: 0;
	height: 274px;
	top: calc(100% + 40px);
	left: -20px;
}
.worry__list{
	margin-top: 86px;
	}
.worry__item{
	font-size: 1.4em;
	position: relative;
	z-index: 2;
}
.worry__item:not(:last-of-type){
	margin-bottom: 18px;
} 
.worry__item::before{
	margin-right: 10px;
}
.arrow__down__img{
	display: block;
	width: 36px;
	margin: 88px auto 30px;
}
	
	.comment__wrap{
		padding: 0 20px;
		position: relative;
	}
.comment__thumbnail{
	width:calc(100% - 40px);
	height: auto;
	margin:0;
	position: absolute;
	top: 124px;
	left: 20px;
}
.comment__content{
	display: flex;
	width: 100%;
	min-width: 0;
	justify-content: space-between;
}
.comment__caption{
	margin:0 0 73.06666vw;
	font-size: 2.4em;
	white-space: nowrap;
	letter-spacing: -0.02em;
}
	.comment__caption span, .point__text span{
		padding: 0 3px;
	}
.comment__text{
	font-size: 1.4em;

}
.comment__name{
	margin-top: 18px;
	font-size-adjust: 15px;
}
/*----- service -----*/
.service__sec {
	background-image: url(../img/lp1/service__bg.png);
}
.service__sec .wrap{
	flex-direction: column;
	justify-content: flex-start
}
.service__sec .sec__head{
	width: 100%;;
}

.service__img__wrap{
	width:100%;
}
.service__img{
	width: calc(50% - 10px);
}
.service__img:nth-child(2n){
	margin-left: 20px;
}
.service__img:nth-child(2n){
	margin-left: 20px;
}
.service__img:not(:nth-last-child(-n + 2)){
	margin-bottom: 20px;
}

/*----- contact-temp -----*/
.contact-temp__sec .sec__head{
	margin-bottom: 30px;
}
.contact-temp__sec .sec__title{
	margin-bottom: 8px;
}
.contact-temp__sec .sec__text{
	font-size: 1.4em;
	line-height: 1.8;
	padding-top: 20px;
}

.contact-temp__sec .contact3__list{
	flex-direction: column;
}
.contact-temp__sec .contact3__item:first-of-type,
.contact-temp__sec .contact3__item a{
	width: 100%;
	min-width: 0;
	height: 58px;
	padding: 8px 0;
}
	.contact3__item.sp a{
		font-size: 1em;
	}
.contact-temp__sec .contact3__item:not(:last-of-type){
	margin: 0 0 20px;
}
	.contact-temp__sec .tel__num___img{
		
	}
/*----- strength -----*/
.strength__sec {
	background-image: url("../img/lp1/strength__bg.png");
}
.strength__wrap{
	display: flex;
	padding-left: 80px;
	justify-content: center;
	}
.strength__wrap:nth-of-type(2n - 1){
	margin-left: 0;
}
.strength__wrap:not(:last-of-type){
	margin-bottom: 80px;
}
	.strength__content{
		flex-direction: column;
	}
.strength__wrap::before{
	font-size: 21.6em;
	top:auto;
	left: 0;
	bottom: auto;
	opacity: 0.33;
}
.strength__caption{
	margin:0 0 20px;
	font-size: 3.2em;
}
.strength__text{
	width: 100%;
	font-size: 1.4em;
}
.strength__thumbnail{
	width: 100%;
	height: auto;
	box-shadow: 20px 20px  40px rgba(41,41,41,0.5)
	}
	.point__wrap{
		margin-top: 0;
	}
.point__content{
	padding: 32px 0 24px;
	border:1px solid #fff;
	border-top: 0;
	align-items: center;
	justify-content: center;
}
	.point__content span{
	margin-left: 0;
	padding: 0;
}
.point__caption{
	font-size: 2.4em;
}

.point__caption:before {
	margin-right: 16px;
}

.point__caption:after {
	margin-left:16px;
}
.point__text{
	font-size: 1.5em;
}
/*----- works -----*/
.achievement__wrap{
	margin-bottom: 70px;
	flex-direction: column;
}
.before__wrap{
	display: flex;
	width: 100%;
	margin: 0 0 20px;
}
.after__wrap{
	width: 100%;
}
.before__content {
	width: calc(100% - 142px);
	flex-direction: column;
	margin: 0;
}
.before__case{
	width: 42px;
	height: 39px;
	margin:0 0 14px 0;
	font-size: 1.9em;

}
.before__case span{
	margin-bottom: 4px;
	font-size: 11px;
	font-weight: bold;
}
.before__details{
	flex-direction: column;
	font-size: 1.3em;
	margin-top: auto;
}
.before__name{
	margin-bottom: 4px;
}

	.before__thumbnail{
		width: 142px;
		height: 90px;
	}
	
.after__thumbnail{
	width: 100%;
	height: auto;
}
.after__thumbnail:nth-of-type(n),
	.after__thumbnail:nth-last-of-type(-n + 2):not(:nth-of-type(-n + 2)),
	.achievement__wrap:nth-of-type(1) .after__thumbnail:nth-of-type(2n){
	margin: 0;
}
	.after__thumbnail:nth-of-type(1){
	margin-bottom: 14px;
}
	.after__thumbnail:nth-of-type(4){
	margin-top: 14px!important;
}
	.achievement__wrap:nth-of-type(1) .after__thumbnail:not(:nth-of-type(1)){
	width: calc(50% - 7px);
	height: auto;
}
	.after__thumbnail:nth-of-type(2),
	.achievement__wrap:nth-of-type(3) .after__thumbnail:nth-of-type(3){
	width: 38.6666667vw;
	height: 30.4vw;
	}
	.after__thumbnail:nth-of-type(3),
		.achievement__wrap:nth-of-type(3) .after__thumbnail:nth-of-type(2){
	width: 46.9333333vw;
	height: 30.4vw;
}
	.achievement__wrap:nth-of-type(2) .after__thumbnail:nth-of-type(3),
	.achievement__wrap:nth-of-type(3) .after__thumbnail:nth-of-type(2) {
	width: calc(100% - 38.6666667vw - 14px);
}
	.achievement__wrap:nth-of-type(1) .after__thumbnail:nth-of-type(2n),
	.after__thumbnail:nth-of-type(2):not(:last-of-type){
		margin-right: 14px;
	}
.after__img{
	height: 100%;
}

.achievement__wrap:nth-of-type(1) .after__thumbnail:nth-of-type(1),
 .after__thumbnail:nth-of-type(1),
 .after__thumbnail:last-of-type{
	width: 100%;
	height: auto;
}

	
.other__wrap{
	padding: 36px 20px;
}
.other__caption{
	margin-bottom: 32px;
	font-size: 1.5em;
}

.other__thumbnail{
	width: calc(50% - 6px);
	margin-bottom: 12px;
}
.other__thumbnail:nth-last-of-type(-n + 2){
	margin-bottom: 0;
}
/*----- flow -----*/
.flow__sec {
	background-image: url("../img/lp1/flow__bg.png");
}
.flow__sec .sec__head{
	margin-bottom: 36px;
}
.flow__list{
	margin-bottom: 60px;
	padding: 0 20px;
}
.flow__item{
	width: 100%;
}
.flow__item__area{
	height: auto;;
	padding: 28px 24px;
}
.flow__item__area::after{
	font-size: 13.2em;
}

.flow__item:nth-child(1) .flow__item__area,
.flow__item:nth-child(4) .flow__item__area,
.flow__item:nth-child(2) .flow__item__area,
.flow__item:nth-child(5) .flow__item__area{
	margin: 0;
}
.flow__item:not(:last-of-type){
	margin-bottom: 40px;
}

.flow__item__area,
.flow__thumbnail{
	box-shadow: 20px  20px 40px rgba(41,41,41,0.5);
}
.flow__thumbnail{
	margin-bottom: 20px;
}
.flow__caption{
	margin-bottom: 12px;
	font-size: 1.6em;
}
.flow__text{
	font-size: 1.2em;
}
/*----- voice -----*/
.voice__wap{
	position: relative;
}
.voice__sec .voice__wap:not(:last-of-type){
	margin-bottom: 64px;
}
.voice__sec .voice__wap:nth-of-type(2n){
	flex-direction: row;
}
.voice__thumbnail,
	.voice__sec .voice__wap:nth-of-type(2n) .voice__thumbnail{
	width: 100%;
	height: 82.66666vw;
	margin: 0 0 32px;
	position: absolute;
	top: 178px;
	left:0;
}
.voice__content{
	width:100%;
}
.voice__caption{
	font-size: 1.7em;
	margin-bottom: 97vw;
	padding-bottom: 20px;
}
.voice__details{
	margin-top: 24px;
	font-size: 12px;
}
.voice__text{
	font-size: 1.3em;
}
/*----- contact -----*/
.contact__sec{
	background-image: url("../img/lp1/contact__bg.png");
}
.contact__sec .sec__head{
	margin-bottom: 36px;
}
.contact2__list{
	flex-direction: column;
	margin-bottom: 20px;
}
.contact2__item{
	width:100%;
	padding: 28px 0 ;
}
.contact2__item:first-of-type{
	margin-bottom: 20px;
}
.contact2__caption{
	margin-bottom: 12px;
	font-size:1.5em;
}
.contact2__item .tel__num{
	margin-bottom: 12px;
}
	.contact2__item .tel__num .sp .call{
	display: flex;
	align-items: center;
}
.contact2__item .phone__img{
	width: 35px;
	height: 35px;
}
	.contact2__item .tel__num___img {
	width: 180px;
}
.contact2__item .tel__text{
	font-size: 1.2em;
	text-align: center;
}
.line__img{
	width: 104px;
}
.contact__wrap{
	padding: 36px 20px;
}
.contact__caption{
	margin-bottom: 18px;
	font-size: 1.5em;
}
.contact__text{
	font-size: 1.2em;
}
.form__wrap{
	margin-bottom: 32px;
	flex-direction: column;
}
.form__wrap:last-of-type{
	margin:0 0 36px;
	
}
.form__caption{
	display: flex;
	width:  100%;
	margin:0 0 12px;
	font-size: 1.4em;
	justify-content:flex-start;
}
.form__wrap:last-of-type .form__caption{
	margin-top: 0;
}
.form__caption::after{
	margin-left: 12px;
}
.fotm__input{
		width:100%;
}
.fotm__input input,
.fotm__input textarea{
	height: 48px;
	padding: 16px 8px;
	font-size: 1.4em;
}
.fotm__input textarea{
	height: 295px;
}
.form__submit{
	width: 100%;
	margin: 56px auto 0;
	font-size: 1.4em;
}
/*----- company -----*/
.company__sec{
	background-color: rgba(23,35,44,0.9);
}
	.company__sec .wrap {
		flex-direction: column;
	}
.company__table{
	width: 100%;
	margin:0;
}
.company__table tr{
	padding: 24px 0 20px;
	font-size: 1.4em;
}

.company__table th,
.company__table td{
	display: block;
	width: 100%;
	}
	.company__table th{
	margin: 0 0 4px;
}
footer{
	padding: 36px 0;
}
.copyright{
	text-align: center;
}
}