.header-logo{
	display: none;
}
.head-right{
	display: none;
}
.head-inner{
	padding: 0;
}
img{
	vertical-align: bottom;
}
svg {
    width: 100%;
    height: auto;
  }




@keyframes anmstpa{
	0%{transform:rotate(-2.5deg);}
	20%{transform:rotate(2.5deg);}
	40%{transform:rotate(-2.5deg);}
	60%{transform:rotate(2.5deg);}
	80%{transform:rotate(-2.5deg);}
	100%{transform:rotate(2.5deg);}
}
@keyframes bar{
	0%{width: 0;}
	100%{width: 100%;}
}

.load-bar{
	margin-bottom: 5.5em;
	position: relative;
	height: 8px;
	background-color: #fff;
	display: block;
	width: 100%;
}
.load-bar_inner{
	height: 100%;
	position: absolute;
	right: 0;
	background-color: #ff8a00;
	animation: bar 3s infinite;
}

.anmstp{
	display:inline-block;
	animation: anmstpa 3s infinite;
	animation-timing-function: steps(10, end);
	position: absolute;
	left: 0;
	transform: translateX(-100%);
	-webkit-transform: translateX(-100%);
	-ms-transform: translateX(-100%);
}

.fix{
	overflow: hidden;
}
#loading{
	position: fixed;
	padding: 12vw;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background-color: #f8f4f2;
	width: 100vw;
	height: 100vh;
	transition: all 1s; /*ローディングにかかる時間*/
	inset: 0;
	z-index: 90;
}
#loading figure img{
	max-width: 100%;
}
#loading .load-bar_inner img{
	max-width: 30vw;
}
#loading .logo{
	margin-bottom: 5.5em;
}
#loading img{
	transition: .1s;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}
#loading figure img{
	transition: .1s;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
}
#loading.loaded {
	opacity: 0;
	visibility: hidden;
}

body  #content{
	transition: 1s;
	opacity: 1;
}
body.fix #content{
	opacity: 0;
}

@media screen and (min-width: 750px) {
	#loading .load-bar img{
		width: 210px;
	}
}


.main-copy{
	left: 0;
	right: 0;
	margin: auto;
	position: absolute;
	margin-top: 18vw;
}
.main-copy p{
	line-height: 1.5;
	text-align: center;
}
.main-copy span:nth-child(n+2){
	margin-top: 0.25em;
}
.main-copy span{
	color: #fff;
	border-radius: 4px;
	padding-left: 0.5em;
	line-height: 1.125;
	background-color: #ff8a00;
	display: inline-block;
	font-size: 2em;
	font-weight: 700;
	padding-bottom: 0.125em;
}
.index-main-visual{
	position: relative;
	width: 100%;
	overflow: hidden;
}
.index-main-visual:before{
	content: "";
	display: block;
	width:0;
	height:0;
	border-style:solid;
	border-width: 0 50vw 18vw 50vw;
	border-color: transparent transparent #fff transparent;
	position: absolute;
	bottom: -1px;
	left: 0;
	right: 0;
	margin: auto;
}
.index-main-visual .main-img img{
	width: 100%;
}
.index-main-visual .main-img img.pc-img{
	display: none;
}
.head-logo{
	display: inline-block;
	text-align: center;
	left: 0;
	right: 0;
	margin: auto;
	position: absolute;
	bottom: 0;
	width: 42vw;
}
.head-logo img{
	width: 100%;
}
.head-navlist{
	display: none;
}
@media screen and (min-width: 750px) {
	.index-main-visual .main-img img.pc-img{
		display: block;
	}
	.index-main-visual .main-img img.sp-img{
		display: none;
	}
	.main-copy{
		margin-top: 5vw;
	}
	.main-copy span{
		font-size: 3.375em;
	}
	.index-main-visual:before{
		border-width: 0 50vw 140px 50vw;
	}
	.head-logo{
		width: auto;
		left: 0;
		right: 0;
		margin: auto;
		text-align: center;
		bottom: 30px;
	}
	.head-logo img{
		width: auto;
		max-width: 100%;
	}
	.head-navlist{
		text-align: center;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.head-navlist_item{
		width: calc(100% / 6);
	}
	.head-navlist_item:nth-child(n+2){
		border-left: 2px dotted #9a9a9a;
	}
	.head-navlist_item a{
		margin: auto;
		display: block;
		width: calc(100% - 4px);
		border-radius: 4px;
	}
	.head-navlist_item a:hover{
		background-color: #f3e8e1;
	}
}
@media screen and (min-width: 1120px) {
	.head-navlist{
		text-align: center;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
}




.about-section{
	position: relative;
	padding-top: 14vw;
	padding-bottom: 5vw;
}
.about-section:before{
	content: "";
	display: block;
	width: 50%;
	height: 65%;
	background-image: url(../img/index/about-bg.png);
	background-position: top left;
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	top: 0;
	z-index: -1;
}
.about-section .content-title01{
	margin-bottom: 2.5em;
}
.about-section .content-title02{
	margin-bottom: 1.5em;
	letter-spacing: 0.2em;
}
.about-section .content-inner{
	display: flex;
	flex-wrap: wrap;
	gap: 8vw;
}
.about-section .content-inner{
	display: flex;
	flex-wrap: wrap;
	gap: 8vw;
}
.about-section .content-inner .about-txt .txt-button{
	margin-top: 2.5em;
}
.about-section .content-inner .about-img{
	width: 100%;
}
.about-section .content-inner .about-img img{
	width: 100%;
}
@media screen and (min-width: 750px) {
	.about-section{
		padding-top: 140px;
		padding-bottom: 80px;
	}
	.about-section:before{
		height: 100%;
		width: 30%;
	}
	.about-section .content-inner{
		position: relative;
		gap: 80px;
	}
	.about-section .content-inner .about-txt{
		width: calc(50% - 80px);
	}
	.about-section .content-inner .about-img{
		bottom: 0;
		right: 0;
		width: calc(50% + 30px);
		position: absolute;
	}
	.about-section .content-inner .about-img img{
		width: 100%;
	}
}


.service-section{
	padding-top: 9vw;
	padding-bottom: 7vw;
	background: linear-gradient(180deg, #fff 0%, #fff 15%, #f8f4f2 15%, #f8f4f2 100%);
}
.service-section .content-title05{
	margin-bottom: 2.5em;
}
.service-list{
	gap: 6vw;
	display: flex;
	flex-wrap: wrap;
}
.service-list_txt{
background-color: #fff;
}
.service-list_item{
}
.service-list figure{
	position: relative;
}
.service-list .list-nom{
	position: absolute;
	left: 1em;
	top: -0.5em;
}
.service-list .content-title03{
	margin-bottom: 1.5em;
	padding-top: 1.75em;
}
.service-list .list-nom span,
.service-list .list-nom strong{
	display: block;
	line-height: 1;
}
.service-list .list-nom span{
	font-size: 1.25em;
}
.service-list .list-nom strong{
	font-size: 3.875em;
	color: #ff8a00;
}
.service-list_txt{
	margin-top: -1vw;
	position: relative;
	padding: 0 4vw 4vw;
}
.service-list_txt .arow{
	position: absolute;
	background-color: #fff;
	display: block;
	width: 3.125em;
	height: 3.125em;
	border-radius: 50%;
	border: solid 2px;
	top: 0;
	right: 2vw;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
}
.service-list_txt .arow:before{
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	width: 0.375em;
	height: 0.375em;
	border-right: solid 2px;
	border-top: 2px solid;
	display: block;
	-moz-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
}

/* バナー部分 */
.service-bana{
	justify-content: center;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	gap: 4vw;
}
.service-bana h4{
	font-weight: 700;
	line-height: 2;
}
.service-bana h4 span{
	font-size: 1.3em;
}
.service-bana h4 strong{
	background-color: #ff8a00;
	border-radius: 4px;
	color: #fff;
}
.service-bana{
	margin-top: 8vw;
	position: relative;
	z-index: 2;
}
@media screen and (min-width: 750px) {
	.service-section{
		padding-top: 90px;
		padding-bottom: 70px;
		background: linear-gradient(180deg, #fff 0%, #fff 40%, #f8f4f2 40%, #f8f4f2 100%);
	}
	.service-list{
		gap: 20px;
	}
	.service-list_txt{
		padding: 0 40px 40px;
	}
	.service-list_item a:hover figure svg{
		opacity: .5;
	}
	.service-list_item a div h3,
	.service-list_item a div p{transition: .3s;}
	.service-list_item a:hover div{
		color: #ff8a00;
	}
	.service-list_item a:hover .arow {
		border-color: #ff8a00;
		background-color: #ff8a00;
		width: 3.75em;
		height: 3.75em;
		right: calc(20px - (0.625em / 2 ));
	}
	.service-list_item a:hover .arow:before{
		border-color: #fff;
	}
	.service-list_item{
		background-color: #fff;
		width: calc((100% - 20px) / 2);
	}
	.service-list_txt{
	background-color: #fff;
		margin-top: 0;
	}
	.service-list_txt .arow{
		transition: 0.3s;
		right: 20px;
	}

	.service-bana{
		margin-top: 60px;
		align-items: center;
		gap: 40px;
	}
	.service-bana h4 span{
		font-size: 2em;
	}
}
@media screen and (min-width: 1024px) {
	.service-list_item{
		width: calc((100% - 40px) / 3);
	}
}


/* work */
.work-section{
	overflow: hidden;
	padding-top: 12vw;
	padding-bottom: 22vw;
	background-color: #f8f4f2;
	background-image: url(../img/index/service-bg.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: top center;
}
.work-section .title-wrap{
	padding-top: 1.25em;
	padding-bottom: 1.25em;
	background-image: url(../img/index/works-title_bg.png);
	background-position: center;
	background-repeat: no-repeat;
}

.work-section .content-title01{
	text-align: center;
}
.work-section .content-title01:before{
	background-color: #fff;
	left: 0;
	right: 0;
	margin: auto;
}
.work-section .work-list{
	margin-bottom: 4vw;
}
.work-section .work-list_item figure{
	position: relative;
}
.work-section .work-list_item figure .cate{
	position: absolute;
	left: 1em;
	bottom: 1em;
	border: solid 1px ;
	background-color: #fff;
	padding: 0.25em 0.5em;
}
.work-section .work-list .content-title04{
	margin-top: 1em;
	margin-bottom: 0.75em;
}
.work-section .txt-button a{
	margin-left: auto;
	margin-right: auto;
}
.work-inner{
	position: relative;
}
.arow-prev,
.arow-next{
	top: 0;
	bottom: 0;
	margin: auto;
	display: block;
	width: 3.125em;
	height: 3.125em;
	border-radius: 50%;
	background-color: #fff;
	border: solid 2px;
	position: absolute;
	z-index: 2;
	cursor: pointer;
}
.arow-prev:before,
.arow-next:before{
	display: block;
	content: "";
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	width: 0.375em;
	height: 0.375em;
	border-right: solid 2px;
	border-top: solid 2px;
	position: absolute;
}
.arow-prev{
	transform: translateX(-25%);
	-webkit-transform: translateX(-25%);
	-ms-transform: translateX(-25%);
}
.arow-next{
	right: 0;
	transform: translateX(25%);
	-webkit-transform: translateX(25%);
	-ms-transform: translateX(25%);
}
.arow-prev:before{
	-moz-transform: rotate(-135deg);
	-webkit-transform: rotate(-135deg);
	-o-transform: rotate(-135deg);
	-ms-transform: rotate(-135deg);
}
.arow-next:before{
	-moz-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
}
@media screen and (min-width: 750px) {
	.work-section{
		padding-top: 120px;
		padding-bottom: 230px;
	}
	.work-list_item a:hover{
		opacity: .7;
	}
	.work-section .work-list{
		margin-top: 40px;
	}
	.arow-next,
	.arow-prev{
		transition: .3s;
	}
	.arow-prev{
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
	}
	.arow-next{
		transform: translateX(50%);
		-webkit-transform: translateX(50%);
		-ms-transform: translateX(50%);
	}
	.arow-prev:hover,
	.arow-next:hover{
		color: #fff;
		border-color: #ff8a00;
		background-color: #ff8a00;
	}
}


/* news-section */
.news-section{
	padding-top: 9vw;
	padding-bottom: 14vw;
	position: relative;
}
.news-top{
	width: 58%;
	right: 0;
	top: 0;
	position: absolute;
	transform: translateY(-40%);
	-webkit-transform: translateY(-40%);
	-ms-transform: translateY(-40%);
}
.news-top img{
	max-width: 100%;
}
.news-section .content-title05{
	margin-bottom: 2.5em;
}
.news-section .news-nav{
	display: flex;
	gap: 2em;
	margin-bottom: 2em;
}
.news-section .news-nav_item{
	cursor: pointer;
	border-radius: 2em;
	font-size: 0.875em;
	font-weight: 600;
	padding: 0.25em 0.5em;
}
.news-section .tab-item {
	display: none;
	opacity: 0;
	transition: opacity 0.5s ease;
	position: absolute;
}
.news-section .tab-item.show{
	display: block;
}
.news-section .tab-item.fade-in {
	opacity: 1;
	position: relative;
}
.news-section .news-nav_item.on{
	color: #fff;
	background-color: #ff8a00;
}

.news-section .news-content{
	border-left: solid #c1bdb9 3px;
}
.news-list{
	position: relative;
}
.news-list_item{
	border-top: solid 1px #f3e8e1;
}
.news-list_item:last-child{
	border-bottom: solid 1px #f3e8e1;
}
.news-list_item a{
	padding-top: 10px;
	padding-bottom: 10px;
	position: relative;
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 5vw;
}
.news-list_item figure{
	width: 100%;
}
.news-list_item figure img{
	width: 100%;
	height: auto;
}
.news-list_item p{
	display: flex;
	gap: 1em;
	align-items: center;
	margin-bottom: 0.5em;
}
.news-list_item span{
	display: block;
}
.news-list_item .data{
	font-weight: 600;
	color: #a6a6a6;
}
.news-list_item .cate{
	background-color: #fff;
	border: solid 1px;
	font-weight: 500;
	padding: 0 0.5em;
}
.news-list_item h3{
	line-height: 1.75;
}
.news-section .txt-button{
	margin-top: 2.5em;
}
@media screen and (min-width: 750px) {
	.news-section{
		padding-top: 90px;
		padding-bottom: 140px;
	}
	.news-section .content-title05{
		margin-bottom: 3.75em;
	}
	.news-list_item a{
		gap: 40px;
	}
	.news-list_item figure{
		width: 220px;
		height: 220px;
		position: relative;
	}
	.news-list_item figure img{
		width: 100%;
		height: 100%;
		position: absolute;
		object-fit: cover;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		margin: auto;
	}
	.news-list_item .news-list_txt{
		width: calc(100% - 260px);
	}
	.news-list_item a:before{
		content: "";
		z-index: -1;
		display: block;
		transition: .3s;
		background-color: #f8f4f2;
		position: absolute;
		top: 0;
		left: 0;
		width: 0;
		height: 100%;
		opacity: 0;
	}
	.news-list_item a:hover::before{
		opacity: 1;
		width: 100%;
	}
}

@media screen and (min-width: 1224px) {
	.news-top{
		width: auto;
	}
}


.pro-section{
	padding-top: 80px;
	padding-bottom: 14vw;
	background-color: #f8f4f2;
}
.pro-section .content-title05{
	margin-bottom: 2.5em;
}
.pro-section .txt-button{
	margin-top: 3em;
}
.pro-section .txt-button a{
	margin: auto;
}
.pro-list{
	gap: 8vw;
	display: flex;
	flex-wrap: wrap;
}
.pro-list_item{
	width: 100%;
}
.pro-list_item .content-title07{
	margin-top: 1em;
}
.pro-list figure{
	position: relative;
}
.pro-list .list-nom{
	position: absolute;
	left: 1em;
	top: -0.5em;
}
.pro-list .content-title03{
	margin-bottom: 1.5em;
	padding-top: 1.75em;
}
.pro-list .list-nom span,
.pro-list .list-nom strong{
	display: block;
	line-height: 1;
}
.pro-list .list-nom span{
	font-size: 1.25em;
}
.pro-list .list-nom strong{
	font-size: 3.875em;
	color: #ff8a00;
}
.pro-list_txt{
	position: relative;
}
.pro-list_txt .arow{
	position: absolute;
	background-color: #fff;
	display: block;
	width: 3.125em;
	height: 3.125em;
	border-radius: 50%;
	border: solid 2px;
	top: 0;
	right: 2vw;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
}
.pro-list_txt .arow:before{
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	width: 0.375em;
	height: 0.375em;
	border-right: solid 2px;
	border-top: 2px solid;
	display: block;
	-moz-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
}

@media screen and (min-width: 750px) {
	.pro-section{
		padding-top: 90px;
		padding-bottom: 140px;
	}
	.pro-list{
		gap: 30px;
	}
	.pro-list_item{
		width: calc((100% - 60px) / 2);
	}
}
@media screen and (min-width: 1024px) {
	.pro-list{
		gap: 50px;
	}
	.pro-list_item{
		width: calc((100% - 100px) / 3);
	}
}



/* 対応地域 */
.area-section{
	padding-top: 16vw;
	padding-bottom: 25vw;
}
.area-section .area-inner{
	display: flex;
	flex-wrap: wrap;
	gap: 5vw;
}
.area-section .area-inner figure,
.area-section .area-inner figure img{
	width: 100%;
}
.area-section .area-inner .read{
	font-weight: 700;
	line-height: 1.5;
	margin-top: 2em;
}
.area-section .area-inner .read span{
	font-size: 1.75em;
}
.area-section .area-inner .flex{
	padding: 3vw;
	border-radius: 10px;
	background-color: #f8f4f2;
	margin-top: 5vw;
	display: flex;
	flex-wrap: wrap;
	gap: 5%;
}
.area-section .area-inner .flex .area-item{
	width: 47.5%;
}
.area-section .area-inner .flex .area-item .txt-size18{
	font-weight: bold;
	padding-bottom: 0.5em;
	margin-bottom: 0.75em;
	border-bottom: solid 1px #ff8a00;
}
.area-section .area-inner .flex .area-item li{
	padding-left: 1em;
	font-weight: 500;
	position: relative;
}
.area-section .area-inner .flex .area-item li:before{
	content: "-";
	position: absolute;
	left: 0;
	color: #ff8a00;
}
.area-section .area-inner .flex .area-item li+li{
	margin-top: 0.325em;
}
@media screen and (min-width: 750px) {
	.area-section{
		padding-top: 80px;
		padding-bottom: 180px;
	}
	.area-section .area-inner{
		gap: 20px;
	}
	.area-section .area-inner .area-list{
		width: calc(50% - 10px);
	}
	.area-section .area-inner figure{
		width: calc(50% - 10px);
	}
	.area-section .area-inner .flex{
		margin-top: 40px;
		gap: 15%;
		padding: 20px 40px;
	}
	.area-section .area-inner .flex .area-item{
		width: 42.5%;
	}
}
@media screen and (min-width: 1024px) {
	.area-section .area-inner{
		gap: 40px;
	}
	.area-section .area-inner .area-list{
		width: calc(100% - 520px);
	}
	.area-section .area-inner figure{
		width: auto;
	}
}