@import url('https://fonts.googleapis.com/css2?family=Geo:ital@0;1&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400;500;700&display=swap');

@charset "utf-8";
/*font-size: max(1vw,1.2rem); 基本1vw、最小1.2remの場合*/

/* TOP
-----------------------------------*/
body{
	/*background-image: linear-gradient(to bottom right in oklab, #05b0ff 0%, #0c78ff 50%, #162fff 100%);*/
	background-color: #FFF;
}

/* MainVisual
-----------------------------------*/
#top{
	position: relative;
	/*z-index: 1;*/
}
#top #mainVisual{
	margin-top: 80px;
	position: relative;
	height: 854px;
}
#top #mainVisual:after{
	content: "";
	width: 1px;
	height: 224px;
	background: #E2041B;
	position: absolute;
	left: 50%;
}
#top #mainVisual:after{
	bottom: 0;
}
#top #mainVisual h1{
	text-align: center;
	max-width: 750px;
	width: 100%;
	margin: 0 auto;
	padding-top: 220px;
	padding-left: 30px;
	max-width: 780px;
	opacity: 0;
	transition: opacity 0.7s cubic-bezier(0.445, 0.05, 0.55, 0.95) 0.5s;
}
#top #mainVisual.is-inview h1{
	opacity: 1;
}
#top #mainVisual h1 span{
	display: block;
	font-weight: bold;
	font-size: 16px;
	max-width: 460px;
	width: 100%;
	margin: 37px auto 0 auto;
	border-radius: 5px;
	color: #E2041B;
	background: transparent;
	line-height: 50px;
	transition: color 0.4s, background 0.4s;
	transition-delay: 0.7s;
}
#top #mainVisual.is-inview h1 span{
	color: #fff;
	background: #E2041B;
}
#top #mainVisual h1 path{
	transition: fill 0.4s;
	fill: transparent;
	transition-delay: 0.7s;
}
#top #mainVisual.is-inview h1 path{
	fill: #E2041B;
}
#top #mainVisual .bnr{
	max-width: 270px;
	width: 100%;
	position: absolute;
	bottom: 60px;
	right: 90px;
}
#top #mainVisual .bnr .switch{
	display: none;
}
#top #mainVisual .bnr a{
	aspect-ratio: 270 / 270;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background: rgba(226, 4, 27, 0.95);
	color: #FFF;
	border-radius: 50%;
	text-align: center;
	transition: opacity 0.2s;
	opacity: 1;
}
#top #mainVisual .bnr a:hover{
	opacity: 0.8;
}
#top #mainVisual .bnr a .p01{
	font-size: 12px;
	line-height: 17px;
	margin-bottom: 20px;
}
#top #mainVisual .bnr a .icon{
	max-width: 64px;
	margin: 0 auto;
	color: #FFF;
}
#top #mainVisual .bnr a h3{
	font-size: 24px;
	line-height: 35px;
	margin-bottom: 25px;
	font-weight: bold;
}
#top #mainVisual .bnr a .p02{
	font-size: 12px;
	font-weight: bold;
	line-height: 18px;
	margin-bottom: 18px;
}
#top #mainVisual .bnr a .more{
	font-size: 10px;
	line-height: 15px;
}
#top #mainVisual .bnr a .icon02{
	display: none;
}
#top #mainVisual .scroll{
	position: absolute;
	bottom: 200px;
	left: 50%;
	margin-left: 7px;
}
#top #purpose{
	padding: 206px 0 600px 0;
	position: relative;
}
#top #purpose:before,
#top #purpose:after{
	content: "";
	width: 1px;
	background: #E2041B;
	position: absolute;
	left: 50%;
}
#top #purpose:before{
	top: 0;
	height: 533px;
}
#top #purpose:after{
	bottom: 0;
	height: 600px;
}
#top #purpose-possibility{
	position: relative;
}
#top #purpose-possibility:after{
	content: "";
	height: 100%;
	width: 100%;
	position: absolute;
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
	bottom: 0;
	left: 0;
	z-index: -2;
}
#top #purpose h2{
	font-family: "din-2014", sans-serif;
	font-size: 100px;
	font-weight: 600;
	color: #E2041B;
	margin-bottom: 100px;
	line-height: 127px;
}
#top #purpose .tit02{
	margin-bottom: 100px;
}
#top #purpose .tit02 h3{
	font-size: 40px;
	line-height: 70px;
}
#top #purpose .tit02 h3 span{
	padding-left: 60px;
	padding-right: 30px;
}
#top #purpose .tit02 h3 span:nth-child(2):after{
	border-top-right-radius: 0;
}
#top #purpose .txt{
	max-width: 400px;
	font-size: 16px;
	line-height: 32px;
	font-weight: 400;
	margin: 0 auto 91px auto;
}
#top #purpose .txt .pc_paragraph{
	margin-bottom: 32px;
}
#top #purpose .txt p{
	margin-bottom: 0;
}
#top #purpose .txt p:last-child{
	margin-bottom: 0;
}
#top #purpose .btn{
	max-width: 980px;
	width: 100%;
	margin: 0 auto;
}
#top #purpose .btn a{
	display: block;
	text-align: right;
	padding: 0 20px;
	font-family: "din-2014", sans-serif;
	font-size: 12px;
	font-weight: 600;
	color: #FFF;
	background: #E2041B;
	border: 1px solid #E2041B;
	border-radius: 20px;
	line-height: 48px;
	transition: color 0.2s, background 0.2s;
}
#top #purpose .btn a:hover{
	background: transparent;
	color: #E2041B;
}
#top #purpose .btn a span{
	position: relative;
}
#top #purpose .btn a span:after{
	content: "";
	width: 0;
	height: 1px;
	bottom: 0;
	left: 0;
	position: absolute;
	background: #E2041B;
	transition: width 0.2s;
}
#top #purpose .btn a:hover span:after{
	width: 100%;
}
#top #possibility{
	position: relative;
	/*overflow: hidden;*/
	/*background: #FFF;*/
}
#top #possibility:before{
	left: 0;
}
#top #possibility:after{
	right: 0;
}
#top #possibility .box{
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
	padding: 250px 0 500px 0;
	position: relative;
	text-align: center;
}
#top #possibility .box:before,
#top #possibility .box:after{
	content: "";
	width: 1px;
	height: 200px;
	background: #E2041B;
	position: absolute;
	left: 50%;
}
#top #possibility .box:before{
	top: 0;
}
#top #possibility .box:after{
	bottom: 0;
	height: 500px;
}
#top #possibility .box .question{
	max-width: 520px;
	width: 100%;
	margin: 0 auto 40px auto;
	position: relative;
}
#top #possibility .box .question .txt{
	margin-bottom: 40px;
}
#top #possibility .box .answer{
	max-width: 520px;
	width: 100%;
	margin: 0 auto 100px auto;
	position: relative;
}
#top #possibility .box .answer .txt{
	margin-bottom: 50px;
}
#top #possibility .box .icon{
	position: absolute;
}

#possibility .icon{
	animation: floating-y 1.8s ease-in-out infinite alternate-reverse;
}
@keyframes floating-y {
	0%{
		transform: translateY(-10%);
	}
	100%{
		transform: translateY(10%);
	}
}
#top #possibility .box .question .p01{
	top: 169px;
	right: 51px;
}
#top #possibility .box .question .p02{
	max-width: 48px;
	filter: blur(3px);
	top: 170px;
	right: 10px;
	animation-delay: 0.2s;
}
#top #possibility .box .question .p03{
	/*transform: rotate(-50deg);*/
	bottom: -2px;
	left: 42px;
}
#top #possibility .box .question .p04{
	max-width: 48px;
	filter: blur(3px);
	/*transform: rotate(-50deg);*/
	bottom: 43px;
	left: -2px;
	animation-delay: 0.2s;
}
#top #possibility .box .answer .p01{
	max-width: 61px;
	top: -10px;
	right: 112px;
	/*transform: scaleX(-1);*/
}
#top #possibility .box .answer .p02{
	top: 120px;
	left: 70px;
}
#top #possibility .box .answer .p03{
	max-width: 57px;
	filter: blur(3px);
	top: 57px;
	left: 12px;
	animation-delay: 0.2s;
	/*transform: scaleX(-1);*/
}
#top #possibility .box .answer .p04{
	max-width: 34px;
	filter: blur(3px);
	top: 66px;
	right: 76px;
	animation-delay: 0.2s;
}
#top #possibility .box .answer .p05{
	top: 216px;
	right: 47px;
}
#top #possibility .box .answer .p06{
	max-width: 46px;
	filter: blur(3px);
	top: 214px;
	right: 6px;
	animation-delay: 0.2s;
}
#top #possibility .box .answer .p07{
	bottom: 0px;
	left: 52px;
	/*transform: rotate(-50deg);*/
}
#top #possibility .box .answer .p08{
	max-width: 46px;
	filter: blur(3px);
	/*transform: rotate(-65deg);*/
	left: 14px;
	bottom: 35px;
	animation-delay: 0.2s;
}
#top #possibility .box .question .p03 img{
	transform: rotate(-50deg);
}
#top #possibility .box .question .p04 img{
	transform: rotate(-50deg);
}
#top #possibility .box .answer .p01 img{
	transform: scaleX(-1);
}
#top #possibility .box .answer .p03 img{
	transform: scaleX(-1);
}
#top #possibility .box .answer .p07 img{
	transform: rotate(-50deg);
}
#top #possibility .box .answer .p08 img{
	transform: rotate(-65deg);
}

#top #possibility .box .btn{
	max-width: 980px;
	width: 100%;
	margin: 0 auto;
}
#top #possibility .box .btn a{
	display: block;
	text-align: right;
	padding: 0 20px;
	font-family: "din-2014", sans-serif;
	font-size: 12px;
	font-weight: 600;
	color: #FFF;
	background: #E2041B;
	border: 1px solid #E2041B;
	border-radius: 20px;
	line-height: 48px;
	transition: color 0.2s, background 0.2s;
}
#top #possibility .box .btn a:hover{
	background: transparent;
	color: #E2041B;
}
#top #possibility .btn a span{
	position: relative;
}
#top #possibility .btn a span:after{
	content: "";
	width: 0;
	height: 1px;
	bottom: 0;
	left: 0;
	position: absolute;
	background: #E2041B;
	transition: width 0.2s;
}
#top #possibility .btn a:hover span:after{
	width: 100%;
}
#top #services{
	background: #E2041B;
	padding: 68px 0 200px 0;
}
#top #services h2{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	font-size: 100px;
	line-height: 127px;
	vertical-align: bottom;
	margin-bottom: 5px;
}
.service_area{
	display: flex;
	align-items: center;
}
.service_area:before,
.service_area:after{
	content: "";
	height: stretch;
	background: #E2041B;
	border: 1px solid #fff;
	/*width: calc(((100vw - 1600px) / 2));*/
	width: calc(((100vw - 1402px) / 2));
	position: relative;
	z-index: 10;
	opacity: 0;
	transition: 0.6s opacity ease;
	transition-delay: 1.0s;
}
.service_area.is-inview:before,
.service_area.is-inview:after{
	opacity: 1;
}
.service_area:before{
	border-left: none;
	border-top-right-radius: 20px;
	border-bottom-right-radius: 20px;
}
.service_area:after{
	border-right: none;
	border-top-left-radius: 20px;
	border-bottom-left-radius: 20px;
	margin-left: -5px;
}
.service_area ul{
	/*max-width: 1600px;*/
	/*max-width: 100vw;*/
	width: 100%;
	display: flex;
	background: #E2041B;
}
.service_area ul li{
	/*width: 100%;*/
	/*width: 25%;*/
	width: calc(100% / 3);
	/*max-width: 400px;*/
	flex-shrink: 0;
	overflow: hidden;
	transition: width 2.75s cubic-bezier(.2,.6,.35,1) 0.5s;
	margin-left: -1px;
	border: 1px solid #E2041B;
	background: #FFF;
	border-radius: 20px;
	opacity: 0;
	transition: border-color 0.2s, 0.6s opacity ease;
}
.service_area ul li:hover{
	border-color: #FFF;
}
.service_area.is-inview ul li{
	opacity: 1;
}
.service_area.is-inview ul li:nth-child(1){
	transition: border-color 0.2s, 0.6s opacity ease 0.2s;
}
.service_area.is-inview ul li:nth-child(2){
	transition: border-color 0.2s, 0.6s opacity ease 0.4s;
}
.service_area.is-inview ul li:nth-child(3){
	transition: border-color 0.2s, 0.6s opacity ease 0.6s;
}
.service_area.is-inview ul li:nth-child(4){
	transition: border-color 0.2s, 0.6s opacity ease 0.8s;
}
.service_area ul li a{
	height: 100%;
	/*height: 398px;*/
	/*height: 498px;*/
	aspect-ratio: 1 / 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	position: relative;
	transition: color 0.2s, background 0.2s;
}
.service_area ul li a:hover{
	background: #E2041B;
	color: #FFF;
}
.service_area ul li a .ico{
	margin-bottom: 34px;
}
.service_area ul li a .ico svg{
	max-width: 65px;
	width: 100%;
	color: #E2041B;
	transition: color 0.2s;
}
.service_area ul li a:hover svg{
	color: #fff;
}
.service_area ul li a .ico2{
	position: absolute;
	right: 20px;
	bottom: 20px;
}
.service_area ul li a .ico2 svg{
	max-width: 21px;
	width: 100%;
	color: #E2041B;
	transition: color 0.2s;
}
.service_area ul li a:hover .ico2 svg{
	color: #fff;
}
.service_area ul li a .txt{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	font-size: 12px;
	line-height: 15px;
}
.service_area ul li a h4{
	font-size: 20px;
	line-height: 29px;
	margin-bottom: 10px;
	font-weight: bold;
}
.service_area.is-inview ul li:nth-child(1) h4{
	font-size: 22px;
	line-height: 32px;
}
.service_area ul li a .cont{
	font-size: 14px;
	line-height: 18px;
	margin-bottom: 32px;
	font-weight: 400;
}
.service_area ul li a .more{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	font-size: 12px;
	line-height: 15px;
	color: #E2041B;
	transition: color 0.2s;
}
.service_area ul li a:hover .more{
	color: #FFF;
}
.service_area ul li a .more span{
	position: relative;
}
.service_area ul li a .more span:after{
	content: "";
	position: absolute;
	width: 0;
	height: 1px;
	bottom: 0;
	left: 0;
	background: #FFF;
	transition: width 0.2s;
}
.service_area ul li a:hover .more span:after{
	width: 100%;
}
#top #work{
	padding: 73px 0 220px 0;
	background: #FFF;
}
#top #work h2{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #E2041B;
	font-size: 100px;
	line-height: 127px;
	vertical-align: bottom;
}
#top #work .list{
	position: relative;
	margin-bottom: 40px;
}
#top #work .list:after{
	content: "";
	position: absolute;
	width: 0;
	height: 1px;
	margin-top: -0.5px;
	top: 50%;
	background: #E2041B;
	transition: 0.8s width ease;
	transition-delay: 1s;
}
#top #work .list.is-inview:after{
	width: 100%;
}
#top #work .list ul{
	max-width: 980px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 0 40px;
}
#top #work .list ul li{
	max-width: 300px;
	width: 100%;
	position: relative;
	background: #FFF;
	z-index: 1;
	opacity: 0;
	transition: 0.6s opacity ease;
}
#top #work .list ul li:before,
#top #work .list ul li:after{
	content: "";
	position: absolute;
	width: 30px;
	height: 30px;
	background: #FFF;
	z-index: 2;
}
#top #work .list ul li:before{
	top: -1px;
	right: -1px;
}
#top #work .list ul li:after{
	bottom: -1px;
	left: -1px;
}
#top #work .list.is-inview ul li{
	opacity: 1;
}
#top #work .list ul li:nth-child(1){
	transition-delay: 0.2s;
}
#top #work .list ul li:nth-child(2){
	transition-delay: 0.4s;
}
#top #work .list ul li:nth-child(3){
	transition-delay: 0.6s;
}
#top #work .list ul li a{
	display: block;
	position: relative;
	border: 1px solid #E2041B;
	border-radius: 20px;
}
#top #work .list ul li a .box{
	width: 100%;
	height: 298px;
	padding: 30px 29px 34px 29px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
#top #work .list ul li a .box:after{
	content: "[ More ]";
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	position: absolute;
	border-radius: 20px;
	top: -1px;
	right: -1px;
	bottom: -1px;
	left: -1px;
	background: #E2041B;
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	transition: opacity 0.2s;
	z-index: 3;
}
#top #work .list ul li a:hover .box:after{
	opacity: 1;
}
#top #work .list ul li a:before,
#top #work .list ul li a:after{
	content: "";
	background: #E2041B;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	position: absolute;
	z-index: 4;
}
#top #work .list ul li a:before{
	top: -1px;
	right: -1px;
}
#top #work .list ul li a:after{
	bottom: -1px;
	left: -1px;
}
#top #work .list ul li .dot{
	background: #E2041B;
	width: 5px;
	height: 5px;
	position: absolute;
	border-radius: 50%;
	top: 50%;
	right: -25px;
	transform: translate(-50%, -50%);
}
#top #work .list ul li:last-child .dot{
	display: none;
}
#top #work .list ul li a .logo{
	aspect-ratio: 240 / 50;
	text-align: center;
}
#top #work .list ul li a .logo img{
	object-fit: contain;
	height: 50px;
	width: auto;
}
#top #work .list ul li a h3{
	margin-bottom: 8px;
	font-size: 16px;
	line-height: 18px;
	font-weight: bold;
	margin-top: 20px;
}
#top #work .list ul li a .cont{
	font-size: 12px;
	line-height: 14px;
	font-weight: 500;
}
#top #work .list ul li a .cats{
	font-size: 10px;
	line-height: 15px;
	font-weight: 500;
}
#top #work .btn{
	position: relative;
	z-index: 1;
	max-width: 980px;
	width: 100%;
	color: #FFF;
	margin: 0 auto;
}
#top #work .btn a{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	display: block;
	background: #E2041B;
	border: 1px solid #E2041B;
	border-radius: 20px;
	padding: 0 20px;
	line-height: 48px;
	text-align: right;
	transition: color 0.2s, background 0.2s;
}
#top #work .btn a:hover{
	background: transparent;
	color: #E2041B;
}
#top #work .btn a span{
	position: relative;
}
#top #work .btn a span:after{
	content: "";
	width: 0;
	height: 1px;
	bottom: 0;
	left: 0;
	position: absolute;
	background: #E2041B;
	transition: width 0.2s;
}
#top #work .btn a:hover span:after{
	width: 100%;
}
#top #member{
	background: #FFF;
	margin-top: -20px;
	display: flex;
	align-items: center;
}
#top #member:before,
#top #member:after{
	content: "";
	height: stretch;
	background: #E2041B;
	flex-shrink: 0;
	width: calc((100% - 1496px) / 2);
	opacity: 0;
	transition: 0.6s opacity ease;
	transition-delay: 1s;
}
#top #member:before{
	border-top-right-radius: 20px;
	border-bottom-right-radius: 20px;
}
#top #member:after{
	border-top-left-radius: 20px;
	border-bottom-left-radius: 20px;
}
#top #member.is-inview:before,
#top #member.is-inview:after{
	opacity: 1;
}
#top #member a{
	display: block;
	position: relative;
	/*max-width: 1496px;*/
	max-width: 100%;
	margin: 0 auto;
	width: 100%;
}
#top #member h2{
	position: absolute;
	left: 50%;
	top: 50%;
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	font-size: 100px;
	margin-top: 30px;
	line-height: 127px;
	color: #fff;
	transform: translate(-50%, -50%);
	vertical-align: bottom;
	mix-blend-mode: overlay;
	z-index: 1;
}
#top #member ul{
	display: flex;
	align-items: center;
	position: relative;
}
#top #member ul li{
	width: 100%;
	overflow: hidden;
	border-radius: 20px;
	opacity: 0;
	transition: 1.0s opacity ease;
}
#top #member.is-inview ul li{
	opacity: 1;
}
#top #member.is-inview ul li:nth-child(1){
	transition: 0.6s opacity ease 0.2s;
}
#top #member.is-inview ul li:nth-child(2){
	transition: 0.6s opacity ease 0.4s;
}
#top #member.is-inview ul li:nth-child(3){
	transition: 0.6s opacity ease 0.6s;
}
#top #member.is-inview ul li:nth-child(4){
	transition: 0.6s opacity ease 0.8s;
}
#top #member a ul li img{
	filter: grayscale(100%);
	transition: filter 0.3s;
}
#top #member a:hover ul li img{
	filter: grayscale(0);
}
#top #news{
	background: #E9E9E9;
	padding: 94px 0 186px 0;
	margin-top: -20px;
}
#top #news h2{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #fff;
	font-size: 100px;
	line-height: 127px;
	vertical-align: bottom;
}
#top #news ul{
	max-width: 980px;
	width: 100%;
	margin: 0 auto 40px auto;
}
#top #news ul li{
	margin-bottom: 2px;
}
#top #news ul li:last-child{
	margin-bottom: 0;
}
#top #news ul li a{
	display: block;
	background: #FFF;
	padding: 31px 30px 30px 30px;
	position: relative;
	transition: color 0.2s;
}
#top #news ul li a:hover{
	color: #E2041B;
}
#top #news ul li a .date-cats{
	display: flex;
	align-items: center;
	margin-bottom: 2px;
}
#top #news ul li a .date-cats .date{
	font-size: 12px;
	margin-right: 13px;
	line-height: 14px;
}
#top #news ul li a .date-cats .cats{
	font-size: 10px;
	line-height: 16px;
	padding: 0 4px;
	border-left: 1px solid #E2041B;
	border-right: 1px solid #E2041B;
	min-width: 80px;
	text-align: center;
}
#top #news ul li a h3{
	font-size: 16px;
	line-height: 24px;
	font-weight: bold;
	padding-right: 120px;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
	font-weight: bold;
}
#top #news ul li a .ico{
	position: absolute;
	top: 50%;
	right: 30px;
	transform: translateY(-50%);
}
#top #news .btn{
	position: relative;
	z-index: 1;
	max-width: 980px;
	width: 100%;
	color: #FFF;
	margin: 0 auto;
}
#top #news .btn a{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	display: block;
	background: #E2041B;
	border: 1px solid #E2041B;
	border-radius: 20px;
	padding: 0 20px;
	line-height: 48px;
	text-align: right;
	transition: color 0.2s, background 0.2s;
}
#top #news .btn a:hover{
	background: transparent;
	color: #E2041B;
}
#top #news .btn a span{
	position: relative;
}
#top #news .btn a span:after{
	content: "";
	width: 0;
	height: 1px;
	bottom: 0;
	left: 0;
	position: absolute;
	background: #E2041B;
	transition: width 0.2s;
}
#top #news .btn a:hover span:after{
	width: 100%;
}

/* title
-----------------------------------*/
.tit_h1{
	font-family: "din-2014", sans-serif;
	font-size: 100px;
	font-weight: 600;
	color: #E2041B;
	margin-bottom: 18px;
	line-height: 127px;
}
.tit01{
	font-size: 16px;
	line-height: 50px;
	padding: 0 17px;
	border-top-left-radius: 5px;
	background: #E2041B;
	color: #fff;
	font-weight: bold;
	max-width: 460px;
	width: 100%;
	margin-left: auto;
}
.tit02{
	width: 1040px;
	margin: 0 auto;
}
.tit02 h3{
	font-size: 30px;
	line-height: 50px;
	color: #E2041B;
	font-weight: bold;
}
.tit02 h3 span{
	display: block;
	padding-left: 20px;
	vertical-align: middle;
	position: relative;
	z-index: 1;
	width: fit-content;
	transition: color 0.8s 0.4s;
}
.tit02 h3 span:after{
	content: "";
	width: 0;
	height: 100%;
	position: absolute;
	left: -23.9583vw;
	top: 0;
	z-index: -1;
	background: #E2041B;
	border-top-right-radius: 5px;
	border-bottom-right-radius: 5px;
	transition: width 0.4s 0.2s;
}
.tit02 h3 span:nth-child(2):after{
	transition-delay: 0.4s;
}
.tit02.is-inview h3{
	color: #FFF;
}
.tit02.is-inview h3 span:after{
	width: calc(100% + 23.9583vw);
}
.tit03{
	width: 1040px;
	margin: 0 auto;
}
.tit03 h4{
	font-size: 16px;
	line-height: 35px;
	font-weight: bold;
}
.tit03 h4 span{
	display: block;
	padding-left: 20px;
	vertical-align: middle;
	position: relative;
	width: fit-content;
	z-index: 1;
}
.tit03 h4 span:after{
	content: "";
	width: 0;
	height: 100%;
	position: absolute;
	left: -23.9583vw;
	top: 0;
	z-index: -1;
	background: #F3F3F3;
	border-top-right-radius: 3px;
	border-bottom-right-radius: 3px;
	transition: width 0.4s 0.2s;
}
.tit03 h4 span:nth-child(2):after{
	transition-delay: 0.4s;
}
.tit03.is-inview h4 span:after{
	width: calc(100% + 23.9583vw);
}
.sp_title{
	display: none;
}

/* Common
-----------------------------------*/
.svg_side{
	display: none;
}
#content_area{
	background: #FFF;
	position: relative;
	z-index: 1;
}
#video{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
	z-index: -3;
	overflow: hidden;
	height: 100lvh;
}
#video.movie{
	top: 0;
}
#video video{
	position: absolute;
	height: 100%;
	right: 0;
	top: 0;
}
#video.sub video{
	height: calc(100% - 80px);
}
#video.sub{
	top: 80px;
	transform: scaleX(-1);
}
#video .video_data{
	position: relative;
	height: 100%;
}
#video.sub .video_data:after{
	content: "";
	height: 100%;
	width: 100%;
	position: absolute;
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
	bottom: 0;
	left: 0;
	z-index: 1;
}
.subPage{
	margin-top: 80px;
}
.sidede{
	position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	z-index: -1;
}
.sidede_left{
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	z-index: -1;
}
.side_tit{
	text-align: left;
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	font-size: 150px;
	line-height: 70%;
	writing-mode: vertical-rl;
	text-orientation: mixed;
	margin-left: auto;
	width: 0;
	padding: 20px 0 50px 0;
	position: sticky;
	top: 60px;
}
.sidede_left .side_tit{
	width: auto;
}
.side_tit span{
	display: inline-block;
	position: relative;
	color: transparent;
	white-space: nowrap;
}
.side_tit span:before,
.side_tit span:after{
	content: attr(aria-label);
	position: absolute;
	top: 0;
	left: 0;
	color: #E2041B;
}
.side_tit span:before{
	filter: url(#dilate);
}
.side_tit span:after{
	opacity: 0;
	/*transition: opacity 0.4s ease 0.5s;*/
	transition: opacity 0.8s ease 0.5s;
}
.side_tit span:hover:after{
	opacity: 1;
}
.side_tit.is-inview span:after{
	opacity: 1;
}
.side_tit_left{
	text-align: left;
	z-index: -1;
	height: 0;
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	font-size: 150px;
	line-height: 70%;
	position: absolute;
	top: 0;
	left: 0.7em;
	transform: rotate(90deg);
	transform-origin: left bottom;
	padding-left: 20px;
}
.side_tit_left span{
	display: inline-block;
	position: relative;
	color: transparent;
	width: max-content;
}
.side_tit_left span:before,
.side_tit_left span:after{
	content: attr(aria-label);
	position: absolute;
	top: 0;
	left: 0;
	color: #E2041B;
}
.side_tit_left span:before{
	filter: url(#dilate);
}
.side_tit_left span:after{
	opacity: 0;
	transition: opacity 0.4s ease 0.5s;
}
.side_tit_left span:hover:after{
	opacity: 1;
}
.side_tit_left.is-inview span:after{
	opacity: 1;
}
#fixed_nav{
	position: fixed;
	bottom: 50px;
	left: 0;
	z-index: 9998;
}
#fixed_nav ul{
}
#fixed_nav ul li{
	margin-bottom: 16px;
	font-weight: 900;
}
#fixed_nav ul li:last-child{
	margin-bottom: 0;
}
#fixed_nav ul li a{
	display: block;
	width: fit-content;
	position: relative;
	/*padding-left: 100px;*/
	padding-left: 5.2083vw;
}
#fixed_nav ul li.active a,
#fixed_nav ul li a:hover{
	color: #E2041B;
}

#fixed_nav.white ul li,
#fixed_nav.white ul li.active a{
	color: #FFF;
}
#fixed_nav.white ul li.active a:after{
	background: #FFF;
}
#fixed_nav ul li a:after{
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	height: 1px;
	background: #E2041B;
	transition: width 0.2s;
}
#fixed_nav ul li a:hover:after,
#fixed_nav ul li.active a:after{
	width: 100%;
}
.fadeUp{
	opacity: 0;
	transform: translate3d(0, 15px, 0);
	transition: opacity 0.5s ease-in-out, transform 0.5s ease-in-out;
}
.fadeUp.is-inview{
	opacity: 1;
	transform: none;
}
.fadeUp_pc{
	opacity: 0;
	transform: translate3d(0, 15px, 0);
	transition: opacity 0.5s ease-in-out, transform 0.5s ease-in-out;
}
.fadeUp_pc.is-inview{
	opacity: 1;
	transform: none;
}
.fadeUp_sp{
	opacity: 1;
	transform: none;
}


/* Company
-----------------------------------*/
#company #firstView .main_tit{
	padding-top: 74px;
	background: #fff;
	padding-bottom: 656px;
}
#company #firstView #image_bloc{
	background-image: url(../images/common/bg_dot.svg);
	padding-bottom: 270px;
	position: relative;
}
#company #firstView #image_bloc .box{
	position: absolute;
	right: 0;
	bottom: 98px;
}
#company #firstView #image_bloc .box .image{
	text-align: right;
	/*max-width: 76.0417vw;*/
	max-width: 1460px;
	width: 100%;
	margin-left: auto;
	overflow: hidden;
	border-top-left-radius: 20px;
	border-bottom-left-radius: 20px;
}
#company #message{
	position: relative;
	z-index: 1;
	padding: 200px 0 250px 0;
}
#company #message .tit02{
	margin-bottom: 100px;
}
#company #message .tit02 h3 span:nth-child(2):after{
	border-top-right-radius: 0;
}
#company #message .txt{
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
	margin-bottom: 100px;
}
#company #message .txt p{
	margin-bottom: 48px;
}
#company #message .txt p:last-child{
	margin-bottom: 0;
}
#company #message .name{
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
	text-align: right;
	font-size: 20px;
	line-height: 29px;
	letter-spacing: 0.04em;
	font-weight: 500;
}
#company #message .name span{
	font-size: 14px;
	line-height: 20px;
	display: block;
	font-weight: 400;
	margin-bottom: 3px;
}
#company #purpose{
	position: relative;
	z-index: 1;
	border-top: 1px solid #E2041B;
	padding-bottom: 250px;
}
#company #purpose .tit01{
	margin-top: -50px;
	margin-bottom: 200px;
}
#company #purpose .tit02{
	margin-bottom: 20px;
}
#company #purpose .tit02 h3 span{
	padding-right: 23px;
}
#company #purpose .tit02 h3 span:nth-child(2):after{
	border-top-right-radius: 0;
}
#company #purpose .tit03{
	margin-bottom: 150px;
}
#company #purpose .tit03 h4 span{
	padding-right: 15px;
}
#company #purpose .tit03 h4 span:nth-child(1):after{
	border-bottom-right-radius: 0;
}
#company #purpose h5{
	font-size: 20px;
	font-weight: bold;
	line-height: 29px;
	padding-bottom: 15px;
	margin-bottom: 40px;
	max-width: 800px;
	width: 100%;
	margin: 0 auto 40px auto;
	position: relative;
}
#company #purpose h5 span{
	display: block;
	font-size: 12px;
	line-height: 17px;
	margin-bottom: 2px;
	color: #E2041B;
	letter-spacing: 0.04em;
}
#company #purpose h5:after{
	content: "";
	position: absolute;
	bottom: 0;
	height: 1px;
	width: calc(100% + 29.1667vw);
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#company #purpose h5:first-of-type:after{
	left: -29.1667vw;
}
#company #purpose h5:last-of-type:after{
	right: -29.1667vw;
}
#company #purpose .box01{
	display: flex;
	max-width: 800px;
	width: 100%;
	margin: 0 auto 100px auto;
	justify-content: space-between;
}
#company #purpose .box01 .txt{
	max-width: 520px;
	width: 100%;
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
}
#company #purpose .box01 .txt p{
	margin-bottom: 24px;
}
#company #purpose .box01 .txt p:last-child{
	margin-bottom: 0;
}
#company #purpose .box01 .image{
	max-width: 200px;
	width: 100%;
}
#company #purpose .box02{
	display: flex;
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
	justify-content: space-between;
}
#company #purpose .box02 .txt{
	max-width: 520px;
	width: 100%;
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
}
#company #purpose .box02 .txt p{
	margin-bottom: 24px;
}
#company #purpose .box02 .txt p:last-child{
	margin-bottom: 0;
}
#company #purpose .box02 .list{
	max-width: 200px;
	width: 100%;
	position: relative;
}
#company #purpose .box02 .list:after{
	content: "";
	background-image: url(../images/pages/ico_company_purpose01.svg);
	width: 42px;
	height: 42px;
	background-position: center;
	background-repeat: no-repeat;
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 1;
	transform: translate(-50%, -50%);
}
#company #purpose .box02 .list ul li{
	max-width: 100%;
	width: 100%;
	border: 1px solid #E2041B;
	border-radius: 20px;
	position: relative;
	background: #FFF;
	z-index: 1;
	margin-bottom: 20px;
}
#company #purpose .box02 .list ul li:last-child{
	margin-bottom: 0;
}
#company #purpose .box02 .list ul li:before,
#company #purpose .box02 .list ul li:after{
	content: "";
	position: absolute;
	width: 30px;
	height: 30px;
	background: #FFF;
}
#company #purpose .box02 .list ul li:before{
	top: 0;
	right: 0;
}
#company #purpose .box02 .list ul li:after{
	bottom: 0;
	left: 0;
}
#company #purpose .box02 .list ul li .cont{
	width: 100%;
	height: 198px;
	display: block;
	padding: 21px 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}
#company #purpose .box02 .list ul li .cont:before,
#company #purpose .box02 .list ul li .cont:after{
	content: "";
	background: #E2041B;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	position: absolute;
	z-index: 2;
}
#company #purpose .box02 .list ul li .cont:before{
	top: 0;
	right: 0;
}
#company #purpose .box02 .list ul li .cont:after{
	bottom: 0;
	left: 0;
}
#company #purpose .box02 .list ul li .cont h6{
	padding-bottom: 11px;
	font-size: 16px;
	line-height: 24px;
	border-bottom: 1px solid #E2041B;
	text-align: center;
	font-weight: bold;
	max-width: 100px;
	width: 100%;
}
#company #purpose .box02 .list ul li .cont h6 span{
	font-size: 14px;
	line-height: 18px;
	display: block;
	font-family: "din-2014", sans-serif;
	font-weight: 800;
}
#company #vision{
	position: relative;
	z-index: 1;
	border-top: 1px solid #E2041B;
	padding-bottom: 250px;
}
#company #vision .tit01{
	margin-top: -50px;
	margin-bottom: 200px;
}
#company #vision .tit02{
	margin-bottom: 100px;
}
#company #vision .tit02 h3 span:nth-child(1):after{
	border-bottom-right-radius: 0;
}
#company #vision .tit02 h3 span{
	padding-right: 5px;
}
#company #vision .box01{
	max-width: 870px;
	width: 100%;
	margin: 0 auto 100px auto;
	display: flex;
	justify-content: space-between;
}
#company #vision .box01 .image01{
	max-width: 310px;
	width: 100%;
	margin-left: -70px;
}
#company #vision .box01 .txt{
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
	max-width: 520px;
	width: 100%;
}
#company #vision .box01 .txt p{
	margin-bottom: 24px;
}
#company #vision .box01 .txt p:last-child{
	margin-bottom: 0;
}
#company #vision .box01 .txt ul{
	margin-bottom: 24px;
}
#company #vision .box01 .txt ul li{
}
#company #vision .box01 .txt ul li:before{
	content: "・　";
}
#company #vision .image02{
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
}
#company #company_profile{
	position: relative;
	z-index: 1;
	border-top: 1px solid #E2041B;
	background: #E9E9E9;
	padding-bottom: 250px;
}
#company #company_profile .side_tit span:before,
#company #company_profile .side_tit span:after{
	color: #FFF;
}
#company #company_profile .tit01{
	margin-top: -50px;
	margin-bottom: 215px;
}
#company #company_profile .logo{
	max-width: 328px;
	width: 100%;
	margin: 0 auto 100px auto;
}
#company #company_profile .table{
	position: relative;
	padding: 85px 0;
}
#company #company_profile .table:before,
#company #company_profile .table:after{
	content: "";
	position: absolute;
	height: 1px;
	width: calc(100% + 29.1667vw);
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#company #company_profile .table:before{
	top: 0;
	left: -29.1667vw;
}
#company #company_profile .table:after{
	bottom: 0;
	right: -29.1667vw;
}
#company #company_profile .table table{
	max-width: 580px;
	width: 100%;
	margin: 0 auto;
}
#company #company_profile .table table th,
#company #company_profile .table table td{
	font-size: 16px;
	line-height: 24px;
	padding: 15px 0;
	text-align: left;
	vertical-align: top;
}
#company #company_profile .table table th{
	width: 157px;
	font-weight: bold;
}
#company #company_profile .table table td{
	padding-left: 23px;
	font-weight: 400;
}
#company #member{
	position: relative;
	z-index: 1;
	border-top: 1px solid #E2041B;
	padding-bottom: 250px;
}
#company #member .tit01{
	margin-top: -50px;
	margin-bottom: 200px;
}
#company #member h4 span{
	display: block;
	font-size: 12px;
	line-height: 17px;
	margin-bottom: 2px;
	color: #E2041B;
}
#company #member h4:after{
	content: "";
	position: absolute;
	bottom: 0;
	right: 0;
	height: 1px;
	width: calc(100% + 29.1667vw);
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#company #member .lead .txt p{
	font-size: 14px;
	line-height: 22px;
	margin-bottom: 22px;
}
#company #member .lead .txt p:last-child{
	margin-bottom: 0;
}

#company #member .executives,
#company #member .advisor{
	margin-bottom: 200px;
}
#company #member .executives h4,
#company #member .advisor h4,
#company #member .team h4{
	font-size: 20px;
	font-weight: bold;
	line-height: 29px;
	padding-bottom: 15px;
	/*max-width: 1360px;*/
	max-width: 1600px;
	padding-left: 240px;
	width: 100%;
	margin-left: auto;
	margin-bottom: 40px;
	position: relative;
}
#company #member .executives h4:after,
#company #member .advisor h4:after,
#company #member .team h4:after{
	content: "";
	position: absolute;
	bottom: 0;
	height: 1px;
	/*width: calc(100% + 29.1667vw);*/
	width: 100%;
	max-width: 1630px;
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#company #member .executives h4:after,
#company #member .team h4:after{
	left: -29.1667vw;
}
#company #member .advisor h4:after{
	left: 240px;
}
#company #member .list01{
	/*max-width: 1380px;*/
	max-width: 1600px;
	padding: 0 20px 0 240px;
	margin-left: auto;
	display: flex;
	flex-wrap: wrap;
	/*gap: 0 30px;*/
	gap: 60px 2.2388%;
}
#company #member .list01 li{
	/*max-width: 300px;*/
	max-width: 22.3881%;
	width: 100%;
	font-size: 14px;
	font-weight: 400;
	line-height: 22px;
}
#company #member .list01 li .image{
	border-radius: 10px;
	overflow: hidden;
	margin-bottom: 13px;
	position: relative;
}
#company #member .list01 li .image .outline{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
#company #member .list01 li .image img{
	position: relative;
	z-index: 1;
}
#company #member .list01 li h5{
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 30px;
	line-height: 22px;
}
#company #member .list01 li h5 span{
	display: block;
	font-size: 14px;
}
#company #member .list03{
	/*max-width: 1380px;*/
	max-width: 1600px;
	padding: 0 20px 0 240px;
	margin-left: auto;
	display: flex;
	flex-wrap: wrap;
	gap: 30px 20px;
}
#company #member .list03 li{
	max-width: 16.1458vw;
	max-width: 310px;
	width: 100%;
	position: relative;
	max-width: calc((100% - 60px - 40px) / 4);
	background: #FFF;
	border-radius: 10px;
}
#company #member .list03 li .outline{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
#company #member .list03 li .box{
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	height: 80px;
	width: 100%;
	padding: 8px 7px;
}
#company #member .list03 li .name{
	margin-left: 20px;
	font-size: 14px;
	line-height: 24px;
}

/*
#company #member .executives,
#company #member .advisor{
	margin-bottom: 200px;
}
#company #member .executives h4,
#company #member .advisor h4,
#company #member .team h4{
	font-size: 20px;
	font-weight: bold;
	line-height: 29px;
	padding-bottom: 15px;
	margin-bottom: 40px;
	max-width: 800px;
	width: 100%;
	margin: 0 auto 40px auto;
	position: relative;
}
#company #member .executives h4:after,
#company #member .advisor h4:after,
#company #member .team h4:after{
	content: "";
	position: absolute;
	bottom: 0;
	height: 1px;
	width: calc(100% + 29.1667vw);
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#company #member .executives h4:after,
#company #member .team h4:after{
	right: 0;
}
#company #member .advisor h4:after{
	left: 0;
}
#company #member .list01{
	max-width: 1355px;
	margin-left: auto;
	display: flex;
	gap: 0 30px;
	margin: 0 auto;
	gap: 0 1.5625vw;
	position: relative;
	right: -275px;
}
#company #member .list01 li{
	max-width: 300px;
	width: 100%;
	font-size: 14px;
	font-weight: 400;
	line-height: 22px;
	max-width: 15.625vw;
}
#company #member .list01 li .image{
	border-radius: 10px;
	overflow: hidden;
	margin-bottom: 23px;
	position: relative;
}
#company #member .list01 li .image .outline{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
#company #member .list01 li .image img{
	position: relative;
	z-index: 1;
}
#company #member .list01 li h5{
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 25px;
	line-height: 22px;
}
#company #member .list01 li h5 span{
	display: block;
	font-size: 14px;
}
#company #member .list03{
	max-width: 1355px;
	margin-left: auto;
	display: flex;
	flex-wrap: wrap;
	gap: 30px 20px;
	margin: 0 auto;
	position: relative;
	right: -275px;
	gap: 1.5625vw 1.0417vw;
}
#company #member .list03 li{
	max-width: 16.1458vw;
	max-width: 310px;
	width: 100%;
	position: relative;
}
#company #member .list03 li .outline{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
#company #member .list03 li .box{
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	height: 80px;
	width: 100%;
	padding: 8px 7px;
}
#company #member .list03 li .name{
	margin-left: 20px;
	font-size: 14px;
	line-height: 24px;
}
*/

/* Service
-----------------------------------*/
#service #lead .tit_h1{
	margin-bottom: 100px;
}
#service .tit02 h3 span:nth-child(1):after{
	border-bottom-right-radius: 0;
}
#service .tit02 h3 span:nth-child(2):after{
	transition-delay: 0.4s;
}
#service #lead .tit02{
	margin-bottom: 100px;
}
#service #lead .box{
	background: #FFF;
	padding-top: 74px;
	padding-bottom: 260px;
}
#service #lead .txt{
	max-width: 800px;
	margin: 0 auto;
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
}
#service #lead .image_bloc{
	background-image: url(../images/common/bg_dot.svg);
	height: 270px;
	position: relative;
}
#service #lead .image_bloc .image{
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 101px;
	max-width: 412px;
	margin: 0 auto;
}
#service #lead_sp{
	display: none;
}
#service #services{
	background: #E2041B;
	padding: 0 0 200px 0;
	border-top: 1px solid transparent;
}
#service #services .tit01{
	margin-top: -50px;
	margin-bottom: 77px;
}
#service #services h3{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	font-size: 100px;
	line-height: 127px;
	vertical-align: bottom;
}
#service #services .service_area .dummy{
	display: none;
}

/* SPARQX
-----------------------------------*/
#sparqx #firstView .main_tit{
	padding-top: 74px;
	background: #fff;
	padding-bottom: 656px;
}
#sparqx #firstView #image_bloc{
	background-image: url(../images/common/bg_dot.svg);
	padding-bottom: 270px;
	position: relative;
}
#sparqx #firstView #mainVisual{
	position: absolute;
	right: 0;
	bottom: 98px;
	max-width: 1460px;
	width: 100%;
	height: 760px;
	background: #E2041B;
	margin-left: auto;
	border-top-left-radius: 20px;
	border-bottom-left-radius: 20px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	color: #fff;
	background-image: url(../images/pages/ico_service_main.svg), url(../images/pages/ico_service_main.svg), url(../images/pages/ico_service_main.svg), url(../images/pages/ico_service_main.svg);
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
	background-position: 100px 100px, 100px calc(100% - 100px), calc(100% - 100px) 100px, calc(100% - 100px) calc(100% - 100px);
}
#sparqx #firstView #mainVisual svg{
	color: transparent;
	max-width: 620px;
	margin: 0 auto;
	transition: color 0.8s ease 0.5s;
}
#sparqx #firstView #mainVisual.is-inview svg{
	color: #FFF;
}
#sparqx #firstView #mainVisual span{
	font-family: "din-2014", sans-serif;
	font-size: 16px;
	line-height: 20px;
	margin-top: 20px;
	font-weight: 400;
}
#sparqx #about{
	padding-bottom: 250px;
	position: relative;
	border-top: 1px solid #E2041B;
}
#sparqx .tit01{
	margin-top: -50px;
	margin-bottom: 198px;
}
#sparqx .tit02{
	margin-bottom: 100px;
}
#sparqx .tit02 h3 span:nth-child(1):after{
	border-bottom-right-radius: 0;
}
#sparqx #about .txt{
	max-width: 440px;
	width: 100%;
	font-size: 16px;
	line-height: 32px;
	font-weight: 400;
	margin: 0 auto 100px auto;
}
#sparqx #about .txt p{
	margin-bottom: 32px;
}
#sparqx #about .txt p:last-child{
	margin-bottom: 0;
}
#sparqx #about .image{
	max-width: 800px;
	width: 100%;
	margin: 0 auto 70px auto;
}
#sparqx #about .wrap{
	display: flex;
	justify-content: center;
}
#sparqx #about .wrap:before,
#sparqx #about .wrap:after{
	content: url(../images/pages/ico_sparqx_about.svg);
	width: calc(((100vw - 1000px) / 2) - 2px);
	height: 498px;
	background: #FFF;
	border: 1px solid #E9E9E9;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: 0.6s opacity;
	transition-delay: 0.4s;
}
#sparqx #about .wrap.is-inview:before,
#sparqx #about .wrap.is-inview:after{
	opacity: 1;
}
#sparqx #about .wrap:before{
	border-left: none;
	border-top-right-radius: 20px;
	border-bottom-right-radius: 20px;
}
#sparqx #about .wrap:after{
	border-right: none;
	border-top-left-radius: 20px;
	border-bottom-left-radius: 20px;
}
#sparqx #about .wrap .box{
	max-width: 1000px;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 80px 100px 71px 100px;
	background: #E9E9E9;
	border-radius: 20px;
	background-image: url(../images/pages/ico_service_about.svg), url(../images/pages/ico_service_about.svg), url(../images/pages/ico_service_about.svg), url(../images/pages/ico_service_about.svg);
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
	background-position: 40px 40px, 40px calc(100% - 40px), calc(100% - 40px) 40px, calc(100% - 40px) calc(100% - 40px);
	opacity: 0;
	transition: 0.8s opacity;
	transition-delay: 0.4s;
}
#sparqx #about .wrap.is-inview .box{
	opacity: 1;
}
#sparqx #about .wrap .box .logos{
	max-width: 160px;
	width: 100%;
	text-align: center;
	order: 1;
}
#sparqx #about .wrap .box .logos .logo{
	margin-bottom: 10px;
}
#sparqx #about .wrap .box .logos .tit{
	font-size: 42px;
	line-height: 61px;
	font-weight: bold;
	color: #E2041B;
}
#sparqx #about .wrap .box .right{
	order: 2;
	max-width: 520px;
	width: 100%;
}
#sparqx #about .wrap .box .right h4{
	font-size: 20px;
	line-height: 25px;
	font-weight: bold;
	color: #E2041B;
	padding-bottom: 15px;
	margin-bottom: 40px;
	position: relative;
}
#sparqx #about .wrap .box .right h4:after{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	height: 1px;
	width: 100%;
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#sparqx #about .wrap .box .right .txt01{
	font-size: 14px;
	line-height: 22px;
}
#sparqx #about .wrap .box .right .txt01 p{
	margin-bottom: 22px;
}
#sparqx #about .wrap .box .right .txt01 p:last-child{
	margin-bottom: 0;
}
#sparqx #about .wrap .box .right .txt01 p span{
	color: #E2041B;
}
#sparqx #case-study{
	border-top: 1px solid #E2041B;
	padding-bottom: 300px;
	position: relative;
}
#sparqx #case-study .tit02 h3 span:nth-child(2){
	padding-right: 20px;
}
#sparqx #case-study .list{
	position: relative;
}
#sparqx #case-study .list:after{
	content: "";
	position: absolute;
	width: 0;
	height: 1px;
	top: 50%;
	background: #E2041B;
	margin-top: -0.5px;
	transition: 0.4s width ease;
	transition-delay: 1s;
}
#sparqx #case-study .list.is-inview:after{
	width: 100%;
}
#sparqx #case-study .list ul{
	max-width: 980px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 0 40px;
}
#sparqx #case-study .list ul li{
	max-width: 300px;
	width: 100%;
	position: relative;
	background: #FFF;
	z-index: 1;
	border: 1px solid #E2041B;
	border-radius: 20px;
	opacity: 0;
	transition: 0.6s opacity ease;
}
#sparqx #case-study .list.is-inview ul li{
	opacity: 1;
}
#sparqx #case-study .list ul li:nth-child(1){
	transition-delay: 0.2s;
}
#sparqx #case-study .list ul li:nth-child(2){
	transition-delay: 0.4s;
}
#sparqx #case-study .list ul li:nth-child(3){
	transition-delay: 0.6s;
}
#sparqx #case-study .list ul li:before,
#sparqx #case-study .list ul li:after{
	content: "";
	position: absolute;
	width: 30px;
	height: 30px;
	background: #FFF;
	z-index: 2;
}
#sparqx #case-study .list ul li:before{
	top: -1px;
	right: -1px;
}
#sparqx #case-study .list ul li:after{
	bottom: -1px;
	left: -1px;
}
#sparqx #case-study .list ul li .box{
	width: 100%;
	height: 298px;
	padding: 30px 29px 34px 29px;
	display: flex;
	flex-direction: column;
}
#sparqx #case-study .list ul li .box:before,
#sparqx #case-study .list ul li .box:after{
	content: "";
	background: #E2041B;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	position: absolute;
	z-index: 4;
}
#sparqx #case-study .list ul li .box:before{
	top: -1px;
	right: -1px;
}
#sparqx #case-study .list ul li .box:after{
	bottom: -1px;
	left: -1px;
}
#sparqx #case-study .list ul li .dot{
	background: #E2041B;
	width: 5px;
	height: 5px;
	position: absolute;
	border-radius: 50%;
	top: calc(50% + 1px);
	right: -25px;
	transform: translate(-50%, -50%);
}
#sparqx #case-study .list ul li:last-child .dot{
	display: none;
}
#sparqx #case-study .list ul li .box h3{
	font-size: 16px;
	font-weight: 700;
	line-height: 18px;
	margin-bottom: 33px;
}
#sparqx #case-study .list ul li .box h3 span{
	display: block;
	font-size: 12px;
	line-height: 14px;
	font-weight: 500;
	margin-bottom: 2px;
}
#sparqx #case-study .list ul li .box h4{
	font-size: 14px;
	line-height: 18px;
	font-weight: bold;
	color: #E2041B;
	margin-bottom: 15px;
}
#sparqx #case-study .list ul li .box p{
	font-size: 14px;
	line-height: 18px;
	font-weight: 400;
}
#sparqx #key-details{
	border-top: 1px solid #E2041B;
	padding-bottom: 200px;
	position: relative;
}
#sparqx #key-details .wrap{
	max-width: 800px;
	margin: 0 auto 100px auto;
}
#sparqx #key-details .wrap:last-child{
	margin-bottom: 0;
}
#sparqx #key-details .wrap h3{
	font-size: 20px;
	font-weight: bold;
	line-height: 29px;
	padding-bottom: 15px;
	margin-bottom: 40px;
	max-width: 800px;
	width: 100%;
	margin: 0 auto 40px auto;
	position: relative;
}
#sparqx #key-details .wrap h3 span{
	display: block;
	font-size: 12px;
	line-height: 17px;
	margin-bottom: 2px;
	color: #E2041B;
	letter-spacing: 0.04em;
}
#sparqx #key-details .wrap h3:after{
	content: "";
	position: absolute;
	bottom: 0;
	height: 1px;
	width: calc(100% + 29.1667vw);
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#sparqx #key-details .wrap:nth-child(odd) h3:after{
	left: 0;
}
#sparqx #key-details .wrap:nth-child(even) h3:after{
	right: 0;
}
#sparqx #key-details .wrap .txt{
	font-size: 16px;
	line-height: 24px;
	margin-bottom: 40px;
	font-weight: 400;
}
#sparqx #key-details .wrap .box{
	background: #E9E9E9;
	border-radius: 20px;
	min-height: 270px;
	padding: 0 80px 0 60px;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	
	background-image: url(../images/pages/ico_service_about.svg), url(../images/pages/ico_service_about.svg), url(../images/pages/ico_service_about.svg), url(../images/pages/ico_service_about.svg);
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
	background-position: 30px 30px, 30px calc(100% - 30px), calc(100% - 30px) 30px, calc(100% - 30px) calc(100% - 30px);
}
#sparqx #key-details .wrap .box .txt01{
	max-width: 450px;
	width: 100%;
	color: #E2041B;
	font-size: 14px;
	line-height: 22px;
}
#sparqx #services{
	background: #E2041B;
	padding: 73px 0 200px 0;
	border-top: 1px solid transparent;
}
#sparqx #services h3{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	font-size: 100px;
	line-height: 127px;
	vertical-align: bottom;
}
#sparqx #services .service_area .dummy{
	display: none;
}

/* Security Consulting
-----------------------------------*/
#security-consulting #firstView .main_tit{
	padding-top: 74px;
	background: #fff;
	padding-bottom: 656px;
}
#security-consulting #firstView #image_bloc{
	background-image: url(../images/common/bg_dot.svg);
	padding-bottom: 270px;
	position: relative;
}
#security-consulting #firstView #mainVisual{
	position: absolute;
	right: 0;
	bottom: 98px;
	max-width: 1460px;
	width: 100%;
	height: 760px;
	background: #E2041B;
	margin-left: auto;
	border-top-left-radius: 20px;
	border-bottom-left-radius: 20px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background-image: url(../images/pages/ico_service_main.svg), url(../images/pages/ico_service_main.svg), url(../images/pages/ico_service_main.svg), url(../images/pages/ico_service_main.svg);
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
	background-position: 100px 100px, 100px calc(100% - 100px), calc(100% - 100px) 100px, calc(100% - 100px) calc(100% - 100px);
	text-align: center;
}
#security-consulting #firstView #mainVisual svg{
	color: transparent;
	max-width: 1043px;
	margin: 0 auto;
	transition: color 0.8s ease 0.5s;
}
#security-consulting #firstView #mainVisual.is-inview svg{
	color: #FFF;
}
#security-consulting #lead{
	padding-bottom: 465px;
	border-top: 1px solid transparent;
	position: relative;
}
#security-consulting .tit01{
	margin-top: -50px;
	margin-bottom: 198px;
}
#security-consulting .tit02{
	margin-bottom: 100px;
}
#security-consulting .tit02 h3 span:nth-child(2):after{
	border-top-right-radius: 0;
	transition-delay: 0.4s;
}
#security-consulting #lead .txt{
	max-width: 800px;
	margin: 0 auto;
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
}
#security-consulting #lead .txt .pc_paragraph p{
	display: inline;
}
#security-consulting #services{
	background: #E2041B;
	padding: 73px 0 200px 0;
	border-top: 1px solid transparent;
}
#security-consulting #services h3{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	font-size: 100px;
	line-height: 127px;
	vertical-align: bottom;
}
#security-consulting #services .service_area .dummy{
	display: none;
}

/* Agile Development Service
-----------------------------------*/
#agile-development-service #firstView .main_tit{
	padding-top: 74px;
	background: #fff;
	padding-bottom: 656px;
}
#agile-development-service #firstView #image_bloc{
	background-image: url(../images/common/bg_dot.svg);
	padding-bottom: 270px;
	position: relative;
}
#agile-development-service #firstView #mainVisual{
	position: absolute;
	right: 0;
	bottom: 98px;
	max-width: 1460px;
	width: 100%;
	height: 760px;
	background: #E2041B;
	margin-left: auto;
	border-top-left-radius: 20px;
	border-bottom-left-radius: 20px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	color: #fff;
	background-image: url(../images/pages/ico_service_main.svg), url(../images/pages/ico_service_main.svg), url(../images/pages/ico_service_main.svg), url(../images/pages/ico_service_main.svg);
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
	background-position: 100px 100px, 100px calc(100% - 100px), calc(100% - 100px) 100px, calc(100% - 100px) calc(100% - 100px);
}
#agile-development-service #firstView #mainVisual svg{
	color: transparent;
	max-width: 552px;
	margin: 0 auto;
	transition: color 0.8s ease 0.5s;
}
#agile-development-service #firstView #mainVisual.is-inview svg{
	color: #FFF;
}
#agile-development-service .bloc{
	position: relative;
}
#agile-development-service #lead{
	padding-bottom: 250px;
	border-top: 1px solid #E2041B;
}
#agile-development-service .tit01{
	margin-top: -50px;
	margin-bottom: 198px;
}
#agile-development-service .tit02{
	margin-bottom: 100px;
}
#agile-development-service .tit02 h3 span:nth-child(2):after{
	border-top-right-radius: 0;
	transition-delay: 0.4s;
}
#agile-development-service #lead .tit02 h3 span:nth-child(1){
	padding-right: 20px;
}
#agile-development-service #lead .txt{
	max-width: 800px;
	margin: 0 auto 100px auto;
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
}
#agile-development-service #lead .images{
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
#agile-development-service #lead .images li{
	max-width: 245px;
	width: 100%;
}
#agile-development-service #lead .image{
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
}
#agile-development-service #flow{
	padding-bottom: 285px;
	border-top: 1px solid #E2041B;
}
#agile-development-service #flow .list{
	position: relative;
}
#agile-development-service #flow .list:after{
	content: "";
	position: absolute;
	width: 0;
	height: 1px;
	top: 50%;
	background: #E2041B;
	margin-top: -0.5px;
	transition: 0.4s width ease;
	transition-delay: 1s;
}
#agile-development-service #flow .list.is-inview:after{
	width: 100%;
}
#agile-development-service #flow .list ul{
	max-width: 980px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 0 40px;
}
#agile-development-service #flow .list ul li{
	max-width: 300px;
	width: 100%;
	position: relative;
	background: #FFF;
	z-index: 1;
	border: 1px solid #E2041B;
	border-radius: 20px;
	opacity: 0;
	transition: 0.6s opacity ease;
}
#agile-development-service #flow .list.is-inview ul li{
	opacity: 1;
}
#agile-development-service #flow .list ul li:nth-child(1){
	transition-delay: 0.2s;
}
#agile-development-service #flow .list ul li:nth-child(2){
	transition-delay: 0.4s;
}
#agile-development-service #flow .list ul li:nth-child(3){
	transition-delay: 0.6s;
}
#agile-development-service #flow .list ul li:before,
#agile-development-service #flow .list ul li:after{
	content: "";
	position: absolute;
	width: 30px;
	height: 30px;
	background: #FFF;
	z-index: 2;
}
#agile-development-service #flow .list ul li:before{
	top: -1px;
	right: -1px;
}
#agile-development-service #flow .list ul li:after{
	bottom: -1px;
	left: -1px;
}
#agile-development-service #flow .list ul li .box{
	width: 100%;
	height: 298px;
	padding: 30px 29px 34px 29px;
	display: flex;
	flex-direction: column;
}
#agile-development-service #flow .list ul li .box:before,
#agile-development-service #flow .list ul li .box:after{
	content: "";
	background: #E2041B;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	position: absolute;
	z-index: 4;
}
#agile-development-service #flow .list ul li .box:before{
	top: -1px;
	right: -1px;
}
#agile-development-service #flow .list ul li .box:after{
	bottom: -1px;
	left: -1px;
}
#agile-development-service #flow .list ul li .dot{
	background: #E2041B;
	width: 5px;
	height: 5px;
	position: absolute;
	border-radius: 50%;
	top: calc(50% + 1px);
	right: -25px;
	transform: translate(-50%, -50%);
}
#agile-development-service #flow .list ul li:last-child .dot{
	display: none;
}
#agile-development-service #flow .list ul li .box h3{
	font-size: 16px;
	font-weight: 700;
	line-height: 18px;
	margin-bottom: 17px;
}
#agile-development-service #flow .list ul li .box h3 span{
	display: block;
	font-size: 12px;
	line-height: 14px;
	margin-bottom: 2px;
	font-weight: 500;
}
#agile-development-service #flow .list ul li .box .image{
	text-align: center;
}
#agile-development-service #services{
	background: #E2041B;
	padding: 73px 0 200px 0;
	border-top: 1px solid transparent;
}
#agile-development-service #services h3{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	font-size: 100px;
	line-height: 127px;
	vertical-align: bottom;
}
#agile-development-service #services .service_area .dummy{
	display: none;
}

/* AX DX Consulting
-----------------------------------*/
#axdx-consulting .bloc{
	position: relative;
}
#axdx-consulting #lead{
	padding: 250px 0;
}
#axdx-consulting #lead .txt{
	max-width: 800px;
	margin: 0 auto 100px auto;
	font-size: 36px;
	line-height: 46px;
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #E2041B;
	text-align: center;
}
#axdx-consulting #services{
	background: #E2041B;
	padding: 73px 0 200px 0;
	border-top: 1px solid transparent;
}
#axdx-consulting #services h3{
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	font-size: 100px;
	line-height: 127px;
	vertical-align: bottom;
}


/* Work
-----------------------------------*/
#works{
	background: #FFF;
	padding-top: 74px;
}
#works .tit_h1{
	margin-bottom: 68px;
}
#works .tit01{
	margin-top: -50px;
	margin-bottom: 200px;
}
#works #content{
	border-top: 1px solid #E2041B;
	padding-bottom: 200px;
	position: relative;
}
#works .list02{
	max-width: 980px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 80px 40px;
	position: relative;
}
#works .list02 li{
	max-width: 300px;
	width: 100%;
	position: relative;
	background: #FFF;
	z-index: 1;
}
#works .list02 li:nth-child(3n + 1):after{
	content: "";
	position: absolute;
	width: 0;
	height: 1px;
	background: #E2041B;
	left: calc((100vw - 980px) / -2);
	top: 50%;
	z-index: -1;
	transition: width 0.8s;
}
#works .list02.is-inview li:nth-child(3n + 1):after{
	width: 100vw;
}
#works .list02 li:nth-child(1):after{
	transition-delay: 2s;
}
#works .list02 li:nth-child(4):after{
	transition-delay: 2.2s;
}
#works .list02 li:nth-child(7):after{
	transition-delay: 2.4s;
}
#works .list02.is-inview li a{
	background: #FFF;
	position: relative;
	z-index: 1;
}
#works .list02 li a:before{
	content: "[ More ]";
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	position: absolute;
	border-radius: 20px;
	top: -1px;
	right: -1px;
	bottom: -1px;
	left: -1px;
	background: #E2041B;
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	transition: opacity 0.2s;
	z-index: 3;
}
#works .list02 li a:hover:before{
	opacity: 1;
}
#works .list02 li a .dot01:before,
#works .list02 li a .dot01:after{
	content: "";
	position: absolute;
	width: 30px;
	height: 30px;
	background: #FFF;
	z-index: 2;
}
#works .list02 li a .dot01:before{
	top: -1px;
	right: -1px;
}
#works .list02 li a .dot01:after{
	bottom: -1px;
	left: -1px;
}
#works .list02 li a .dot02:before,
#works .list02 li a .dot02:after{
	content: "";
	background: #E2041B;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	position: absolute;
	z-index: 4;
}
#works .list02 li a .dot02:before{
	top: -1px;
	right: -1px;
}
#works .list02 li a .dot02:after{
	bottom: -1px;
	left: -1px;
}
#works .list02 li a .dot03{
	background: #E2041B;
	width: 5px;
	height: 5px;
	position: absolute;
	border-radius: 50%;
	top: calc(50% + 1px);
	right: -25px;
	transform: translate(-50%, -50%);
}
#works .list02 li:nth-child(3n) .dot03{
	display: none;
}
#works .list02 li a .box{
	display: flex;
	flex-direction: column;
	padding: 30px 29px 34px 29px;
	aspect-ratio: 1 / 1;
	display: flex;
	flex-direction: column;
	z-index: 1;
	border: 1px solid #E2041B;
	background: #FFF;
	border-radius: 20px;
	align-items: center;
	justify-content: center;
}
#works .list02 li a .box .logo{
	margin-bottom: auto;
	aspect-ratio: 240 / 50;
	text-align: left;
}
#works .list02 li a .box .logo img{
	object-fit: contain;
	height: 50px;
	width: auto;
}
#works .list02 li a .box h3{
	margin-bottom: 8px;
	font-size: 16px;
	line-height: 18px;
	font-weight: bold;
	margin-top: 20px;
}
#works .list02 li a .box .cont{
	font-size: 12px;
	line-height: 14px;
	font-weight: 500;
}
#works .list02 li a .box .cats{
	font-size: 10px;
	line-height: 15px;
	font-weight: 500;
}
#works .list{
	position: relative;
	margin-bottom: 40px;
}
#works .list:after{
	content: "";
	position: absolute;
	width: 0;
	height: 1px;
	margin-top: -0.5px;
	top: 50%;
	background: #E2041B;
	transition: 0.4s width ease;
	transition-delay: 1s;
}
#works .list:nth-child(1):after{
	transition-delay: 0.8s;
}
#works .list:nth-child(2):after{
	transition-delay: 1.2s;
}
#works .list:nth-child(3):after{
	transition-delay: 1.6s;
}
#works .list.is-inview:after{
	width: 100%;
}
#works .list ul{
	max-width: 980px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 0 40px;
	position: relative;
}
#works .list ul li{
	max-width: 300px;
	width: 100%;
	position: relative;
	background: #FFF;
	z-index: 1;
	opacity: 0;
	transition: 0.6s opacity ease;
}
#works .list.is-inview ul li{
	opacity: 1;
}
#works .list:nth-child(1) ul li:nth-child(1){
	transition-delay: 0.2s;
}
#works .list:nth-child(1) ul li:nth-child(2){
	transition-delay: 0.3s;
}
#works .list:nth-child(1) ul li:nth-child(3){
	transition-delay: 0.4s;
}
#works .list:nth-child(2) ul li:nth-child(1){
	transition-delay: 0.5s;
}
#works .list:nth-child(2) ul li:nth-child(2){
	transition-delay: 0.6s;
}
#works .list:nth-child(2) ul li:nth-child(3){
	transition-delay: 0.7s;
}
#works .list:nth-child(3) ul li:nth-child(1){
	transition-delay: 0.8s;
}
#works .list:nth-child(3) ul li:nth-child(2){
	transition-delay: 0.9s;
}
#works .list:nth-child(3) ul li:nth-child(3){
	transition-delay: 1.0s;
}
#works .list ul li:before,
#works .list ul li:after{
	content: "";
	position: absolute;
	width: 30px;
	height: 30px;
	background: #FFF;
	z-index: 2;
}
#works .list ul li:before{
	top: -1px;
	right: -1px;
}
#works .list ul li:after{
	bottom: -1px;
	left: -1px;
}
#works .list ul li a{
	display: block;
	position: relative;
	border: 1px solid #E2041B;
	border-radius: 20px;
}
#works .list ul li a .box{
	width: 100%;
	height: 298px;
	padding: 30px 29px 34px 29px;
	display: flex;
	flex-direction: column;
}
/*#works .list ul li:nth-child(1) a .box:before{
    content: "";
    position: absolute;
    width: 100vw;
    height: 1px;
    background: #000;
    left: calc((100vw - 980px) / -2);
    top: 50%;
    z-index: -1;
}*/
#works .list ul li a .box:after{
	content: "[ More ]";
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	position: absolute;
	border-radius: 20px;
	top: -1px;
	right: -1px;
	bottom: -1px;
	left: -1px;
	background: #E2041B;
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	transition: opacity 0.2s;
	z-index: 3;
}
#works .list ul li a:hover .box:after{
	opacity: 1;
}
#works .list ul li a:before,
#works .list ul li a:after{
	content: "";
	background: #E2041B;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	position: absolute;
	z-index: 4;
}
#works .list ul li a:before{
	top: -1px;
	right: -1px;
}
#works .list ul li a:after{
	bottom: -1px;
	left: -1px;
}
#works .list ul li .dot{
	background: #E2041B;
	width: 5px;
	height: 5px;
	position: absolute;
	border-radius: 50%;
	top: calc(50% + 1px);
	right: -25px;
	transform: translate(-50%, -50%);
}
#works .list ul li:last-child .dot{
	display: none;
}
#works .list ul li a .logo{
	margin-bottom: auto;
	aspect-ratio: 240 / 50;
	text-align: left;
}
#works .list ul li a .logo img{
	object-fit: contain;
	height: 50px;
	width: auto;
}
#works .list ul li a h3{
	margin-bottom: 8px;
	font-size: 16px;
	line-height: 18px;
	font-weight: bold;
	margin-top: auto;
}
#works .list ul li a .cont{
	font-size: 12px;
	line-height: 14px;
	min-height: 28px;
	font-weight: 500;
}
#works .list ul li a .cats{
	font-size: 10px;
	line-height: 15px;
	font-weight: 500;
}
#works .tit h3{
	padding-bottom: 20px;
	margin-bottom: 100px;
	position: relative;

	display: flex;
	align-items: center;
	justify-content: space-between;
}
#works .tit h3:after{
	content: "";
	position: absolute;
	bottom: 0;
	height: 1px;
	width: calc(100% + 29.1667vw);
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
	right: 0;
}
#works .tit h3 .cont{
	order: 1;
}
#works .tit h3 .cont .date-cats{
	display: flex;
	align-items: center;
	margin-bottom: 2px;
}
#works .tit h3 .cont .date-cats .date{
	font-size: 12px;
	margin-right: 13px;
	line-height: 14px;
}
#works .tit h3 .cont .date-cats .cats{
	font-size: 10px;
	line-height: 16px;
	padding: 0 4px;
	border-left: 1px solid #E2041B;
	border-right: 1px solid #E2041B;
	min-width: 80px;
	text-align: center;
}
#works .tit h3 .logo{
	order: 2;
	margin-bottom: auto;
	aspect-ratio: 240 / 50;
	text-align: right;
	max-width: 240px;
	width: 100%;
}
#works .tit h3 .logo img{
	object-fit: contain;
	height: 50px;
	width: auto;
}
#works .tit h3 span{
	font-size: 20px;
	line-height: 30px;
	font-weight: bold;
	color: #E2041B;

	display: inline-block;
	min-height: 60px;
}
#works #content #works_content{
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
}
#works #content #works_content h1{
	font-size: 22px;
	line-height: 32px;
	font-weight: bold;
	color: #E2041B;
	margin-bottom: 40px;
}
#works #content #works_content h2{
	position: relative;
	padding-bottom: 12px;
	font-size: 20px;
	font-weight: bold;
	line-height: 24px;
	margin-bottom: 40px;
}
#works #content #works_content h2:after{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	height: 1px;
	width: 100%;
	background-image: linear-gradient(to right, #333333, #333333 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#works #content #works_content .blocs{
	margin-bottom: 100px;
}
#works #content #works_content .blocs:last-of-type{
	margin-bottom: 0;
}
#works #content #works_content .blocs *:last-child{
	margin-bottom: 0;
}
#works #content #works_content *:last-child{
	margin-bottom: 0;
}
#works #content #works_content h3{
	font-size: 16px;
	font-weight: bold;
	line-height: 24px;
	margin-bottom: 20px;
}
#works #content #works_content h4,
#works #content #works_content h5,
#works #content #works_content h6{
	font-weight: bold;
	margin-bottom: 20px;
}
#works #content #works_content ul{
	margin-bottom: 40px;
}
#works #content #works_content ul li:before{
	content: "・";
}
#works #content #works_content ol{
	list-style-type: decimal;
	list-style-position: inside;
	margin-bottom: 40px;
}
#works #content #works_content li{
	margin-bottom: 3px;
}
#works #content #works_content table{
	width: 100%;
	line-height: 24px;
	font-size: 14px;
}
#works #content #works_content table th,
#works #content #works_content table td{
	padding: 15px;
	border: 1px solid #ccc;
	vertical-align: middle;
	text-align: left;
}
#works #content #works_content table thead th{
	background: #111;
	color: #FFF;
	text-align: center;
	font-weight: bold;
}
#works #content #works_content table tbody th{
	background: #ececec;
	font-weight: 500;
}
#works #content #works_content p:has(img){
	margin-bottom: 40px;
	text-align: center;
}
#works #content #works_content blockquote{
	background: #E9E9E9;
	padding: 37px 40px;
	border-radius: 20px;
	font-size: 14px;
	line-height: 22px;
	margin: 40px 0;
}
#works #content #works_content blockquote strong{
	font-weight: bold;
}
#works #content #works_content blockquote p{
	margin-bottom: 22px;
}
#works #content #works_content blockquote p:last-child{
	margin-bottom: 0;
}
#works #content #works_content strong{
	font-weight: bold;
}
#works #content #works_content hr{
	margin: 40px 0;
}
#works #content #works_content p{
	margin-bottom: 40px;
}
#works #content #works_content em{
	font-style: italic;
}
#works #content #works_content a{
	text-decoration: underline;
	color: #E2041B;
}
#works #content #works_content .sing_list{
	border-radius: 20px;
	padding: 40px;
	position: relative;
}
#works #content #works_content .sing_list .outline{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
#works #content #works_content .sing_list li{
	padding-bottom: 40px;
	margin-bottom: 40px;
	line-height: 24px;
	font-size: 14px;
	font-weight: 400;
	position: relative;
}
#works #content #works_content .sing_list li:before{
	display: none;
}
#works #content #works_content .sing_list li:after{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	height: 1px;
	width: 100%;
	background-image: linear-gradient(to right, 333333, 333333 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#works #content #works_content .sing_list li h2{
	font-size: 16px;
	margin-bottom: 10px;
	line-height: 24px;
	font-weight: bold;
	margin-bottom: 10px;
	padding-bottom: 0;
}
#works #content #works_content .sing_list li h2:after{
	display: none;
}
#works #content #works_content .sing_list li h2:before{
	content: "・";
}
#works #content #works_content .sing_list li:last-of-type{
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}
#works #content #works_content .sing_list li p{
	margin-bottom: 0;
}
#works #content #works_content .sing_list li:last-of-type:after{
	display: none;
}

/* Single
-----------------------------------*/
#pagenavi{
	padding: 41px 0 38px 0;
	border-top: 1px solid #E2041B;
	border-bottom: 1px solid #E2041B;
}
#pagenavi .box{
	display: flex;
	justify-content: space-between;
	font-family: "din-2014", sans-serif;
	font-size: 16px;
	line-height: 20px;
	font-weight: bold;
}
#pagenavi .box .disabled{
	color: #E9E9E9;
}
#pagenavi .box .prev-link,
#pagenavi .box .next-link{
	position: relative;
	transition: color 0.2s;
}
#pagenavi .box .prev-link{
	padding-left: 40px;
}
#pagenavi .box .next-link{
	padding-right: 40px;
}
#pagenavi .box a.prev-link:hover,
#pagenavi .box a.next-link:hover{
	color: #E2041B;
}
#pagenavi .box .prev-link:after,
#pagenavi .box .next-link:after{
	content: "";
	width: 20px;
	height: 1px;
	position: absolute;
	top: 50%;
	background: #333;
	transition: background 0.2s;
}
#pagenavi .box .prev-link:after{
	left: 10px;
}
#pagenavi .box .next-link:after{
	right: 10px;
}
#pagenavi .box .prev-link.disabled:after,
#pagenavi .box .next-link.disabled:after{
	background: #E9E9E9;
}
#pagenavi .box a.prev-link:hover:after,
#pagenavi .box a.next-link:hover:after{
	background: #E2041B;
}
#news-list .tit01{
	margin-top: -50px;
	margin-bottom: 200px;
}
#news-list{
	background: #FFF;
	padding-top: 74px;
}
#news-list .tit_h1{
	margin-bottom: 68px;
}
#news-list #single_list{
	border-top: 1px solid #E2041B;
	position: relative;
	padding-bottom: 200px;
	min-height: 1100px;
}
#news-list #single_list .nopost{
	max-width: 980px;
	width: 100%;
	margin: 0 auto;
	font-size: 16px;
	line-height: 24px;
	font-weight: bold;
	color: #E2041B;
}
#news-list #single_list ul{
	max-width: 980px;
	width: 100%;
	margin: 0 auto;
}
#news-list #single_list ul li{
	margin-bottom: 2px;
}
#news-list #single_list ul li:last-child{
	margin-bottom: 0;
}
#news-list #single_list ul li a{
	display: block;
	background: #F6F6F6;
	padding: 31px 30px 30px 30px;
	position: relative;
	transition: color 0.2s;
}
#news-list #single_list ul li a:hover{
	color: #E2041B;
}
#news-list #single_list ul li a .date-cats{
	display: flex;
	align-items: center;
	margin-bottom: 2px;
}
#news-list #single_list ul li a .date-cats .date{
	font-size: 12px;
	margin-right: 13px;
	line-height: 14px;
}
#news-list #single_list ul li a .date-cats .cats{
	font-size: 10px;
	line-height: 16px;
	padding: 0 4px;
	border-left: 1px solid #E2041B;
	border-right: 1px solid #E2041B;
	min-width: 80px;
	text-align: center;
}
#news-list #single_list ul li a h3{
	font-size: 16px;
	line-height: 24px;
	font-weight: bold;
	padding-right: 120px;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
	font-weight: bold;
}
#news-list #single_list ul li a .ico{
	position: absolute;
	top: 50%;
	right: 30px;
	transform: translateY(-50%);
}
#news-single .tit01{
	margin-top: -50px;
	margin-bottom: 200px;
}
#news-single{
	background: #FFF;
	padding-top: 74px;
}
#news-single .tit_h1{
	margin-bottom: 68px;
}
#news-single .tit h3{
	padding-bottom: 20px;
	margin-bottom: 100px;
	position: relative;
}
#news-single .tit h3:after{
	content: "";
	position: absolute;
	bottom: 0;
	height: 1px;
	width: calc(100% + 29.1667vw);
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
	right: 0;
}
#news-single .tit h3 .date-cats{
	display: flex;
	align-items: center;
	margin-bottom: 2px;
}
#news-single .tit h3 .date-cats .date{
	font-size: 12px;
	margin-right: 13px;
	line-height: 14px;
}
#news-single .tit h3 .date-cats .cats{
	font-size: 10px;
	line-height: 16px;
	padding: 0 4px;
	border-left: 1px solid #E2041B;
	border-right: 1px solid #E2041B;
	min-width: 80px;
	text-align: center;
}
#news-single .tit h3 span{
	font-size: 20px;
	line-height: 30px;
	font-weight: bold;
	color: #E2041B;

	display: inline-block;
	min-height: 60px;
}
#news-single #content{
	border-top: 1px solid #E2041B;
	position: relative;
	padding-bottom: 200px;
}
#news-single #content .single_content{
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
}
#news-single #content .single_content h1{
	font-size: 22px;
	line-height: 32px;
	font-weight: bold;
	color: #E2041B;
	margin-bottom: 40px;
}
#news-single #content .single_content h2{
	position: relative;
	padding-bottom: 12px;
	font-size: 20px;
	font-weight: bold;
	line-height: 24px;
	margin-bottom: 40px;
}
#news-single #content .single_content h2:after{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	height: 1px;
	width: 100%;
	background-image: linear-gradient(to right, #333333, #333333 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#news-single #content .single_content .blocs{
	margin-bottom: 100px;
}
#news-single #content .single_content .blocs:last-of-type{
	margin-bottom: 0;
}
#news-single #content .single_content .blocs *:last-child{
	margin-bottom: 0;
}
#news-single #content .single_content *:last-child{
	margin-bottom: 0;
}
#news-single #content .single_content h3{
	font-size: 16px;
	font-weight: bold;
	line-height: 24px;
	margin-bottom: 20px;
}
#news-single #content .single_content h4,
#news-single #content .single_content h5,
#news-single #content .single_content h6{
	font-weight: bold;
	margin-bottom: 20px;
}
#news-single #content .single_content ul{
	margin-bottom: 40px;
}
#news-single #content .single_content ul li:before{
	content: "・";
}
#news-single #content .single_content ol{
	list-style-type: decimal;
	list-style-position: inside;
	margin-bottom: 40px;
}
#news-single #content .single_content li{
	margin-bottom: 3px;
}
#news-single #content .single_content table{
	width: 100%;
	line-height: 24px;
	font-size: 14px;
}
#news-single #content .single_content table th,
#news-single #content .single_content table td{
	padding: 15px;
	border: 1px solid #ccc;
	vertical-align: middle;
	text-align: left;
}
#news-single #content .single_content table thead th{
	background: #111;
	color: #FFF;
	text-align: center;
	font-weight: bold;
}
#news-single #content .single_content table tbody th{
	background: #ececec;
	font-weight: 500;
}
#news-single #content .single_content p:has(img){
	margin-bottom: 40px;
	text-align: center;
}
#news-single #content .single_content blockquote{
	background: #E9E9E9;
	padding: 37px 40px;
	border-radius: 20px;
	font-size: 14px;
	line-height: 22px;
	margin: 40px 0;
}
#news-single #content .single_content blockquote strong{
	font-weight: bold;
}
#news-single #content .single_content blockquote p{
	margin-bottom: 22px;
}
#news-single #content .single_content blockquote p:last-child{
	margin-bottom: 0;
}
#news-single #content .single_content strong{
	font-weight: bold;
}
#news-single #content .single_content hr{
	margin: 40px 0;
}
#news-single #content .single_content p{
	margin-bottom: 40px;
}
#news-single #content .single_content em{
	font-style: italic;
}
#news-single #content .single_content a{
	text-decoration: underline;
	color: #E2041B;
}
#news-single #content .single_content .sing_list{
	border-radius: 20px;
	padding: 40px;
	position: relative;
	border: 1px dashed #ccc;
}
#news-single #content .single_content .sing_list .outline{
	display: none;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
#news-single #content .single_content .sing_list li{
	padding-bottom: 40px;
	margin-bottom: 40px;
	line-height: 24px;
	font-size: 14px;
	font-weight: 400;
	position: relative;
}
#news-single #content .single_content .sing_list li:before{
	display: none;
}
#news-single #content .single_content .sing_list li:after{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	height: 1px;
	width: 100%;
	background-image: linear-gradient(to right, #333333, #333333 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#news-single #content .single_content .sing_list li h2{
	font-size: 16px;
	margin-bottom: 10px;
	line-height: 24px;
	font-weight: bold;
	margin-bottom: 10px;
	padding-bottom: 0;
}
#news-single #content .single_content .sing_list li h2:after{
	display: none;
}
#news-single #content .single_content .sing_list li h2:before{
	content: "・";
}
#news-single #content .single_content .sing_list li:last-of-type{
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}
#news-single #content .single_content .sing_list li:last-of-type:after{
	display: none;
}
#news-single #content .single_content .sing_list li p{
	margin-bottom: 0;
}

/* Contact
-----------------------------------*/
#contact{
	padding-top: 74px;
}
#contact .tit_h1{
	margin-bottom: 68px;
}
#contact .tit01{
	margin-top: -50px;
	margin-bottom: 198px;
}
#contact #content{
	border-top: 1px solid #E2041B;
	padding-bottom: 200px;
	position: relative;
}
#contact #content .txt{
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
	max-width: 800px;
	width: 100%;
	margin: 0 auto 100px auto;
}
#contact #content .txt p{
	margin-bottom: 24px;
}
#contact #content .txt p:last-child{
	margin-bottom: 0;
}
#contact #content .table{
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
}
#contact #content .table{
	position: relative;
	padding: 100px 0;
}
#contact #content .table:before,
#contact #content .table:after{
	content: "";
	position: absolute;
	height: 1px;
	width: calc(100% + 29.1667vw);
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#contact #content .table:before{
	top: 0;
	left: -29.1667vw;
}
#contact #content .table:after{
	bottom: 0;
	right: -29.1667vw;
}
#contact #content .table table{
	width: 100%;
}
#contact #content .table table th,
#contact #content .table table td{
	vertical-align: top;
	text-align: left;
	padding-bottom: 30px;
	font-size: 16px;
	line-height: 24px;
}
#contact #content .table table th{
	width: 180px;
	font-weight: bold;
	padding-top: 13px;
}
#contact #content .table .confirm_area table th{
	padding-top: 0;
}
#contact #content .table table th span{
	color: #E2041B;
}
#contact #content .table table td input:not([type="checkbox"]),
#contact #content .table table td select,
#contact #content .table table td textarea{
	width: 100%;
	padding: 13px 20px;
	font-size: 16px;
	line-height: 24px;
}
#contact #content .table table td input:not([type="checkbox"])::placeholder,
#contact #content .table table td textarea::placeholder{
	color: #999;
}
#contact #content .table table td input:not([type="checkbox"]),
#contact #content .table table td textarea{
	background: #F6F6F6;
	border: none;
	outline-style: none;
	-webkit-appearance: none;
	   -moz-appearance: none;
	        appearance: none;
}
#contact #content .table table td select{
	border: 1px dashed #333;
	background: #FFF;
	-webkit-appearance: none;
	   -moz-appearance: none;
	        appearance: none;
}
#contact #content .table table td .privacy{
	font-weight: 400;
	margin-bottom: 30px;
}
#contact #content .table table td .privacy .check{
	display: flex;
	align-items: center;
}
#contact #content .table table td .privacy .red{
	color: #E2041B;
}
#contact #content .table table td .privacy input{
	padding: 0;
	margin: 0;
	width: 20px;
	height: 20px;
	border: 1px solid #acacac;
	border-radius: 0;
	margin-right: 8px;
	margin-left: 20px;
}
#contact #content .table table td .privacy a{
	text-decoration: underline;
}
#contact #content .table table td .privacy .wpcf7-not-valid-tip{
	display: none;
}
#contact #content .table table td .privacy .wpcf7-list-item{
	margin: 0;
}
#contact #content .table table td .privacy .wpcf7-list-item-label{
	display: none;
}
#contact #content .table table td .privacy .error{
	display: none;
	color: #dc3232;
	font-weight: normal;
	font-size: 11px;
	line-height: 16px;
	margin-top: 5px;
}
#contact #content .table table td .privacy .wpcf7-form-control-wrap{
	display: flex;
	align-items: center;
	justify-content: center;
}
#contact #content .table table td .privacy:has(.wpcf7-not-valid-tip) .error{
	display: block;
}
#contact #content .table table td .select_area{
	position: relative;
}
#contact #content .table table td .select_area:after{
	content: "";
	position: absolute;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 6px 0 6px;
	border-color: #333 transparent transparent transparent;
	top: 50%;
	right: 12px;
}
#contact #content .table table td button[disabled]{
	/*background: #acacac;*/
	border: 1px dashed #D9041A;
	color: #333;
}
#contact #content .table table td button,
#contact #content .table table td input[type="submit"]{
	display: block;
	cursor: pointer;
	max-width: 100%;
	width: 100%;
	font-size: 16px;
	line-height: 24px;
	padding: 13px 20px;
	font-weight: bold;
	border: 1px dashed #D9041A;
	color: #333;
	background: none;
	outline-style: none;
	-webkit-appearance: none;
	   -moz-appearance: none;
	        appearance: none;
}
#contact #content .table table td .btns .prev{
	margin-top: 20px;
}
#contact #content .table table td .wpcf7-not-valid-tip{
	font-size: 11px;
	line-height: 16px;
	margin-top: 5px;
}
.confirm_area{
	display: none;
}

/* Privacy Policy
-----------------------------------*/
#privacy-policy{
	background: #FFF;
	padding-top: 74px;
}
#privacy-policy .tit_h1{
	margin-bottom: 68px;
}
#privacy-policy .tit01{
	margin-top: -50px;
	margin-bottom: 198px;
}
#privacy-policy #content{
	border-top: 1px solid #E2041B;
	padding-bottom: 200px;
	position: relative;
}
#privacy-policy #content .txt{
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
	max-width: 800px;
	width: 100%;
	margin: 0 auto 100px auto;
}
#privacy-policy #content .table{
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
}
#privacy-policy #content .table{
	position: relative;
	padding: 100px 0;
}
#privacy-policy #content .table:before,
#privacy-policy #content .table:after{
	content: "";
	position: absolute;
	height: 1px;
	width: calc(100% + 29.1667vw);
	background-image: linear-gradient(to right, #E2041B, #E2041B 1px, transparent 1px, transparent 4px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
}
#privacy-policy #content .table:before{
	top: 0;
	left: -29.1667vw;
}
#privacy-policy #content .table:after{
	bottom: 0;
	right: -29.1667vw;
}
#privacy-policy #content .table table{
	width: 100%;
	max-width: 580px;
	margin: 0 auto;
}
#privacy-policy #content .table table th,
#privacy-policy #content .table table td{
	font-size: 16px;
	line-height: 24px;
	vertical-align: top;
	text-align: left;
}
#privacy-policy #content .table table th{
	width: 162px;
	display: flex;
	justify-content: space-between;
}
#privacy-policy #content .table table th:after{
	content: "：";
}
#privacy-policy #content .table table td{
	font-weight: 400;
	padding-left: 18px;
	padding-bottom: 30px;
}
#privacy-policy #content .table table tbody tr:last-child td{
	padding-bottom: 0;
}
#privacy-policy #content .table table td ul{
	font-size: 14px;
	line-height: 22px;
	margin-top: 3px;
}
#privacy-policy #content .table table td ul li{
	padding-left: 1em;
	text-indent: -1em;
}
#privacy-policy #content .table table td .list_address li{
	padding-left: 4.15em;
	text-indent: -4.15em;
}
#privacy-policy #content .table table td ul li:before{
	content: "・";
}

/* Legal Notice
-----------------------------------*/
#legal-notice{
	background: #FFF;
	padding-top: 74px;
}
#legal-notice .tit_h1{
	margin-bottom: 68px;
}
#legal-notice .tit01{
	margin-top: -50px;
	margin-bottom: 198px;
}
#legal-notice #content{
	border-top: 1px solid #E2041B;
	padding-bottom: 200px;
	position: relative;
}
#legal-notice #content .txt{
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
	max-width: 800px;
	width: 100%;
	margin: 0 auto 100px auto;
}
#legal-notice #content .table{
	max-width: 580px;
	width: 100%;
	margin: 0 auto;
}
#legal-notice #content .table table{
	width: 100%;
}
#legal-notice #content .table table th,
#legal-notice #content .table table td{
	font-size: 16px;
	line-height: 24px;
	vertical-align: top;
	text-align: left;
}
#legal-notice #content .table table th{
	width: 162px;
	display: flex;
	justify-content: space-between;
}
#legal-notice #content .table table th:after{
	content: "：";
}
#legal-notice #content .table table td{
	font-weight: 400;
	padding-left: 18px;
	padding-bottom: 30px;
}
#legal-notice #content .table table tbody tr:last-child td{
	padding-bottom: 0;
}
#legal-notice #content .table table td ul{
	font-size: 14px;
	line-height: 22px;
	margin-top: 3px;
}
#legal-notice #content .table table td ul li{
	padding-left: 1em;
	text-indent: -1em;
}
#legal-notice #content .table table td ul li:before{
	content: "・";
}
#legal-notice #content .table table td a{
	text-decoration: underline;
}

/* Not Found
-----------------------------------*/
#notfound{
	background: #FFF;
	padding-top: 74px;
}
#notfound .tit_h1{
	margin-bottom: 68px;
}
#notfound .tit01{
	margin-top: -50px;
	margin-bottom: 198px;
}
#notfound #content{
	border-top: 1px solid #E2041B;
	padding-bottom: 200px;
	position: relative;
}
#notfound #content .txt{
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
	max-width: 800px;
	width: 100%;
	margin: 0 auto 100px auto;
}
#notfound #content .txt p{
	margin-bottom: 24px;
}
#notfound #content .txt p:last-child{
	margin-bottom: 0;
}


/* 1700px以下の場合 */
@media screen and (max-width: 1700px) {
	/* SPARQX
	-----------------------------------*/
	#service #services .service_area{
		display: flex;
		padding: 0 14.1026vw;
	}
	#service #services .service_area:before,
	#service #services .service_area:after{
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: 50%;
		flex-shrink: 0;
		position: absolute;
		opacity: 1;
		transition: none;
	}
	#service #services .service_area.is-inview:before,
	#service #services .service_area.is-inview:after{
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		border: 1px solid #fff;
	}
	#service #services .service_area.is-inview:before{
		border-left: none;
	}
	#service #services .service_area.is-inview:after{
		border-right: none;
	}
	#service #services .service_area{
		position: relative;
	}
	#service #services .service_area:before{
		bottom: 2px;
		left: 0;
		height: calc(50% - 3px);
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
	}
	#service #services .service_area:after{
		margin-left: 0;
		bottom: 2px;
		right: 0;
		height: calc(50% - 3px);
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
	}
	#service #services .service_area ul{
		max-width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding-bottom: 0;
	}
	#service #services .service_area ul:before{
		content: "";
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-left: none;
		position: absolute;
		left: 0;
		top: 1px;
	}
	#service #services .service_area ul:after{
		content: "";
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-right: none;
		position: absolute;
		right: 0;
		top: 1px;
	}
	#service #services .service_area ul li{
		width: 50%;
		position: relative;
		margin-left: -1px;
		margin-top: -1px;
		border-radius: 2.5641vw;
	}
	#service #services .service_area ul li:nth-child(1),
	#service #services .service_area ul li:nth-child(3){
		margin-left: 0;
	}
	#service #services .service_area .dummy{
		background: #E2041B;
		border: 1px solid #fff;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	#service #services .service_area .dummy .ico{
		max-width: 7.0588vw;
	}
	#service #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#service #services .service_area ul li a .ico{
		margin-bottom: 3.8462vw;
	}
	#service #services .service_area ul li a .ico svg{
		max-width: 9.7436vw;
		max-width: 6.6667vw;
	}
	#service #services .service_area ul li a .ico2{
		right: 2.5641vw;
		bottom: 2.5641vw;
		max-width: 1.7949vw;
		line-height: 1;
	}
	#service #services .service_area ul li a .ico2 svg{
		max-width: 1.7949vw;
	}
	#service #services .service_area ul li a .txt{
		font-size: 1.2821vw;
		line-height: 1.7949vw;
		margin-bottom: 0.5128vw;
	}
	#service #services .service_area ul li a h4{
		font-size: 1.7949vw;
		line-height: 2.8205vw;
		margin-bottom: 3.8462vw;
	}
	#service #services .service_area ul li a .cont{
		display: block;
		font-size: 1.2821vw;
		line-height: 2.0513vw;
		margin-bottom: 3.8462vw;
	}
	#service #services .service_area ul li a .more{
		font-size: 1.2821vw;
		line-height: 3.3333vw;
	}

	/* SPARQX
	-----------------------------------*/
	#sparqx #services .service_area{
		display: flex;
		padding: 0 14.1026vw;
	}
	#sparqx #services .service_area:before,
	#sparqx #services .service_area:after{
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: 50%;
		flex-shrink: 0;
		position: absolute;
		opacity: 1;
		transition: none;
	}
	#sparqx #services .service_area.is-inview:before,
	#sparqx #services .service_area.is-inview:after{
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		border: 1px solid #fff;
	}
	#sparqx #services .service_area.is-inview:before{
		border-left: none;
	}
	#sparqx #services .service_area.is-inview:after{
		border-right: none;
	}
	#sparqx #services .service_area{
		position: relative;
	}
	#sparqx #services .service_area:before{
		bottom: 2px;
		left: 0;
		height: calc(50% - 3px);
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
	}
	#sparqx #services .service_area:after{
		margin-left: 0;
		bottom: 2px;
		right: 0;
		height: calc(50% - 3px);
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
	}
	#sparqx #services .service_area ul{
		max-width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding-bottom: 0;
	}
	#sparqx #services .service_area ul:before{
		content: "";
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-left: none;
		position: absolute;
		left: 0;
		top: 1px;
	}
	#sparqx #services .service_area ul:after{
		content: "";
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-right: none;
		position: absolute;
		right: 0;
		top: 1px;
	}
	#sparqx #services .service_area ul li{
		width: 50%;
		position: relative;
		margin-left: -1px;
		margin-top: -1px;
		border-radius: 2.5641vw;
	}
	#sparqx #services .service_area ul li:nth-child(1),
	#sparqx #services .service_area ul li:nth-child(3){
		margin-left: 0;
	}
	#sparqx #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#sparqx #services .service_area ul li a .ico{
		margin-bottom: 3.8462vw;
	}
	#sparqx #services .service_area ul li a .ico svg{
		max-width: 9.7436vw;
		max-width: 6.6667vw;
	}
	#sparqx #services .service_area ul li a .ico2{
		right: 2.5641vw;
		bottom: 2.5641vw;
		max-width: 1.7949vw;
		line-height: 1;
	}
	#sparqx #services .service_area ul li a .ico2 svg{
		max-width: 1.7949vw;
	}
	#sparqx #services .service_area ul li a .txt{
		font-size: 1.2821vw;
		line-height: 1.7949vw;
		margin-bottom: 0.5128vw;
	}
	#sparqx #services .service_area ul li a h4{
		font-size: 1.7949vw;
		line-height: 2.8205vw;
		margin-bottom: 3.8462vw;
	}
	#sparqx #services .service_area ul li a .cont{
		display: none;
	}
	#sparqx #services .service_area ul li a .more{
		font-size: 1.2821vw;
		line-height: 3.3333vw;
	}
	#sparqx #services .service_area .dummy{
		background: #E2041B;
		border: 1px solid #fff;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	#sparqx #services .service_area .dummy .ico{
		max-width: 7.0588vw;
	}

	/* Security Consulting
	-----------------------------------*/
	#security-consulting #services .service_area{
		display: flex;
		padding: 0 14.1026vw;
	}
	#security-consulting #services .service_area:before,
	#security-consulting #services .service_area:after{
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: 50%;
		flex-shrink: 0;
		position: absolute;
		opacity: 1;
		transition: none;
	}
	#security-consulting #services .service_area.is-inview:before,
	#security-consulting #services .service_area.is-inview:after{
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		border: 1px solid #fff;
	}
	#security-consulting #services .service_area.is-inview:before{
		border-left: none;
	}
	#security-consulting #services .service_area.is-inview:after{
		border-right: none;
	}
	#security-consulting #services .service_area{
		position: relative;
	}
	#security-consulting #services .service_area:before{
		bottom: 2px;
		left: 0;
		height: calc(50% - 3px);
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
	}
	#security-consulting #services .service_area:after{
		margin-left: 0;
		bottom: 2px;
		right: 0;
		height: calc(50% - 3px);
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
	}
	#security-consulting #services .service_area ul{
		max-width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding-bottom: 0;
	}
	#security-consulting #services .service_area ul:before{
		content: "";
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-left: none;
		position: absolute;
		left: 0;
		top: 1px;
	}
	#security-consulting #services .service_area ul:after{
		content: "";
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-right: none;
		position: absolute;
		right: 0;
		top: 1px;
	}
	#security-consulting #services .service_area ul li{
		width: 50%;
		position: relative;
		margin-left: -1px;
		margin-top: -1px;
		border-radius: 2.5641vw;
	}
	#security-consulting #services .service_area ul li:nth-child(1),
	#security-consulting #services .service_area ul li:nth-child(3){
		margin-left: 0;
	}
	#security-consulting #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#security-consulting #services .service_area ul li a .ico{
		margin-bottom: 3.8462vw;
	}
	#security-consulting #services .service_area ul li a .ico svg{
		max-width: 9.7436vw;
		max-width: 6.6667vw;
	}
	#security-consulting #services .service_area ul li a .ico2{
		right: 2.5641vw;
		bottom: 2.5641vw;
		max-width: 1.7949vw;
		line-height: 1;
	}
	#security-consulting #services .service_area ul li a .ico2 svg{
		max-width: 1.7949vw;
	}
	#security-consulting #services .service_area ul li a .txt{
		font-size: 1.2821vw;
		line-height: 1.7949vw;
		margin-bottom: 0.5128vw;
	}
	#security-consulting #services .service_area ul li a h4{
		font-size: 1.7949vw;
		line-height: 2.8205vw;
		margin-bottom: 3.8462vw;
	}
	#security-consulting #services .service_area ul li a .cont{
		display: none;
	}
	#security-consulting #services .service_area ul li a .more{
		font-size: 1.2821vw;
		line-height: 3.3333vw;
	}
	#security-consulting #services .service_area .dummy{
		background: #E2041B;
		border: 1px solid #fff;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	#security-consulting #services .service_area .dummy .ico{
		max-width: 7.0588vw;
	}

	/* Agile Development Service
	-----------------------------------*/
	#agile-development-service #services .service_area{
		display: flex;
		padding: 0 14.1026vw;
	}
	#agile-development-service #services .service_area:before,
	#agile-development-service #services .service_area:after{
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: 50%;
		flex-shrink: 0;
		position: absolute;
		opacity: 1;
		transition: none;
	}
	#agile-development-service #services .service_area.is-inview:before,
	#agile-development-service #services .service_area.is-inview:after{
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		border: 1px solid #fff;
	}
	#agile-development-service #services .service_area.is-inview:before{
		border-left: none;
	}
	#agile-development-service #services .service_area.is-inview:after{
		border-right: none;
	}
	#agile-development-service #services .service_area{
		position: relative;
	}
	#agile-development-service #services .service_area:before{
		bottom: 2px;
		left: 0;
		height: calc(50% - 3px);
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
	}
	#agile-development-service #services .service_area:after{
		margin-left: 0;
		bottom: 2px;
		right: 0;
		height: calc(50% - 3px);
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
	}
	#agile-development-service #services .service_area ul{
		max-width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding-bottom: 0;
	}
	#agile-development-service #services .service_area ul:before{
		content: "";
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-left: none;
		position: absolute;
		left: 0;
		top: 1px;
	}
	#agile-development-service #services .service_area ul:after{
		content: "";
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-right: none;
		position: absolute;
		right: 0;
		top: 1px;
	}
	#agile-development-service #services .service_area ul li{
		width: 50%;
		position: relative;
		margin-left: -1px;
		margin-top: -1px;
		border-radius: 2.5641vw;
	}
	#agile-development-service #services .service_area ul li:nth-child(1),
	#agile-development-service #services .service_area ul li:nth-child(3){
		margin-left: 0;
	}
	#agile-development-service #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#agile-development-service #services .service_area ul li a .ico{
		margin-bottom: 3.8462vw;
	}
	#agile-development-service #services .service_area ul li a .ico svg{
		max-width: 9.7436vw;
		max-width: 6.6667vw;
	}
	#agile-development-service #services .service_area ul li a .ico2{
		right: 2.5641vw;
		bottom: 2.5641vw;
		max-width: 1.7949vw;
		line-height: 1;
	}
	#agile-development-service #services .service_area ul li a .ico2 svg{
		max-width: 1.7949vw;
	}
	#agile-development-service #services .service_area ul li a .txt{
		font-size: 1.2821vw;
		line-height: 1.7949vw;
		margin-bottom: 0.5128vw;
	}
	#agile-development-service #services .service_area ul li a h4{
		font-size: 1.7949vw;
		line-height: 2.8205vw;
		margin-bottom: 3.8462vw;
	}
	#agile-development-service #services .service_area ul li a .cont{
		display: none;
	}
	#agile-development-service #services .service_area ul li a .more{
		font-size: 1.2821vw;
		line-height: 3.3333vw;
	}
	#agile-development-service #services .service_area .dummy{
		background: #E2041B;
		border: 1px solid #fff;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	#agile-development-service #services .service_area .dummy .ico{
		max-width: 7.0588vw;
	}

	/* AX DX Consulting
	-----------------------------------*/
	#axdx-consulting #services .service_area{
		display: flex;
		padding: 0 14.1026vw;
	}
	#axdx-consulting #services .service_area:before,
	#axdx-consulting #services .service_area:after{
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: 50%;
		flex-shrink: 0;
		position: absolute;
		opacity: 1;
		transition: none;
	}
	#axdx-consulting #services .service_area.is-inview:before,
	#axdx-consulting #services .service_area.is-inview:after{
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		border: 1px solid #fff;
	}
	#axdx-consulting #services .service_area.is-inview:before{
		border-left: none;
	}
	#axdx-consulting #services .service_area.is-inview:after{
		border-right: none;
	}
	#axdx-consulting #services .service_area{
		position: relative;
	}
	#axdx-consulting #services .service_area:before{
		bottom: 2px;
		left: 0;
		height: calc(50% - 3px);
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
	}
	#axdx-consulting #services .service_area:after{
		margin-left: 0;
		bottom: 2px;
		right: 0;
		height: calc(50% - 3px);
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
	}
	#axdx-consulting #services .service_area ul{
		max-width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding-bottom: 0;
	}
	#axdx-consulting #services .service_area ul:before{
		content: "";
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-left: none;
		position: absolute;
		left: 0;
		top: 1px;
	}
	#axdx-consulting #services .service_area ul:after{
		content: "";
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 71.7949vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-right: none;
		position: absolute;
		right: 0;
		top: 1px;
	}
	#axdx-consulting #services .service_area ul li{
		width: 50%;
		position: relative;
		margin-left: -1px;
		margin-top: -1px;
		border-radius: 2.5641vw;
	}
	#axdx-consulting #services .service_area ul li:nth-child(1),
	#axdx-consulting #services .service_area ul li:nth-child(3){
		margin-left: 0;
	}
	#axdx-consulting #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#axdx-consulting #services .service_area ul li a .ico{
		margin-bottom: 3.8462vw;
	}
	#axdx-consulting #services .service_area ul li a .ico svg{
		max-width: 9.7436vw;
		max-width: 6.6667vw;
	}
	#axdx-consulting #services .service_area ul li a .ico2{
		right: 2.5641vw;
		bottom: 2.5641vw;
		max-width: 1.7949vw;
		line-height: 1;
	}
	#axdx-consulting #services .service_area ul li a .ico2 svg{
		max-width: 1.7949vw;
	}
	#axdx-consulting #services .service_area ul li a .txt{
		font-size: 1.2821vw;
		line-height: 1.7949vw;
		margin-bottom: 0.5128vw;
	}
	#axdx-consulting #services .service_area ul li a h4{
		font-size: 1.7949vw;
		line-height: 2.8205vw;
		margin-bottom: 3.8462vw;
	}
	#axdx-consulting #services .service_area ul li a .cont{
		display: none;
	}
	#axdx-consulting #services .service_area ul li a .more{
		font-size: 1.2821vw;
		line-height: 3.3333vw;
	}
}


/* 1605px以下の場合 */
@media screen and (max-width: 1605px) {
	.service_area:before,
	.service_area:after{
		border: none;
	}
}

/* 1024px以下の場合 */
@media screen and (max-width: 1024px) {

	/* MainVisual
	-----------------------------------*/
	#top #mainVisual{
		margin-top: 17.9487vw;
		/*height: calc(100dvh - 17.9487vw);*/
		height: 152.3077vw;
		width: 100%;
		-ms-overflow: hidden;
		    overflow: hidden;
	}
	#top #mainVisual:after{
		height: 51.2821vw;
	}
	#top #mainVisual h1{
		padding-top: 44.6154vw;
		padding-left: 0;
		max-width: 74.6154vw;
	}
	#top #mainVisual .bnr{
		width: 100%;
		max-width: 104.1026vw;
		max-width: 100vw;
		/*position: fixed;*/
		position: absolute;
		bottom: 0;
		/*right: -95.7vw;*/
		right: calc(-100vw + 3.8462vw);
		z-index: 9996;
		overflow: hidden;
		display: flex;
		align-items: center;
		transition: right 0.6s;
		background: #E2041B;
	}
	#top #mainVisual .bnr.active{
		right: 0;
	}
	#top #mainVisual .bnr .switch{
		display: block;
		writing-mode: vertical-rl;
		text-orientation: mixed;
		line-height: 1;
		text-align: center;
		/*aspect-ratio: 15 / 98;*/
		aspect-ratio: 15 / 100;
		width: 3.8462vw;
		font-size: 2.5641vw;
		line-height: 1.25;
		background: #E2041B;
		color: #fff;
	}
	#top #mainVisual .bnr a{
		/*aspect-ratio: 390 / 98;*/
		aspect-ratio: 375 / 100;
		width: 100vw;
		flex-direction: inherit;
		justify-content: flex-start;
		background: #E2041B;
		border-top: 1px solid #E2041B;
		border-bottom: 1px solid #E2041B;
		border-radius: 0;
	}
	#top #mainVisual .bnr a:hover{
		color: #E2041B;
		background: #FFF;
		opacity: 1;
	}
	#top #mainVisual .bnr a .p01{
		order: 2;
		font-size: 3.0769vw;
		line-height: 5.1282vw;
		margin-bottom: 0;
		font-weight: 400;
		text-align: left;
		padding-left: 4.8718vw;
		padding-right: 6.4103vw;
	}
	#top #mainVisual .bnr a .icons{
		order: 1;
		border-right: 1px solid #fff;
		height: 100%;
		max-width: 25.641vw;
		width: 100%;
		text-align: center;
		display: flex;
		align-items: center;
		justify-content: center;
		flex-direction: column;
		transition: border-color 0.2s;
	}
	#top #mainVisual .bnr a:hover .icons{
		border-color: #E2041B;
	}
	#top #mainVisual .bnr a .icon{
		margin: 0 auto;
		max-width: 6.7872vw;
	}
	#top #mainVisual .bnr a .icon svg{
		max-width: 6.7744vw;
		width: 100%;
		transition: color 0.2s;
	}
	#top #mainVisual .bnr a:hover .icon svg{
		color: #E2041B;
	}
	#top #mainVisual .bnr a h3{
		font-size: 2.5641vw;
		line-height: 3.8462vw;
		margin-bottom: 0;
	}
	#top #mainVisual .bnr a .more{
		display: none;
	}
	#top #mainVisual .bnr a .icon02{
		display: block;
		position: absolute;
		top: 50%;
		right: 3.8462vw;
		width: 4.359vw;
		color: #FFF;
		transform: translateY(-50%);
	}
	#top #mainVisual .bnr a:hover .icon02{
		
	}
	#top #mainVisual .scroll{
		bottom: 44.8718vw;
		margin-left: 1.7949vw;
	}
	#top #purpose{
		padding: 18.4615vw 0 64.1026vw 0;
	}
	#top #purpose:before{
		height: 12.8205vw;
	}
	#top #purpose:after{
		height: 64.1026vw;
	}
	#top #purpose-possibility:after{
		/*background: #FFF;*/
	}
	#top #purpose h2{
		font-size: 11.5385vw;
		margin-bottom: 12.8205vw;
		line-height: 14.8718vw;
	}
	#top #purpose .tit02{
		margin-bottom: 7.6923vw;
	}
	#top #purpose .tit02 h3{
		font-size: 4.6154vw;
		line-height: 8.2051vw;
	}
	#top #purpose .tit02 h3 span{
		padding-left: 14.1026vw;
		padding-right: 3.8462vw;
	}
	#top #purpose .txt{
		max-width: 100%;
		font-size: 3.3333vw;
		line-height: 5.641vw;
		font-weight: 400;
		margin: 0 auto 20.5128vw auto;
		padding: 0 17.9487vw;
	}
	#top #purpose .txt .pc_paragraph{
		margin-bottom: 5.641vw;
	}
	#top #purpose .txt .pc_paragraph p{
		margin-bottom: 5.641vw;
	}
	#top #purpose .txt .pc_paragraph p:last-child{
		margin-bottom: 0;
	}
	#top #purpose .btn{
		max-width: 100%;
		padding: 0 11.5385vw;
	}
	#top #purpose .btn a{
		padding: 0 5.1282vw;
		font-size: 3.0769vw;
		border-radius: 6.4103vw;
		line-height: 12.3077vw;
	}
	#top #possibility .box{
		max-width: 100%;
		padding: 0 0 64.1026vw 0;
	}
	#top #possibility .box:before{
		display: none;
	}
	#top #possibility .box:after{
		height: 64.1026vw;
	}
	#top #possibility .box .question{
		max-width: 76.9231vw;
		margin: 0 auto 10.7692vw auto;
	}
	#top #possibility .box .question .txt{
		max-width: 21.1846vw;
		padding-top: 10.2564vw;
		margin: 0 auto 10.2564vw auto;
	}
	#top #possibility .box .answer{
		max-width: 76.9231vw;
		margin: 0 auto 10.2564vw auto;
	}
	#top #possibility .box .answer .txt{
		max-width: 21.2333vw;
		margin: 0 auto 9.7436vw auto;
	}
	#top #possibility .box .circle{
		max-width: 64.1026vw;
		margin: 0 auto;
	}
	#top #possibility .box .question .p01{
		top: 46.6667vw;
		right: 7.9487vw;
		max-width: 12.8205vw;
	}
	#top #possibility .box .question .p02{
		max-width: 6.4103vw;
		filter: blur(0.5128vw);
		top: 45.641vw;
		right: 1.7949vw;
	}
	#top #possibility .box .question .p03{
		bottom: -6.6667vw;
		left: 8.7179vw;
		max-width: 12.8205vw;
	}
	#top #possibility .box .question .p04{
		max-width: 6.4103vw;
		filter: blur(0.5128vw);
		bottom: 3.3333vw;
		left: 2.0513vw;
	}
	#top #possibility .box .answer .p01{
		max-width: 8.2051vw;
		top: -10.2564vw;
		right: 13.8462vw;
	}
	#top #possibility .box .answer .p02{
		top: 26.6667vw;
		left: 8.9744vw;
		max-width: 13.5897vw;
	}
	#top #possibility .box .answer .p03{
		max-width: 8.2051vw;
		filter: blur(0.5128vw);
		top: 16.6667vw;
		left: 2.0513vw;
	}
	#top #possibility .box .answer .p04{
		max-width: 5.3846vw;
		filter: blur(0.5128vw);
		top: -1.5385vw;
		right: 9.2308vw;
	}
	#top #possibility .box .answer .p05{
		top: 35.641vw;
		right: 6.1538vw;
		max-width: 16.1538vw;
	}
	#top #possibility .box .answer .p06{
		max-width: 9.2308vw;
		filter: blur(0.5128vw);
		top: 35.8974vw;
		right: 0;
	}
	#top #possibility .box .answer .p07{
		bottom: -7.6923vw;
		left: 7.1795vw;
		max-width: 16.1538vw;
	/*transform: rotate(-50deg);*/
	}
	#top #possibility .box .answer .p08{
		max-width: 9.2308vw;
		filter: blur(0.5128vw);
		left: 0.7692vw;
		bottom: 0.7692vw;
	}
	#top #possibility .box .answer .p06 img{
		transform: rotate(10deg);
	}
	#top #possibility .box .btn{
		max-width: 100%;
		padding: 0 11.5385vw;
	}
	#top #possibility .box .btn a{
		padding: 0 5.1282vw;
		font-size: 3.0769vw;
		border-radius: 6.4103vw;
		line-height: 12.3077vw;
	}
	#top #services{
		padding: 8.2051vw 0 3.8462vw 0;
	}
	#top #services h2{
		font-size: 11.5385vw;
		line-height: 14.8718vw;
	}
	#top #services h2:last-of-type{
		display: none;
	}
	.service_area{
		display: block;
		padding: 0 3.8462vw;
	}
	.service_area:before,
	.service_area:after{
		display: none;
	}
	.service_area ul{
		max-width: 100%;
		display: block;
		padding-bottom: 0;
	}
	.service_area ul li{
		width: 100%;
		max-width: 100%;
		margin-left: 0;
		margin-top: -1px;
		border-radius: 5.1282vw;
	}
	.service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	.service_area ul li a .ico{
		margin-bottom: 6.4103vw;
	}
	.service_area ul li a .ico svg{
		max-width: 15.8974vw;
	}
	.service_area ul li a .ico2{
		right: 5.3846vw;
		bottom: 5.3846vw;
		line-height: 1;
	}
	.service_area ul li a .ico2 svg{
		max-width: 4.8718vw;
	}
	.service_area ul li a .txt{
		font-size: 2.5641vw;
		line-height: 3.3333vw;
	}
	.service_area ul li a h4{
		font-size: 4.6154vw;
		line-height: 6.6667vw;
		margin-bottom: 3.8462vw;
	}
	.service_area ul li a h4.sparqx{
		font-size: 5.641vw;
	}
	.service_area ul li a .cont{
		font-size: 3.0769vw;
		line-height: 4.359vw;
		margin-bottom: 7.6923vw;
	}
	.service_area ul li a .more{
		font-size: 2.8205vw;
		line-height: 3.5897vw;
	}

	#top #work{
		padding: 8.2051vw 0 29.4872vw 0;
	}
	#top #work h2{
		font-size: 11.5385vw;
		line-height: 14.8718vw;
	}
	#top #work .list{
	position: relative;
	margin-bottom: 40px;
	}
	#top #work .list:after{
	content: "";
	position: absolute;
	width: 0;
	height: 1px;
	margin-top: -0.5px;
	top: 50%;
	background: #E2041B;
	transition: 0.4s width ease;
	transition-delay: 1s;
	}
	#top #work .list ul{
		max-width: 100%;
		display: block;
	gap: 0 40px;
	}
	#top #work .list ul li{
		max-width: 100%;
		max-width: 76.9231vw;
		opacity: 1;
		transition: none;
		width: 100%;
	}
	#top #work .list ul li:before,
	#top #work .list ul li:after{
	content: "";
	position: absolute;
	width: 30px;
	height: 30px;
	background: #FFF;
	z-index: 2;
	}
	#top #work .list ul li:before{
	top: -1px;
	right: -1px;
	}
	#top #work .list ul li:after{
	bottom: -1px;
	left: -1px;
	}
	#top #work .list.is-inview ul li{
	opacity: 1;
	}
	#top #work .list ul li:nth-child(1){
	transition-delay: 0.2s;
	}
	#top #work .list ul li:nth-child(2){
	transition-delay: 0.4s;
	}
	#top #work .list ul li:nth-child(3){
	transition-delay: 0.6s;
	}
	#top #work .list ul li a{
		width: 100%;
	display: block;
	position: relative;
	border: 1px solid #E2041B;
	border-radius: 20px;
	}
	#top #work .list ul li a .box{
		height: auto;
		aspect-ratio: 1 / 1;
		padding: 7.6923vw 7.4359vw 8.7179vw 7.4359vw;
	}
	#top #work .list ul li a .box:after{
	content: "[ More ]";
	font-family: "din-2014", sans-serif;
	font-weight: 600;
	color: #FFF;
	position: absolute;
	border-radius: 20px;
	top: -1px;
	right: -1px;
	bottom: -1px;
	left: -1px;
	background: #E2041B;
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	transition: opacity 0.2s;
	z-index: 3;
	}
	#top #work .list ul li a:hover .box:after{
	opacity: 1;
	}
	#top #work .list ul li a:before,
	#top #work .list ul li a:after{
	content: "";
	background: #E2041B;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	position: absolute;
	z-index: 4;
	}
	#top #work .list ul li a:before{
	top: -1px;
	right: -1px;
	}
	#top #work .list ul li a:after{
	bottom: -1px;
	left: -1px;
	}
	#top #work .list ul li .dot{
		right: -15px;
	}
	#top #work .list ul li:last-child .dot{
		display: block;
	}
	#top #work .list ul li a .logo{
		padding: 0 5.1282vw;
		width: 100%;
	}
	#top #work .list ul li a .logo img{
		height: 100%;
	}
	#top #work .list ul li a h3{
		margin-bottom: 2.0513vw;
		font-size: 4.1026vw;
		line-height: 4.6154vw;
	}
	#top #work .list ul li a .cont{
		font-size: 3.0769vw;
		line-height: 3.5897vw;
		min-height: 7.1795vw;
	}
	#top #work .list ul li a .cats{
		font-size: 2.5641vw;
		line-height: 3.8462vw;
	}
	#top #work .btn{
		max-width: 100%;
		padding: 0 11.5385vw;
	}
	#top #work .btn a{
		padding: 0 5.1282vw;
		font-size: 3.0769vw;
		border-radius: 6.4103vw;
		line-height: 12.3077vw;
	}
	#top #member{
		margin-top: -3.8462vw;
	}
	#top #member:before,
	#top #member:after{
		height: 79.4872vw;
		transition: none;
	}
	#top #member.is-inview:before,
	#top #member.is-inview:after{
		width: calc((100% - 79.4872vw) / 2);
	}
	#top #member:before{
		border-top-right-radius: 3.8462vw;
		border-bottom-right-radius: 3.8462vw;
	}
	#top #member:after{
		border-top-left-radius: 3.8462vw;
		border-bottom-left-radius: 3.8462vw;
	}
	#top #member a{
		max-width: 79.4872vw;
	}
	#top #member h2{
		font-size: 10.2564vw;
		margin-top: 0;
		line-height: 10.2564vw;
		white-space: nowrap;
		z-index: 3;
	}
	#top #member ul{
		position: relative;
		flex-wrap: wrap;
	}
	#top #member ul:after{
		content: "";
		width: 100%;
		height: 7.6923vw;
		position: absolute;
		left: 0;
		top: 50%;
		background: #3B3B3B;
		transform: translateY(-50%);
		z-index: 1;
		opacity: 0;
		transition: 0.4s opacity 1.4s;
	}
	#top #member.is-inview ul:after{
		opacity: 1;
	}
	#top #member ul li{
		width: 50%;
		aspect-ratio: 1;
		overflow: hidden;
		border-radius: 3.8462vw;
		z-index: 2;
	}
	#top #news{
		padding: 12.0513vw 0 25.641vw 0;
		margin-top: -3.8462vw;
	}
	#top #news h2{
		font-size: 11.5385vw;
		line-height: 14.8718vw;
	}
	#top #news ul{
		max-width: 100%;
		margin: 0 auto 10.2564vw auto;
	}
	#top #news ul li{
		margin-bottom: 0.5128vw;
	}
	#top #news ul li a{
		padding: 3.0769vw 5.1282vw 3.5897vw 5.1282vw;
	}
	#top #news ul li a .date-cats{
		margin-bottom: 0.5128vw;
	}
	#top #news ul li a .date-cats .date{
		font-size: 2.5641vw;
		line-height: 3.5897vw;
		margin-right: 0.7692vw;
	}
	#top #news ul li a .date-cats .cats{
		font-size: 2.3077vw;
		line-height: 2.5641vw;
		padding: 0 1.7949vw;
		min-width: 20.5128vw;
	}
	#top #news ul li a h3{
		font-size: 3.0769vw;
		line-height: 4.6154vw;
		padding-right: 5.1282vw;
	}
	#top #news ul li a .ico{
		right: 5.1282vw;
		max-width: 3.5897vw;
	}
	#top #news .btn{
		max-width: 100%;
		padding: 0 11.5385vw;
	}
	#top #news .btn a{
		padding: 0 5.1282vw;
		font-size: 3.0769vw;
		border-radius: 6.4103vw;
		line-height: 12.3077vw;
	}

	/* title
	-----------------------------------*/
	.tit_h1{
		overflow: hidden;
		width: 100%;
		white-space: nowrap;
		font-size: 11.5385vw;
		margin-bottom: 7.1795vw;
		line-height: 14.8718vw;
	}
	.tit01{
		font-size: 2.5641vw;
		/*line-height: 5.641vw;*/
		line-height: 5.3846vw;
		padding: 0 2.8205vw;
		padding-bottom: 1px;
		border-top-left-radius: 0.7692vw;
		/*max-width: 38.4615vw;*/
		max-width: 38.4615vw;
	}
	.tit02{
		width: 100%;
	}
	.tit02 h3{
		font-size: 4.6154vw;
		/*line-height: 8.2051vw;*/
		line-height: 8.4615vw;
	}
	.tit02 h3 span{
		padding-left: 3.8462vw;
	}
	.tit02 h3 span:after{
		left: 0;
		border-top-right-radius: 0.7692vw;
		border-bottom-right-radius: 0.7692vw;
	}
	.tit02.is-inview h3 span:after{
		width: 100%;
	}
	.tit03{
		width: 100%;
	}
	.tit03 h4{
		font-size: 3.3333vw;
		/*line-height: 6.1538vw;*/
		line-height: 5.8974vw;
	}
	.tit03 h4 span{
		padding-left: 3.8462vw;
	}
	.tit03 h4 span:after{
		left: 0;
		border-top-right-radius: 0.3846vw;
		border-bottom-right-radius: 0.3846vw;
	}
	.tit03.is-inview h4 span:after{
		width: 100%;
	}

	/* Common
	-----------------------------------*/
	#video{
		/*top: 35.1282vw;*/
		top: 17.9487vw;
	}
	#video video{
		/*width: 270.7692vw;
		transform: translateX(-128.2051vw);*/
		right: -60vw;
	}
	#video.sub{
		top: 17.9487vw;
		height: calc(100dvh - 17.9487vw);
	}
	#video.sub video{
		height: 100dvh;

		position: absolute;
		right: -55%;
		/*transform: translateX(-123.5897vw);*/
	}
	.subPage{
		margin-top: 17.9487vw;
	}
	.side_tit{
		font-size: 15.3846vw;
		line-height: 80%;
		padding: 2.5641vw 0 12.8205vw 0;
		top: 15.3846vw;
	}
	.side_tit span{
		/*right: -8px;*/
		overflow: hidden;
		/*vertical-align: bottom;*/
		width: 94px;
		width: 11.4634vw;
	}
	.sidede_left .side_tit{
		line-height: 75%;
	}
	.side_tit span:before,
	.side_tit span:after{
		left: 2px;
	}
	.sidede_left .side_tit span:before,
	.sidede_left .side_tit span:after{
		left: -2px;
	}
	.sidede_left .side_tit span{
		vertical-align: bottom;
	}
	.side_tit_left{
		font-size: 15.3846vw;
	}
	#fixed_nav{
		display: none;
	}
	.fadeUp_pc{
		opacity: 1;
		transform: none;
	}
	.fadeUp_sp{
		opacity: 0;
		transform: translate3d(0, 15px, 0);
		transition: opacity 0.5s ease-in-out, transform 0.5s ease-in-out;
	}
	.fadeUp_sp.is-inview{
		opacity: 1;
		transform: none;
	}

	/* Company
	-----------------------------------*/
	.sp_title{
		display: block;
		max-width: 10.2564vw;
		width: 100%;
		border-right: 1px solid #ccc;
		position: absolute;
		top: 0;
		left: 0;
		height: 100%;
		z-index: 2;
	}
	.sp_title span{
		text-align: left;
		font-size: 2.5641vw;
		line-height: 100%;
		writing-mode: vertical-rl;
		/*text-orientation: mixed;*/
		text-orientation: sideways;
		display: block;
		margin: 0 auto;
		padding: 4.359vw 0 12.8205vw 0;
		position: sticky;
		/*top: 60px;*/
		top: 17.9487vw;
		text-align: center;
		width: auto;
		color: #E2041B;
	}
	.sp_wrap{
		/*max-width: 79.4872vw;*/
		max-width: 100%;
		width: 100%;
		margin: 0 auto;
		/*padding: 0 7.6923vw;*/
		padding: 0 10.2564vw; 
	}
	#company #firstView .main_tit{
		padding-top: 5.1282vw;
		padding-bottom: 35.8974vw;
	}
	#company #firstView .main_tit .tit_h1{
		margin-bottom: 2.5641vw;
	}
	#company #firstView #image_bloc{
		padding-bottom: 30.7692vw;
	}
	#company #firstView #image_bloc .box{
		bottom: 15.3846vw;
	}
	#company #firstView #image_bloc .box .image{
		max-width: 87.1795vw;
		border-top-left-radius: 1.2821vw;
		border-bottom-left-radius: 1.2821vw;
	}
	#company #message{
		/*padding: 12.8205vw 0 31.5385vw 0;*/
		padding: 13.0769vw 0 31.5385vw 0;
		display: flex;
	}
	#company #message .sp_title{
		padding-top: 1px;
	}
	#company #message .tit02{
		margin-bottom: 7.1795vw;
	}
	#company #message .tit02 h3 span:nth-child(1):after{
		border-bottom-right-radius: 0;
	}
	#company #message .tit02 h3 span:nth-child(2):after{
		border-top-right-radius: 0.7692vw;
		border-bottom-right-radius: 0;
	}
	#company #message .tit02 h3 span:nth-child(3):after{
		border-top-right-radius: 0;
		transition-delay: 0.6s;
	}
	#company #message .txt{
		max-width: 100%;
		padding: 0 7.6923vw;
		font-size: 3.3333vw;
		line-height: 5.8974vw;
		margin-bottom: 15.1282vw;
	}
	#company #message .txt p{
		margin-bottom: 5.641vw;
	}
	#company #message .name{
		max-width: 100%;
		padding: 0 7.6923vw;
		font-size: 4.1026vw;
		line-height: 5.641vw;
		letter-spacing: 0;
	}
	#company #message .name span{
		font-size: 3.3333vw;
		line-height: 4.8718vw;
		margin-bottom: 0.5128vw;
	}
	#company #purpose{
		padding-bottom: 31.2821vw;
	}
	#company #purpose .tit01{
		margin-top: -5.641vw;
		/*margin-bottom: 12.8205vw;*/
		margin-bottom: 13.0769vw;
	}
	#company #purpose .tit02{
		margin-bottom: 2.8205vw;
	}
	#company #purpose .tit02 h3 span{
		padding-right: 3.8462vw;
	}
	#company #purpose .tit03{
		margin-bottom: 14.8718vw;
	}
	#company #purpose .tit03 h4 span{
		padding-right: 3.8462vw;
	}
	#company #purpose .tit03 h4 span:nth-child(1){
		padding-bottom: 0.5128vw;
	}
	#company #purpose .tit03 h4 span:nth-child(2){
		line-height: 5.8974vw;
		padding-bottom: 0.5128vw;
	}
	#company #purpose h5{
		font-size: 3.8462vw;
		line-height: 5.3846vw;
		padding-bottom: 3.8462vw;
		margin-bottom: 7.1795vw;
		max-width: 100%;
		padding: 0 7.6923vw 2.8205vw 7.6923vw;
	}
	#company #purpose h5 span{
		font-size: 2.5641vw;
		line-height: 5.1282vw;
		margin-bottom: 0;
	}
	#company #purpose h5:after{
		width: 89.7436vw;
	}
	#company #purpose h5:first-of-type:after{
		left: auto;
		right: -10.2564vw;
	}
	#company #purpose h5:last-of-type:after{
		right: -10.2564vw;
	}
	#company #purpose .box01{
		max-width: 100%;
		margin: 0 auto 25.1282vw auto;
		display: block;
		padding: 0 7.6923vw;
	}
	#company #purpose .box01 .txt{
		max-width: 100%;
		font-size: 3.3333vw;
		line-height: 5.8974vw;
		margin-bottom: 7.6923vw;
	}
	#company #purpose .box01 .txt p{
		margin-bottom: 5.8974vw;
	}
	#company #purpose .box01 .image{
		max-width: 51.2821vw;
		margin: 0 auto;
	}
	#company #purpose .box02{
		display: block;
		max-width: 100%;
		padding: 0 7.6923vw;
	}
	#company #purpose .box02 .txt{
		max-width: 100%;
		font-size: 3.3333vw;
		line-height: 5.8974vw;
		margin-bottom: 7.4359vw;
	}
	#company #purpose .box02 .txt p{
		margin-bottom: 5.8974vw;
	}
	#company #purpose .box02 .list{
		max-width: 100%;
	}
	#company #purpose .box02 .list:after{
		width: 7.6923vw;
		height: 7.6923vw;
		background-size: contain;
		transform: translate(-50%, -50%) rotate(90deg);
		z-index: 10;
	}
	#company #purpose .box02 .list ul{
		display: flex;
		justify-content: space-between;
	}
	#company #purpose .box02 .list ul li{
		max-width: 30.7692vw;
		border-radius: 2.5641vw;
		margin-bottom: 0;
	}
	#company #purpose .box02 .list ul li:before,
	#company #purpose .box02 .list ul li:after{
		width: 3.0769vw;
		height: 3.0769vw;
	}
	#company #purpose .box02 .list ul li:before,
	#company #purpose .box02 .list ul li .cont:before{
		top: -1px;
		right: -1px;
	}
	#company #purpose .box02 .list ul li:after,
	#company #purpose .box02 .list ul li .cont:after{
		bottom: -1px;
		left: -1px;
	}
	#company #purpose .box02 .list ul li .cont{
		height: auto;
		aspect-ratio: 1 / 1;
		padding: 7.6923vw;
	}
	#company #purpose .box02 .list ul li .cont:before,
	#company #purpose .box02 .list ul li .cont:after{
		width: 2px;
		height: 2px;
	}
	#company #purpose .box02 .list ul li .cont h6{
		padding-bottom: 2.0513vw;
		font-size: 3.0769vw;
		line-height: 4.359vw;
		max-width: 15.3846vw;
	}
	#company #purpose .box02 .list ul li .cont h6 span{
		font-size: 2.5641vw;
		line-height: 3.3333vw;
	}
	#company #vision{
		padding-bottom: 25.641vw;
	}
	#company #vision .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 12.8205vw;
	}
	#company #vision .tit02{
		margin-bottom: 7.6923vw;
	}
	#company #vision .tit02 h3 span{
	padding-right: 5px;
	}
	#company #vision .box01{
		max-width: 100%;
		margin: 0 auto 7.6923vw auto;
		display: block;
	}
	#company #vision .box01 .image01{
		max-width: 41.0256vw;
		margin-left: 0;
		margin-bottom: 7.6923vw;
	}
	#company #vision .box01 .txt{
		font-size: 3.3333vw;
		line-height: 5.8974vw;
		max-width: 100%;
		padding: 0 7.6923vw;
	}
	#company #vision .box01 .txt p{
		margin-bottom: 5.641vw;
	}
	#company #vision .box01 .txt ul{
		margin-bottom: 5.641vw;
	}
	#company #vision .image_wrap{
		/*padding: 0 7.6923vw 6.4103vw 0;*/
		padding: 0 11.5385vw 6.4103vw 0;
		margin-left: 7.6923vw;
		width: calc(100vw - 17.9487vw);
		display: none;
	}
	#company #vision .image02{
		padding-right: 11.5385vw;
		max-width: none;
		width: 135.8974vw;
		margin: 0 auto;
	}
	#company #company_profile{
		padding-bottom: 31.0256vw;
	}
	#company #company_profile .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		/*margin-bottom: 12.8205vw;*/
		margin-bottom: 13.5897vw;
	}
	#company #company_profile .logo{
		max-width: 30vw;
		margin: 0 auto 12.8205vw auto;
	}
	#company #company_profile .table{
		padding: 3.8462vw 0;
		padding-right: 7.6923vw;
	}
	#company #company_profile .table:before,
	#company #company_profile .table:after{
		width: 89.7436vw;
	}
	#company #company_profile .table:before{
		left: auto;
		right: -10.2564vw;
	}
	#company #company_profile .table:after{
		right: -10.2564vw;
	}
	#company #company_profile .table table{
		max-width: 100%;
		padding: 0 7.6923vw;
	}
	#company #company_profile .table table th,
	#company #company_profile .table table td{
		display: block;
		font-size: 3.3333vw;
		padding: 0 0 0 7.6923vw;
	}
	#company #company_profile .table table th{
		width: auto;
		padding-top: 3.8462vw;
		line-height: 4.8718vw;
	}
	#company #company_profile .table table td{
		padding-left: 7.6923vw;
		line-height: 4.6154vw;
		padding-bottom: 4.1026vw;
		position: relative;
	}
	#company #company_profile .table table td:after{
		content: "";
		position: absolute;
		height: 1px;
		left: 0;
		bottom: 0;
		width: 100%;
		background-image: linear-gradient(to right, #333333, #333333 1px, transparent 1px, transparent 4px);
		background-size: 4px 1px;
		background-repeat: repeat-x;
	}
	#company #company_profile .table table tr:last-child td:after{
		display: none;
	}
	#company #member{
		padding-bottom: 25.641vw;
	}
	#company #member .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 13.3333vw;
	}
	#company #member h4:after{
		width: 89.7436vw;
	}
	#company #member .executives,
	#company #member .advisor{
		margin-bottom: 25.641vw;
	}
	#company #member .executives h4,
	#company #member .advisor h4,
	#company #member .team h4{
		font-size: 3.8462vw;
		line-height: 5.1282vw;
		padding: 0 7.6923vw;
		padding-bottom: 2.8205vw;
		max-width: 100%;
		margin: 0 auto 7.6923vw auto;
	}
	#company #member .executives h4:after,
	#company #member .advisor h4:after,
	#company #member .team h4:after{
		width: 89.7436vw;
	}
	#company #member .executives h4:after,
	#company #member .team h4:after{
		left: 0;
	}
	#company #member .advisor h4:after{
		left: 0;
		/*right: -10.2564vw;*/
	}
	#company #member .list01{
		max-width: 100%;
		display: block;
		padding: 0 7.6923vw;
		right: 0;
	}
	#company #member .list01 li{
		max-width: 100%;
		margin-bottom: 12.5641vw;
		font-size: 3.3333vw;
		line-height: 5.8974vw;
	}
	#company #member .list01 li:last-child{
		margin-bottom: 0;
	}
	#company #member .list01 li .image{
		border-radius: 1.2821vw;
		margin-bottom: 2.5641vw;
		height: 46.1538vw;
	}
	#company #member .list01 li .image .outline rect{
		rx: 1.2821vw;
		ry: 1.2821vw;
	}
	#company #member .list01 li h5{
		font-size: 3.8462vw;
		margin-bottom: 6.1538vw;
		line-height: 5.1282vw;
	}
	#company #member .list01 li h5 span{
		font-size: 3.3333vw;
	}
	#company #member .list03{
		max-width: 100%;
		display: block;
		padding: 0 7.6923vw;
		right: 0;
	}
	#company #member .list03 li{
		max-width: 100%;
		margin-bottom: 2.5641vw;
	}
	#company #member .list03 li:last-child{
		margin-bottom: 0;
	}
	#company #member .list03 li .outline rect{
		rx: 1.2821vw;
		ry: 1.2821vw;
	}
	#company #member .list03 li .box{
		height: 16.6667vw;
		padding: 1.7949vw;
	}
	#company #member .list03 li .box .image{
		max-width: 15.3846vw;
		width: 100%;
		flex-shrink: 0;
	}
	#company #member .list03 li .name{
		margin-left: 2.0513vw;
		font-size: 3.3333vw;
		line-height: 4.6154vw;
	}

	/* Service
	-----------------------------------*/
	#service #lead .tit_h1{
		margin-bottom: 0;
	}
	#service #lead .tit02{
		display: none;
	}
	#service #lead .box{
		padding-top: 5.1282vw;
		/*padding-bottom: 43.3333vw;*/
		padding-bottom: 38.4615vw;
	}
	#service #lead .txt{
		display: none;
	}
	#service #lead .image_bloc{
		height: 30.7692vw;
	}
	#service #lead .image_bloc .image{
		bottom: 9.2308vw;
		max-width: 61.5385vw;
		width: 100%;
	}
	#service #lead_sp{
		display: block;
		border-top: 1px solid #E2041B;
		padding-bottom: 30.7692vw;
	}
	#service #lead_sp .sp_title{
		padding-top: 1px;
	}
	#service #lead_sp .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 12.8205vw;
	}
	#service #lead_sp .tit02{
		margin-bottom: 7.6923vw;
	}
	#service #lead_sp .tit02 h3 span{
		padding-right: 1.0256vw;
	}
	#service #lead_sp .tit02 h3 span:nth-child(4){
		padding-right: 1.2821vw;
	}
	#service #lead_sp .tit02 h3 span:nth-child(3):after{
		border-top-right-radius: 0;
		border-bottom-right-radius: 0;
		transition-delay: 0.6s;
	}
	#service #lead_sp .tit02 h3 span:nth-child(4):after{
		transition-delay: 0.8s;
	}
	#service #lead_sp .tit02 h3 span:nth-child(3){
		padding-right: 3.8462vw;
	}
	#service #lead_sp .txt{
		max-width: 100%;
		padding: 0 7.6923vw;
		font-size: 3.3333vw;
		line-height: 5.8974vw;
	}
	#service #lead_sp .txt p{
		margin-bottom: 5.8974vw;
	}
	#service #lead_sp .txt p:last-child{
		margin-bottom: 0;
	}
	#service #services{
		padding: 0 0 3.8462vw 0;
		position: relative;
		z-index: 1;
	}
	#service #services .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 7.6923vw;
	}
	#service #services h3{
		font-size: 11.5385vw;
		line-height: 14.8718vw;
		margin-bottom: 3.0769vw;
	}
	#service #services .service_area{
		display: block;
		padding: 0 3.8462vw;
	}
	#service #services .service_area:before,
	#service #services .service_area:after,
	#service #services .service_area ul:before,
	#service #services .service_area ul:after{
		display: none;
	}
	#service #services .service_area ul{
		max-width: 100%;
		display: block;
		padding-bottom: 0;
	}
	#service #services .service_area ul li{
		width: 100%;
		max-width: 100%;
		margin-left: 0;
		margin-top: -1px;
		border-radius: 5.1282vw;
	}
	#service #services .service_area .dummy{
		display: none;
	}
	#service #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#service #services .service_area ul li a .ico{
		margin-bottom: 6.4103vw;
	}
	#service #services .service_area ul li a .ico svg{
		max-width: 15.8974vw;
	}
	#service #services .service_area ul li a .ico2{
		right: 5.3846vw;
		bottom: 5.3846vw;
		line-height: 1;
		max-width: 100%;
	}
	#service #services .service_area ul li a .ico2 svg{
		max-width: 4.8718vw;
	}
	#service #services .service_area ul li a .txt{
		font-size: 2.5641vw;
		line-height: 3.3333vw;
	}
	#service #services .service_area ul li a h4{
		font-size: 4.6154vw;
		line-height: 6.6667vw;
		margin-bottom: 3.8462vw;
	}
	#service #services .service_area ul li a h4.sparqx{
		font-size: 5.641vw;
	}
	#service #services .service_area ul li a .cont{
		font-size: 3.0769vw;
		line-height: 4.359vw;
		margin-bottom: 7.6923vw;
	}
	#service #services .service_area ul li a .more{
		font-size: 2.8205vw;
		line-height: 3.5897vw;
	}

	/* SPARQX
	-----------------------------------*/
	#sparqx #firstView .main_tit{
		padding-top: 5.1282vw;
		/*padding-bottom: 43.3333vw;*/
		padding-bottom: 38.4615vw;
	}
	#sparqx #firstView .main_tit .tit_h1{
		margin-bottom: 0;
	}
	#sparqx #firstView #image_bloc{
		padding-bottom: 30.7692vw;
	}
	#sparqx #firstView #mainVisual{
		padding-top: 1.0256vw;
		bottom: 15.3846vw;
		max-width: 87.1795vw;
		height: 45.3846vw;
		border-top-left-radius: 1.2821vw;
		border-bottom-left-radius: 1.2821vw;
		background-position: 5.1282vw 5.1282vw, 5.1282vw calc(100% - 5.1282vw), calc(100% - 5.1282vw) 5.1282vw, calc(100% - 5.1282vw) calc(100% - 5.1282vw);
		background-size: 2.8205vw;
	}
	#sparqx #firstView #mainVisual svg{
		max-width: 44.6154vw;
	}
	#sparqx #firstView #mainVisual span{
		font-size: 2.0513vw;
		line-height: 2.8205vw;
		margin-top: 2.3077vw;
	}
	#sparqx #about{
		padding-bottom: 0;
	}
	#sparqx .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 12.8205vw;
	}
	#sparqx .tit02{
		margin-bottom: 30px;
	}
	#sparqx #about .tit02 h3 span{
		padding-right: 1.2821vw;
	}
	#sparqx #about .tit02 h3 span:nth-child(1){
		padding-right: 3.8462vw;
	}
	#sparqx #about .tit02 h3 span:nth-child(1):after{
		border-bottom-right-radius: 0.7692vw;
	}
	#sparqx #about .tit02 h3 span:nth-child(2):after{
		border-top-right-radius: 0;
		border-bottom-right-radius: 0;
	}
	#sparqx #about .tit02 h3 span:nth-child(3):after{
		transition-delay: 0.6s;
	}
	#sparqx #about .txt{
		max-width: 100%;
		padding: 0 7.6923vw;
		font-size: 3.3333vw;
		line-height: 5.8974vw;
		margin-bottom: 7.6923vw;
		margin-bottom: 20.5128vw;
	}
	#sparqx #about .txt p{
		margin-bottom: 5.8974vw;
	}
	#sparqx #about .image_wrap{
		padding: 0 11.5385vw 6.4103vw 0;
		margin-left: 7.6923vw;
		width: calc(100vw - 17.9487vw);
		margin-bottom: 8.4615vw;
		display: none;
	}
	#sparqx #about .image{
		padding-right: 11.5385vw;
		max-width: none;
		width: 135.8974vw;
		margin: 0 auto;
	}
	#sparqx #about .wrap{
		display: block;
	}
	#sparqx #about .wrap:before,
	#sparqx #about .wrap:after{
		display: none;
	}
	#sparqx #about .wrap .box{
		max-width: none;
		position: relative;
		z-index: 1;
		width: 100vw;
		margin-left: -10.2564vw;
		display: block;
		padding: 18.4615vw 17.9487vw 32.5641vw 17.9487vw;
		border-radius: 0;
		background-image: none;
	}
	#sparqx #about .wrap .box .logos{
		max-width: 100%;
	}
	#sparqx #about .wrap .box .logos .logo{
		max-width: 22.0974vw;
		width: 100%;
		margin: 0 auto 2.8205vw auto;
	}
	#sparqx #about .wrap .box .logos .tit{
		font-size: 7.1795vw;
		line-height: 7.9487vw;
	}
	#sparqx #about .wrap .box .right{
		max-width: 100%;
		margin-bottom: 7.6923vw;
	}
	#sparqx #about .wrap .box .right h4{
		font-size: 3.8462vw;
		line-height: 5.1282vw;
		padding-bottom: 2.8205vw;
		margin-bottom: 7.1795vw;
	}
	#sparqx #about .wrap .box .right .txt01{
		font-size: 3.3333vw;
		line-height: 5.8974vw;
	}
	#sparqx #about .wrap .box .right .txt01 p{
		margin-bottom: 5.8974vw;
	}
	#sparqx #case-study{
		padding-bottom: 45.1282vw;
		position: relative;
	}
	#sparqx #case-study .tit02 h3 span:nth-child(1){
		padding-right: 1.0256vw;
	}
	#sparqx #case-study .tit02 h3 span:nth-child(2){
		padding-right: 3.8462vw;
	}
	#sparqx #case-study .tit02 h3 span:nth-child(3){
		padding-right: 3.8462vw;
	}
	#sparqx #case-study .tit02 h3 span:nth-child(3):after{
		border-top-right-radius: 0;
		transition-delay: 0.6s;
	}
	#sparqx #case-study .list{
		position: static;
	}
	#sparqx #case-study .list:after{
		width: 1px;
		height: 0;
		top: 0;
		left: 50%;
		margin-left: -0.5px;
		transition: 0.8s height ease;
		transition-delay: 1s;
	}
	#sparqx #case-study .list.is-inview:after{
		width: 1px;
		height: 100%;
	}
	#sparqx #case-study .list ul{
		max-width: 100%;
		padding: 0 7.6923vw;
		display: block;
	}
	#sparqx #case-study .list ul li{
		max-width: 100%;
		aspect-ratio: 1 / 1;
		margin-bottom: 8.9744vw;
		border-radius: 5.1282vw;
	}
	#sparqx #case-study .list ul li:last-child{
		margin-bottom: 0;
	}
	#sparqx #case-study .list ul li:before,
	#sparqx #case-study .list ul li:after{
		width: 6.4103vw;
		height: 6.4103vw;
	}
	#sparqx #case-study .list ul li .box{
		height: auto;
		padding: 6.1538vw;
	}
	#sparqx #case-study .list ul li .box{
		height: auto;
		padding: 6.1538vw;
	}
	#sparqx #case-study .list ul li .box:before,
	#sparqx #case-study .list ul li .box:after{
		width: 1.0256vw;
		height: 1.0256vw;
	}
	#sparqx #case-study .list ul li .dot{
		width: 4px;
		height: 4px;
		top: calc(100% + 3.8462vw);
		right: auto;
		left: 50%;
		transform: none;
		margin-left: -1.75px;
	}
	#sparqx #case-study .list ul li .box h3{
		font-size: 4.1026vw;
		line-height: 4.6154vw;
		margin-bottom: 6.9231vw;
	}
	#sparqx #case-study .list ul li .box h3 span{
		font-size: 2.5641vw;
		line-height: 3.5897vw;
		margin-bottom: 0.5128vw;
	}
	#sparqx #case-study .list ul li .box h4{
		font-size: 3.0769vw;
		line-height: 4.1026vw;
		margin-bottom: 2.8205vw;
	}
	#sparqx #case-study .list ul li .box p{
		font-size: 3.0769vw;
		line-height: 4.1026vw;
	}
	#sparqx #key-details{
		padding-bottom: 24.359vw;
	}
	#sparqx #key-details .wrap{
		max-width: 100%;
		margin: 0 auto 25.641vw auto;
	}
	#sparqx #key-details .wrap h3{
		font-size: 3.8462vw;
		line-height: 5.3846vw;
		margin-bottom: 7.6923vw;
		max-width: 100%;
		padding: 0 7.6923vw 2.5641vw 7.6923vw;
	}
	#sparqx #key-details .wrap h3 span{
		font-size: 2.5641vw;
		line-height: 3.8462vw;
		margin-bottom: 0.5128vw;
	}
	#sparqx #key-details .wrap h3:after{
		width: calc(100% + 10.2564vw);
	}
	#sparqx #key-details .wrap:nth-child(even) h3:after{
		right: auto;
		left: 0;
	}
	#sparqx #key-details .wrap .txt{
		font-size: 3.3333vw;
		line-height: 5.8974vw;
		margin-bottom: 7.6923vw;
		padding: 0 7.6923vw;
	}
	#sparqx #key-details .wrap .box{
		border-radius: 2.5641vw;
		border-top-right-radius: 0;
		border-bottom-right-radius: 0;
		min-height: auto;
		padding: 12.8205vw 15.3846vw 7.6923vw 15.3846vw;
		width: 82.0513vw;
		aspect-ratio: 1 / 1;
		position: relative;
		right: -10.2564vw;
		right: -7.6923vw;
		z-index: 10;
		display: block;
		background-size: 2.8205vw;
		background-position: 5.1282vw 5.1282vw, 5.1282vw calc(100% - 5.1282vw), calc(100% - 5.1282vw) 5.1282vw, calc(100% - 5.1282vw) calc(100% - 5.1282vw);
	}
	#sparqx #key-details .wrap .box .txt01{
		max-width: 100%;
		font-size: 3.0769vw;
		line-height: 4.6154vw;
		margin-bottom: 5.1282vw;
	}
	#sparqx #key-details .wrap .box .image{
		margin: 0 auto;
	}
	#sparqx #key-details .wrap:nth-child(1) .box .image{
		max-width: 27.8564vw;
	}
	#sparqx #key-details .wrap:nth-child(2) .box .image{
		max-width: 17.5769vw;
	}
	#sparqx #key-details .wrap:nth-child(3) .box .image{
		max-width: 22.0513vw;
	}
	#sparqx #services{
		padding: 7.4359vw 0 3.8462vw 0;
		position: relative;
		z-index: 1;
	}
	#sparqx #services .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 8.2051vw;
	}
	#sparqx #services h3{
		font-size: 11.5385vw;
		line-height: 14.8718vw;
		margin-bottom: 3.0769vw;
	}
	#sparqx #services .service_area{
		display: flex;
		padding: 0 3.8462vw;
	}
	#sparqx #services .service_area:before,
	#sparqx #services .service_area:after{
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: 50%;
		flex-shrink: 0;
		position: absolute;
		opacity: 1;
		transition: none;
	}
	#sparqx #services .service_area.is-inview:before,
	#sparqx #services .service_area.is-inview:after{
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		border: 1px solid #fff;
	}
	#sparqx #services .service_area.is-inview:before{
		border-left: none;
	}
	#sparqx #services .service_area.is-inview:after{
		border-right: none;
	}
	#sparqx #services .service_area{
		position: relative;
	}
	#sparqx #services .service_area:before{
		bottom: 2px;
		left: 0;
		height: calc(50% - 3px);
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
	}
	#sparqx #services .service_area:after{
		margin-left: 0;
		bottom: 2px;
		right: 0;
		height: calc(50% - 3px);
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
	}
	#sparqx #services .service_area ul{
		max-width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding-bottom: 0;
	}
	#sparqx #services .service_area ul:before{
		content: "";
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-left: none;
		position: absolute;
		left: 0;
		top: 1px;
	}
	#sparqx #services .service_area ul:after{
		content: "";
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-right: none;
		position: absolute;
		right: 0;
		top: 1px;
	}
	#sparqx #services .service_area ul li{
		width: 50%;
		position: relative;
		margin-left: -1px;
		margin-top: -1px;
		border-radius: 2.5641vw;
	}
	#sparqx #services .service_area ul li:nth-child(1),
	#sparqx #services .service_area ul li:nth-child(3){
		margin-left: 0;
	}
	#sparqx #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#sparqx #services .service_area ul li a .ico{
		margin-bottom: 3.8462vw;
	}
	#sparqx #services .service_area ul li a .ico svg{
		max-width: 9.7436vw;
	}
	#sparqx #services .service_area ul li a .ico2{
		right: 3.8462vw;
		bottom: 3.8462vw;
		max-width: 2.8205vw;
		line-height: 1;
	}
	#sparqx #services .service_area ul li a .ico2 svg{
		max-width: 2.8205vw;
	}
	#sparqx #services .service_area ul li a .txt{
		font-size: 2.0513vw;
		line-height: 1.7949vw;
		margin-bottom: 0.5128vw;
	}
	#sparqx #services .service_area ul li a h4{
		font-size: 3.0769vw;
		line-height: 2.8205vw;
		margin-bottom: 3.8462vw;
	}
	#sparqx #services .service_area ul li a .cont{
		display: none;
	}
	#sparqx #services .service_area ul li a .more{
		font-size: 2.5641vw;
		line-height: 3.3333vw;
	}

	/* Security Consulting
	-----------------------------------*/
	#security-consulting #firstView .main_tit{
		padding-top: 5.1282vw;
		/*padding-bottom: 42.8205vw;*/
		padding-bottom: 38.4615vw;
	}
	#security-consulting #firstView .main_tit .tit_h1{
		margin-bottom: 0;
	}
	#security-consulting #firstView #image_bloc{
		padding-bottom: 30.7692vw;
	}
	#security-consulting #firstView #mainVisual{
		bottom: 15.3846vw;
		max-width: 87.1795vw;
		height: 45.3846vw;
		border-top-left-radius: 1.2821vw;
		border-bottom-left-radius: 1.2821vw;
		background-position: 5.1282vw 5.1282vw, 5.1282vw calc(100% - 5.1282vw), calc(100% - 5.1282vw) 5.1282vw, calc(100% - 5.1282vw) calc(100% - 5.1282vw);
		background-size: 2.8205vw;
	}
	#security-consulting #firstView #mainVisual svg{
		max-width: 62.5641vw;
	}
	#security-consulting #lead{
		padding-bottom: 25.641vw;
		border-top: 1px solid #E2041B;
	}
	#security-consulting .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 12.8205vw;
	}
	#security-consulting .tit02{
		margin-bottom: 7.6923vw;
	}
	#security-consulting .tit02 h3 span:nth-child(1){
		padding-right: 3.8462vw;
	}
	#security-consulting .tit02 h3 span:nth-child(2):after{
		border-top-right-radius: 0;
		border-bottom-right-radius: 0;
	}
	#security-consulting .tit02 h3 span:nth-child(3):after{
		transition-delay: 0.6s;
	}
	#security-consulting #lead .txt{
		max-width: 100%;
		padding: 0 7.6923vw;
		font-size: 3.3333vw;
		line-height: 5.8974vw;
		margin-bottom: 15.3846vw;
	}
	#security-consulting #lead .txt .pc_paragraph p{
		margin-bottom: 5.8974vw;
		display: block;
	}
	#security-consulting #lead .txt .pc_paragraph p:last-child{
		margin-bottom: 0;
	}
	#security-consulting #services{
		padding: 7.4359vw 0 3.8462vw 0;
		position: relative;
		z-index: 1;
	}
	#security-consulting #services .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 8.2051vw;
	}
	#security-consulting #services h3{
		font-size: 11.5385vw;
		line-height: 14.8718vw;
		margin-bottom: 3.0769vw;
	}
	#security-consulting #services .service_area{
		display: flex;
		padding: 0 3.8462vw;
	}
	#security-consulting #services .service_area:before,
	#security-consulting #services .service_area:after{
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: 50%;
		flex-shrink: 0;
		position: absolute;
		opacity: 1;
		transition: none;
	}
	#security-consulting #services .service_area.is-inview:before,
	#security-consulting #services .service_area.is-inview:after{
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		border: 1px solid #fff;
	}
	#security-consulting #services .service_area.is-inview:before{
		border-left: none;
	}
	#security-consulting #services .service_area.is-inview:after{
		border-right: none;
	}
	#security-consulting #services .service_area{
		position: relative;
	}
	#security-consulting #services .service_area:before{
		bottom: 2px;
		left: 0;
		height: calc(50% - 3px);
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
	}
	#security-consulting #services .service_area:after{
		margin-left: 0;
		bottom: 2px;
		right: 0;
		height: calc(50% - 3px);
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
	}
	#security-consulting #services .service_area ul{
		max-width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding-bottom: 0;
	}
	#security-consulting #services .service_area ul:before{
		content: "";
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-left: none;
		position: absolute;
		left: 0;
		top: 1px;
	}
	#security-consulting #services .service_area ul:after{
		content: "";
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-right: none;
		position: absolute;
		right: 0;
		top: 1px;
	}
	#security-consulting #services .service_area ul li{
		width: 50%;
		position: relative;
		margin-left: -1px;
		margin-top: -1px;
		border-radius: 2.5641vw;
	}
	#security-consulting #services .service_area ul li:nth-child(1),
	#security-consulting #services .service_area ul li:nth-child(3){
		margin-left: 0;
	}
	#security-consulting #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#security-consulting #services .service_area ul li a .ico{
		margin-bottom: 3.8462vw;
	}
	#security-consulting #services .service_area ul li a .ico svg{
		max-width: 9.7436vw;
	}
	#security-consulting #services .service_area ul li a .ico2{
		right: 3.8462vw;
		bottom: 3.8462vw;
		max-width: 2.8205vw;
		line-height: 1;
	}
	#security-consulting #services .service_area ul li a .ico2 svg{
		max-width: 2.8205vw;
	}
	#security-consulting #services .service_area ul li a .txt{
		font-size: 2.0513vw;
		line-height: 1.7949vw;
		margin-bottom: 0.5128vw;
	}
	#security-consulting #services .service_area ul li a h4{
		font-size: 3.0769vw;
		line-height: 2.8205vw;
		margin-bottom: 3.8462vw;
	}
	#security-consulting #services .service_area ul li a .cont{
		display: none;
	}
	#security-consulting #services .service_area ul li a .more{
		font-size: 2.5641vw;
		line-height: 3.3333vw;
	}

	/* Agile Development Service
	-----------------------------------*/
	#agile-development-service #firstView .main_tit{
		padding-top: 5.1282vw;
		/*padding-bottom: 43.3333vw;*/
		padding-bottom: 38.4615vw;
	}
	#agile-development-service #firstView .main_tit .tit_h1{
		margin-bottom: 0;
	}
	#agile-development-service #firstView #image_bloc{
		padding-bottom: 30.7692vw;
	}
	#agile-development-service #firstView #mainVisual{
		bottom: 15.3846vw;
		max-width: 87.1795vw;
		height: 45.3846vw;
		border-top-left-radius: 1.2821vw;
		border-bottom-left-radius: 1.2821vw;
		background-position: 5.1282vw 5.1282vw, 5.1282vw calc(100% - 5.1282vw), calc(100% - 5.1282vw) 5.1282vw, calc(100% - 5.1282vw) calc(100% - 5.1282vw);
		background-size: 2.8205vw;
	}
	#agile-development-service #firstView #mainVisual svg{
		max-width: 41.0256vw;
	}
	#agile-development-service #lead{
		padding-bottom: 31.0256vw;
		position: relative;
	}
	#agile-development-service .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 12.8205vw;
	}
	#agile-development-service .tit02{
		margin-bottom: 7.6923vw;
	}
	#agile-development-service .tit02 h3 span{
		padding-right: 3.8462vw;
	}
	#agile-development-service .tit02 h3 span:nth-child(4){
		padding-right: 1.2821vw;
	}
	#agile-development-service .tit02 h3 span:nth-child(1):after{
		border-bottom-right-radius: 0;
	}
	#agile-development-service .tit02 h3 span:nth-child(2):after{
		border-top-right-radius: 0.7692vw;
	}
	#agile-development-service .tit02 h3 span:nth-child(3):after{
		border-top-right-radius: 0;
		transition-delay: 0.6s;
	}
	#agile-development-service .tit02 h3 span:nth-child(4):after{
		border-top-right-radius: 0;
		transition-delay: 0.8s;
	}
	#agile-development-service #lead .tit02 h3 span:nth-child(1){
		padding-right: 3.8462vw;
	}
	#agile-development-service #lead .txt{
		max-width: 100%;
		padding: 0 7.6923vw;
		font-size: 3.3333vw;
		line-height: 5.8974vw;
		margin-bottom: 7.6923vw;
	}
	#agile-development-service #lead .images{
		max-width: 100%;
		flex-wrap: wrap;
		gap: 5.1282vw 0;
		padding: 0 7.6923vw;
	}
	#agile-development-service #lead .images li{
		max-width: 30.7692vw;
	}
	#agile-development-service #lead .image{
		max-width: 100%;
		padding: 0 7.6923vw;
	}
	#agile-development-service #flow{
		padding-bottom: 44.8718vw;
		position: relative;
	}
	#agile-development-service #flow .list{
		position: static;
	}
	#agile-development-service #flow .list:after{
		width: 1px;
		height: 0;
		top: 0;
		left: 50%;
		margin-left: -0.5px;
		transition: 0.8s height ease;
		transition-delay: 1s;
	}
	#agile-development-service #flow .list.is-inview:after{
		width: 1px;
		height: 100%;
	}
	#agile-development-service #flow .list ul{
		max-width: 100%;
		padding: 0 7.6923vw;
		display: block;
	}
	#agile-development-service #flow .list ul li{
		max-width: 100%;
		aspect-ratio: 1 / 1;
		margin-bottom: 8.9744vw;
		border-radius: 5.1282vw;
	}
	#agile-development-service #flow .list ul li:last-child{
		margin-bottom: 0;
	}
	#agile-development-service #flow .list ul li:before,
	#agile-development-service #flow .list ul li:after{
		width: 6.4103vw;
		height: 6.4103vw;
	}
	#agile-development-service #flow .list ul li .box{
		height: auto;
		padding: 6.1538vw;
	}
	#agile-development-service #flow .list ul li .box:before,
	#agile-development-service #flow .list ul li .box:after{
		width: 1.0256vw;
		height: 1.0256vw;
	}
	#agile-development-service #flow .list ul li .dot{
		width: 4px;
		height: 4px;
		top: calc(100% + 3.8462vw);
		right: auto;
		left: 50%;
		transform: none;
		margin-left: -1.75px;
	}
	#agile-development-service #flow .list ul li .box h3{
		font-size: 4.1026vw;
		line-height: 4.6154vw;
		margin-bottom: 3.3333vw;
	}
	#agile-development-service #flow .list ul li:nth-child(1) .box h3{
		margin-bottom: 4.8718vw;
	}
	#agile-development-service #flow .list ul li:nth-child(2) .box h3{
		margin-bottom: 4.1026vw;
	}
	#agile-development-service #flow .list ul li:nth-child(3) .box h3{
		margin-bottom: 6.6667vw;
	}
	#agile-development-service #flow .list ul li .box h3 span{
		font-size: 2.5641vw;
		line-height: 3.5897vw;
		margin-bottom: 0.5128vw;
	}
	#agile-development-service #services{
		padding: 7.4359vw 0 3.8462vw 0;
		position: relative;
		z-index: 1;
	}
	#agile-development-service #services .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 8.2051vw;
	}
	#agile-development-service #services h3{
		font-size: 11.5385vw;
		line-height: 14.8718vw;
		margin-bottom: 3.0769vw;
	}
	#agile-development-service #services .service_area{
		display: flex;
		padding: 0 3.8462vw;
	}
	#agile-development-service #services .service_area:before,
	#agile-development-service #services .service_area:after{
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: 50%;
		flex-shrink: 0;
		position: absolute;
		opacity: 1;
		transition: none;
	}
	#agile-development-service #services .service_area.is-inview:before,
	#agile-development-service #services .service_area.is-inview:after{
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		border: 1px solid #fff;
	}
	#agile-development-service #services .service_area.is-inview:before{
		border-left: none;
	}
	#agile-development-service #services .service_area.is-inview:after{
		border-right: none;
	}
	#agile-development-service #services .service_area{
		position: relative;
	}
	#agile-development-service #services .service_area:before{
		bottom: 2px;
		left: 0;
		height: calc(50% - 3px);
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
	}
	#agile-development-service #services .service_area:after{
		margin-left: 0;
		bottom: 2px;
		right: 0;
		height: calc(50% - 3px);
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
	}
	#agile-development-service #services .service_area ul{
		max-width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding-bottom: 0;
	}
	#agile-development-service #services .service_area ul:before{
		content: "";
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-left: none;
		position: absolute;
		left: 0;
		top: 1px;
	}
	#agile-development-service #services .service_area ul:after{
		content: "";
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-right: none;
		position: absolute;
		right: 0;
		top: 1px;
	}
	#agile-development-service #services .service_area ul li{
		width: 50%;
		position: relative;
		margin-left: -1px;
		margin-top: -1px;
		border-radius: 2.5641vw;
	}
	#agile-development-service #services .service_area ul li:nth-child(1),
	#agile-development-service #services .service_area ul li:nth-child(3){
		margin-left: 0;
	}
	#agile-development-service #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#agile-development-service #services .service_area ul li a .ico{
		margin-bottom: 3.8462vw;
	}
	#agile-development-service #services .service_area ul li a .ico svg{
		max-width: 9.7436vw;
	}
	#agile-development-service #services .service_area ul li a .ico2{
		right: 3.8462vw;
		bottom: 3.8462vw;
		max-width: 2.8205vw;
		line-height: 1;
	}
	#agile-development-service #services .service_area ul li a .ico2 svg{
		max-width: 2.8205vw;
	}
	#agile-development-service #services .service_area ul li a .txt{
		font-size: 2.0513vw;
		line-height: 1.7949vw;
		margin-bottom: 0.5128vw;
	}
	#agile-development-service #services .service_area ul li a h4{
		font-size: 3.0769vw;
		line-height: 2.8205vw;
		margin-bottom: 3.8462vw;
	}
	#agile-development-service #services .service_area ul li a .cont{
		display: none;
	}
	#agile-development-service #services .service_area ul li a .more{
		font-size: 2.5641vw;
		line-height: 3.3333vw;
	}

	/* AX DX Consulting
	-----------------------------------*/
	#axdx-consulting .bloc{
	}
	#axdx-consulting #lead{
		/*padding: 64.1026vw 0;*/
		padding: 30.7692vw 0;
	}
	#axdx-consulting #lead .txt{
		max-width: 100%;
		margin-bottom: 0;
		/*margin-bottom: 25.641vw;
		font-size: 9.2308vw;
		line-height: 11.7949vw;*/
	}
	#axdx-consulting #services{
		padding: 7.4359vw 0 3.8462vw 0;
		position: relative;
		z-index: 1;
	}
	#axdx-consulting #services .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 8.2051vw;
	}
	#axdx-consulting #services h3{
		font-size: 11.5385vw;
		line-height: 14.8718vw;
		margin-bottom: 3.0769vw;
	}
	#axdx-consulting #services .service_area{
		display: flex;
		padding: 0 3.8462vw;
	}
	#axdx-consulting #services .service_area:before,
	#axdx-consulting #services .service_area:after{
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: 50%;
		flex-shrink: 0;
		position: absolute;
		opacity: 1;
		transition: none;
	}
	#axdx-consulting #services .service_area.is-inview:before,
	#axdx-consulting #services .service_area.is-inview:after{
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		border: 1px solid #fff;
	}
	#axdx-consulting #services .service_area.is-inview:before{
		border-left: none;
	}
	#axdx-consulting #services .service_area.is-inview:after{
		border-right: none;
	}
	#axdx-consulting #services .service_area{
		position: relative;
	}
	#axdx-consulting #services .service_area:before{
		bottom: 2px;
		left: 0;
		height: calc(50% - 3px);
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
	}
	#axdx-consulting #services .service_area:after{
		margin-left: 0;
		bottom: 2px;
		right: 0;
		height: calc(50% - 3px);
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
	}
	#axdx-consulting #services .service_area ul{
		max-width: 100%;
		display: flex;
		flex-wrap: wrap;
		padding-bottom: 0;
	}
	#axdx-consulting #services .service_area ul:before{
		content: "";
		border-top-right-radius: 2.5641vw;
		border-bottom-right-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-left: none;
		position: absolute;
		left: 0;
		top: 1px;
	}
	#axdx-consulting #services .service_area ul:after{
		content: "";
		border-top-left-radius: 2.5641vw;
		border-bottom-left-radius: 2.5641vw;
		background: #E2041B;
		border: 1px solid #fff;
		display: block;
		width: calc(((100vw - 92.3077vw) / 2) + 1px);
		height: calc(50% - 3px);
		flex-shrink: 0;
		border-right: none;
		position: absolute;
		right: 0;
		top: 1px;
	}
	#axdx-consulting #services .service_area ul li{
		width: 50%;
		position: relative;
		margin-left: -1px;
		margin-top: -1px;
		border-radius: 2.5641vw;
	}
	#axdx-consulting #services .service_area ul li:nth-child(1),
	#axdx-consulting #services .service_area ul li:nth-child(3){
		margin-left: 0;
	}
	#axdx-consulting #services .service_area ul li a{
		height: auto;
		aspect-ratio: 1 / 1;
	}
	#axdx-consulting #services .service_area ul li a .ico{
		margin-bottom: 3.8462vw;
	}
	#axdx-consulting #services .service_area ul li a .ico svg{
		max-width: 9.7436vw;
	}
	#axdx-consulting #services .service_area ul li a .ico2{
		right: 3.8462vw;
		bottom: 3.8462vw;
		max-width: 2.8205vw;
		line-height: 1;
	}
	#axdx-consulting #services .service_area ul li a .ico2 svg{
		max-width: 2.8205vw;
	}
	#axdx-consulting #services .service_area ul li a .txt{
		font-size: 2.0513vw;
		line-height: 1.7949vw;
		margin-bottom: 0.5128vw;
	}
	#axdx-consulting #services .service_area ul li a h4{
		font-size: 3.0769vw;
		line-height: 2.8205vw;
		margin-bottom: 3.8462vw;
	}
	#axdx-consulting #services .service_area ul li a .cont{
		display: none;
	}
	#axdx-consulting #services .service_area ul li a .more{
		font-size: 2.5641vw;
		line-height: 3.3333vw;
	}


	/* Work
	-----------------------------------*/
	#works{
		/*padding-top: 5.641vw;*/
		padding-top: 5.1282vw;
	}
	#works .tit_h1{
		margin-bottom: 8.2051vw;
	}
	#works.worksSingle .sidede{
		display: none;
	}
	#works .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 12.8205vw;
	}
	#works #content{
		padding-bottom: 25.641vw;
	}
	#works.worksSingle .sp_wrap{
		padding-right: 0;
	}
	#works .list02{
		max-width: 100%;
		align-items: flex-start;
		gap: 7.6923vw 2.5641vw;
		padding: 0 7.6923vw;
	}
	#works .list02 li{
		max-width: 30.7692vw;
	}
	#works .list02 li:nth-child(3n + 1):after{
		display: none;
	}
	#works .list02 li a:before{
		display: none;
	}
	#works .list02 li a .dot01:before,
	#works .list02 li a .dot01:after{
		width: 3.0769vw;
		height: 3.0769vw;
	}
	#works .list02 li a .dot01:before{
		top: -2px;
		right: -2px;
	}
	#works .list02 li a .dot01:after{
		bottom: -2px;
		left: -2px;
	}
	#works .list02 li a .dot02:before,
	#works .list02 li a .dot02:after{
		width: 2px;
		height: 2px;
	}
	#works .list02 li a .dot03{
		display: none;
	}
	#works .list02 li a .box{
		display: block;
		padding: 0;
		aspect-ratio: auto;
		border: none;
		background: none;
		border-radius: 0;
	}
	#works .list02 li a .box .logos{
		position: relative;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		aspect-ratio: 1 / 1;
		border: 1px solid #E2041B;
		border-radius: 2.0513vw;
		margin-bottom: 2.5641vw;
	}
	#works .list02 li a .box .logo{
		margin-bottom: 0;
		aspect-ratio: 120 / 30;
		padding: 0 2.5641vw;
		width: 100%;
	}
	#works .list02 li a .box .logo img{
		height: 7.6923vw;
		width: 100%;
	}
	#works .list02 li a .box h3{
		padding-bottom: 2.5641vw;
		margin: 0 1.2821vw;
		margin-bottom: 2.5641vw;
		font-size: 3.0769vw;
		line-height: 3.5897vw;
		position: relative;
		margin-top: 0;
	}
	#works .list02 li a .box h3:after{
		content: "";
		width: 100%;
		height: 1px;
		position: absolute;
		bottom: 0;
		left: 0;
		background-image: linear-gradient(to right, #333, #333 1px, transparent 1px, transparent 4px);
		background-size: 4px 1px;
		background-repeat: repeat-x;
	}
	#works .list02 li a .box .cont{
		font-size: 2.5641vw;
		line-height: 3.0769vw;
		min-height: 10vw;
		margin: 0 1.2821vw;
	}
	#works .tit h3{
		padding: 0 7.6923vw;
		padding-bottom: 3.8462vw;
		margin-bottom: 15.3846vw;
		flex-direction: column;
	}
	#works .tit h3:after{
		width: 100%;
	}
	#works .tit h3 .cont{
		order: 2;
		margin-right: auto;
	}
	#works .tit h3 .cont .date-cats{
		margin-bottom: 0.5128vw;
	}
	#works .tit h3 .cont .date-cats .date{
		font-size: 3.0769vw;
		margin-right: 3.3333vw;
		line-height: 3.5897vw;
	}
	#works .tit h3 .cont .date-cats .cats{
		font-size: 2.5641vw;
		line-height: 4.1026vw;
		padding: 0 1.0256vw;
		min-width: 20.5128vw;
	}
	#works .tit h3 .logo{
		text-align: left;
		/*margin-bottom: 2.5641vw;*/
		margin-bottom: 3.8462vw;
		margin-right: auto;
	}
	#works .tit h3 .logo img{
		height: 12.8205vw;
	}
	#works #content #works_content{
		font-size: 3.5897vw;
		line-height: 5.641vw;
		padding: 0 7.6923vw;
	}
	#works #content #works_content h1{
		font-size: 5.641vw;
		line-height: 8.2051vw;
		margin-bottom: 10.2564vw;
	}
	#works #content #works_content h2{
		padding-bottom: 3.8462vw;
		font-size: 4.1026vw;
		line-height: 5.641vw;
		margin-bottom: 3.8462vw;
	}
	#works #content #works_content .blocs{
		margin-bottom: 15.3846vw;
	}
	#works #content #works_content h3{
		font-size: 3.5897vw;
		line-height: 5.1282vw;
		margin-bottom: 2.5641vw;
	}
	#works #content #works_content h4,
	#works #content #works_content h5,
	#works #content #works_content h6{
		font-size: 3.5897vw;
		line-height: 5.1282vw;
		margin-bottom: 2.5641vw;
	}
	#works #content #works_content p:has(img){
		margin-bottom: 7.6923vw;
	}
	#works #content #works_content blockquote{
		padding: 6.4103vw;
		border-radius: 2.5641vw;
		/*font-size: 3.5897vw;
		line-height: 5.641vw;*/
		font-size: 3.0769vw;
		line-height: 4.6154vw;
		margin: 7.6923vw 0;
	}
	#works #content #works_content blockquote p{
		margin-bottom: 4.6154vw;
	}
	#works #content #works_content hr{
		margin: 5.1282vw 0;
	}
	#works #content #works_content p{
		margin-bottom: 5.1282vw;
	}
	#works #content #works_content .sing_list{
		border-radius: 5.1282vw;
		padding: 6.4103vw;
	}
	#works #content #works_content .sing_list li{
		padding-bottom: 5.1282vw;
		margin-bottom: 5.1282vw;
		/*line-height: 6.1538vw;
		font-size: 3.5897vw;*/
		font-size: 3.0769vw;
		line-height: 4.6154vw;
	}
	#works #content #works_content .sing_list li h2{
		/*font-size: 3.5897vw;
		line-height: 5.641vw;*/
		font-size: 3.0769vw;
		line-height: 4.6154vw;
		margin-bottom: 2.0513vw;
		padding-bottom: 0;
	}

	/* Single
	-----------------------------------*/
	#pagenavi{
		padding: 5.1282vw 0;
		border-bottom: none;
	}
	#pagenavi .box{
		font-size: 3.5897vw;
		line-height: 4.6154vw;
	}
	#pagenavi .box .prev-link{
		padding-left: 7.6923vw;
	}
	#pagenavi .box .next-link{
		padding-right: 7.6923vw;
	}
	#pagenavi .box .prev-link:after,
	#pagenavi .box .next-link:after{
		width: 2.5641vw;
	}
	#pagenavi .box .prev-link:after{
		left: 2.5641vw;
	}
	#pagenavi .box .next-link:after{
		right: 2.5641vw;
	}
	#news-list .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 20.5128vw;
	}
	#news-list{
		padding-top: 5.1282vw;
	}
	#news-list .sp_wrap{
		padding-right: 0;
	}
	#news-single .sp_wrap{
		padding-right: 0;
	}
	#news-list .sidede{
		display: none;
	}
	#news-list .tit_h1{
		margin-bottom: 8.2051vw;
	}
	#news-list #single_list{
		padding-bottom: 25.641vw;
		min-height: auto;
	}
	#news-list #single_list .nopost{
		max-width: 100%;
		font-size: 4.1026vw;
		line-height: 6.1538vw;
		padding: 0 7.6923vw;
	}
	#news-list #single_list ul{
		max-width: 100%;
		padding: 0 7.6923vw;
	}
	#news-list #single_list ul li{
		margin-bottom: 0.5128vw;
	}
	#news-list #single_list ul li a{
		padding: 3.8462vw 5.1282vw;
	}
	#news-list #single_list ul li a .date-cats{
		margin-bottom: 0.5128vw;
	}
	#news-list #single_list ul li a .date-cats .date{
		font-size: 3.0769vw;
		margin-right: 3.3333vw;
		line-height: 3.5897vw;
	}
	#news-list #single_list ul li a .date-cats .cats{
		font-size: 2.5641vw;
		line-height: 4.1026vw;
		padding: 0 1.0256vw;
		min-width: 20.5128vw;
	}
	#news-list #single_list ul li a h3{
		font-size: 3.5897vw;
		line-height: 4.6154vw;
		padding-right: 5.1282vw;
	}
	#news-list #single_list ul li a .ico{
		max-width: 3.8462vw;
		right: 5.1282vw;
	}
	#news-single .sidede{
		display: none;
	}
	#news-single .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 20.5128vw;
	}
	#news-single{
		/*padding-top: 5.641vw;*/
		padding-top: 5.1282vw;
	}
	#news-single .tit_h1{
		margin-bottom: 8.2051vw;
	}
	#news-single .tit h3{
		margin-bottom: 15.3846vw;
		padding: 0 7.6923vw;
		padding-bottom: 3.8462vw;
	}
	#news-single .tit h3:after{
		width: 100%;
	}
	#news-single .tit h3 .date-cats{
		margin-bottom: 0.5128vw;
	}
	#news-single .tit h3 .date-cats .date{
		font-size: 3.0769vw;
		margin-right: 3.3333vw;
		line-height: 3.5897vw;
	}
	#news-single .tit h3 .date-cats .cats{
		font-size: 2.5641vw;
		line-height: 4.1026vw;
		padding: 0 1.0256vw;
		min-width: 20.5128vw;
	}
	#news-single .tit h3 span{
		font-size: 5.1282vw;
		line-height: 7.6923vw;
	}
	#news-single #content{
		max-width: 100%;
		padding-bottom: 25.641vw;
	}
	#news-single #content .single_content{
		font-size: 3.5897vw;
		line-height: 5.641vw;
		padding: 0 7.6923vw;
	}
	#news-single #content .single_content h1{
		font-size: 5.641vw;
		line-height: 8.2051vw;
		margin-bottom: 10.2564vw;
	}
	#news-single #content .single_content h2{
		padding-bottom: 3.8462vw;
		font-size: 4.1026vw;
		line-height: 5.641vw;
		margin-bottom: 3.8462vw;
	}
	#news-single #content .single_content .blocs{
		margin-bottom: 15.3846vw;
	}
	#news-single #content .single_content h3{
		font-size: 3.5897vw;
		line-height: 5.1282vw;
		margin-bottom: 2.5641vw;
	}
	#news-single #content .single_content h4,
	#news-single #content .single_content h5,
	#news-single #content .single_content h6{
		font-size: 3.5897vw;
		line-height: 5.1282vw;
		margin-bottom: 2.5641vw;
	}
	#news-single #content .single_content p:has(img){
		margin-bottom: 7.6923vw;
	}
	#news-single #content .single_content blockquote{
		padding: 6.4103vw;
		border-radius: 2.5641vw;
		/*font-size: 3.5897vw;
		line-height: 5.641vw;*/
		font-size: 3.0769vw;
		line-height: 4.6154vw;
		margin: 7.6923vw 0;
	}
	#news-single #content .single_content blockquote p{
		margin-bottom: 4.6154vw;
	}
	#news-single #content .single_content hr{
		margin: 5.1282vw 0;
	}
	#news-single #content .single_content p{
		margin-bottom: 5.1282vw;
	}
	#news-single #content .single_content .sing_list{
		border-radius: 5.1282vw;
		padding: 6.4103vw;
	}
	#news-single #content .single_content .sing_list li{
		padding-bottom: 5.1282vw;
		margin-bottom: 5.1282vw;
		/*line-height: 6.1538vw;
		font-size: 3.5897vw;*/
		font-size: 3.0769vw;
		line-height: 4.6154vw;
	}
	#news-single #content .single_content .sing_list li h2{
		/*font-size: 3.5897vw;
		line-height: 5.641vw;*/
		font-size: 3.0769vw;
		line-height: 4.6154vw;
		margin-bottom: 2.0513vw;
		padding-bottom: 0;
	}

	/* Contact
	-----------------------------------*/
	#privacy-policy #content .txt{
		font-size: 3.5897vw;
		line-height: 5.641vw;
		max-width: 100%;
		margin: 0 auto 15.3846vw auto;
	}
	#contact{
		padding-top: 5.1282vw;
	}
	#contact .sidede{
		display: none;
	}
	#contact .sp_wrap{
		padding-right: 0;
	}
	#contact .tit_h1{
		margin-bottom: 8.2051vw;
	}
	#contact .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		/*margin-bottom: 20.5128vw;*/
		margin-bottom: 13.0769vw;
	}
	#contact #content{
		padding-bottom: 15.3846vw;
	}
	#contact #content .txt{
		/*font-size: 3.8462vw;
		line-height: 5.641vw;*/
		font-size: 3.5897vw;
		line-height: 5.8974vw;
		max-width: 100%;
		margin: 0 auto 15.3846vw auto;
		padding: 0 7.6923vw;
	}
	#contact #content .txt p{
		margin-bottom: 5.1282vw;
	}
	#contact #content .table{
		max-width: 100%;
	}
	#contact #content .table{
		padding: 15.3846vw 7.6923vw 0 7.6923vw;
	}
	#contact #content .table:before,
	#contact #content .table:after{
		width: 100%;
	}
	#contact #content .table:before{
		left: 0;
	}
	#contact #content .table:after{
		display: none;
	}
	#contact #content .table table th,
	#contact #content .table table td{
		padding-bottom: 0;
		font-size: 3.8462vw;
		line-height: 5.641vw;
		display: block;
	}
	#contact #content .table table th{
		width: 100%;
		padding-top: 0;
		margin-bottom: 1.2821vw;
	}
	#contact #content .table table td{
		margin-bottom: 10.2564vw;
	}
	#contact #content .table .confirm_area table th{
		padding-top: 0;
	}
	#contact #content .table table td input:not([type="checkbox"]),
	#contact #content .table table td select,
	#contact #content .table table td textarea{
		padding: 3.8462vw;
		font-size: 3.5897vw;
		line-height: 5.641vw;
	}
	#contact #content .table table td .privacy{
		font-size: 3.0769vw;
		margin-bottom: 0;
	}
	#contact #content .table table td .privacy input{
		/*width: 5.1282vw;
		height: 5.1282vw;*/
		width: 3.8462vw;
		height: 3.8462vw;
		margin-right: 1.2821vw;
		margin-left: 3.8462vw;
	}
	#contact #content .table table td .privacy .error{
		font-size: 2.8205vw;
		line-height: 4.1026vw;
		margin-top: 1.2821vw;
	}
	#contact #content .table table td .select_area:after{
		border-width: 1.5385vw 1.0256vw 0 1.0256vw;
		right: 2.5641vw;
	}
	#contact #content .table table td button,
	#contact #content .table table td input[type="submit"]{
		font-size: 3.8462vw;
		line-height: 5.641vw;
		padding: 3.3333vw 5.1282vw;
	}
	#contact #content .table table td .btns .prev{
		margin-top: 5.1282vw;
	}
	#contact #content .table table td .wpcf7-not-valid-tip{
		font-size: 2.8205vw;
		line-height: 4.1026vw;
		margin-top: 1.2821vw;
	}

	/* Privacy Policy
	-----------------------------------*/
	#privacy-policy{
		/*padding-top: 5.641vw;*/
		padding-top: 5.1282vw;
	}
	#privacy-policy .sidede{
		display: none;
	}
	#privacy-policy .sp_wrap{
		padding-right: 0;
	}
	#privacy-policy .tit_h1{
		margin-bottom: 8.2051vw;
	}
	#privacy-policy .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		/*margin-bottom: 20.5128vw;*/
		margin-bottom: 13.0769vw;
	}
	#privacy-policy #content{
		padding-bottom: 25.641vw;
	}
	#privacy-policy #content .txt{
		font-size: 3.5897vw;
		line-height: 5.8974vw;
		max-width: 100%;
		margin: 0 auto 15.3846vw auto;
		padding: 0 7.6923vw;
	}
	#privacy-policy #content .table{
		max-width: 100%;
	}
	#privacy-policy #content .table{
		padding: 15.3846vw 0 0 0;
	}
	#privacy-policy #content .table:before,
	#privacy-policy #content .table:after{
		width: 100%;
	}
	#privacy-policy #content .table:before{
		left: 0;
	}
	#privacy-policy #content .table:after{
		display: none;
	}
	#privacy-policy #content .table table{
		max-width: 100%;
	}
	#privacy-policy #content .table table th,
	#privacy-policy #content .table table td{
		display: block;
		font-size: 3.5897vw;
		line-height: 5.8974vw;
		padding: 0 7.6923vw;
	}
	#privacy-policy #content .table table th{
		width: 100%;
		display: block;
		margin-bottom: 2.5641vw;
	}
	#privacy-policy #content .table table th:after{
		display: none;
	}
	#privacy-policy #content .table table td{
		padding: 0 7.6923vw;
		padding-bottom: 10.2564vw;
	}
	#privacy-policy #content .table table td ul{
		font-size: 3.5897vw;
		line-height: 5.8974vw;
		margin-top: 0.7692vw;
	}

	/* Legal Notice
	-----------------------------------*/
	#legal-notice{
		/*padding-top: 5.641vw;*/
		padding-top: 5.1282vw;
	}
	#legal-notice .sidede{
		display: none;
	}
	#legal-notice .sp_wrap{
		padding-right: 0;
	}
	#legal-notice .tit_h1{
		margin-bottom: 8.2051vw;
	}
	#legal-notice .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		/*margin-bottom: 20.5128vw;*/
		margin-bottom: 13.0769vw;
		max-width: 39.7436vw;
	}
	#legal-notice #content{
		padding-bottom: 25.641vw;
	}
	#legal-notice #content .txt{
		font-size: 3.5897vw;
		line-height: 5.8974vw;
		max-width: 100%;
		margin: 0 auto 15.3846vw auto;
		padding: 0 10.2564vw;
	}
	#legal-notice #content .table{
		max-width: 100%;
	}
	#legal-notice #content .table{
		padding: 0;
	}
	#legal-notice #content .table:before,
	#legal-notice #content .table:after{
		width: 100%;
	}
	#legal-notice #content .table:before{
		left: 0;
	}
	#legal-notice #content .table:after{
		right: 0;
	}
	#legal-notice #content .table table{
		max-width: 100%;
	}
	#legal-notice #content .table table th,
	#legal-notice #content .table table td{
		display: block;
		font-size: 3.5897vw;
		line-height: 5.8974vw;
		padding: 0 7.6923vw;
	}
	#legal-notice #content .table table th{
		width: 100%;
		display: block;
		margin-bottom: 2.5641vw;
	}
	#legal-notice #content .table table th:after{
		display: none;
	}
	#legal-notice #content .table table td{
		padding: 0 7.6923vw;
		/*padding-bottom: 10.2564vw;*/
		padding-bottom: 7.6923vw;
	}
	#legal-notice #content .table table td ul{
		font-size: 3.5897vw;
		line-height: 5.8974vw;
		margin-top: 0.7692vw;
	}

	/* Not Found
	-----------------------------------*/
	#notfound{
		/*padding-top: 5.641vw;*/
		padding-top: 5.1282vw;
	}
	#notfound .sidede{
		display: none;
	}
	#notfound .sp_wrap{
		padding-right: 0;
	}
	#notfound .tit_h1{
		margin-bottom: 8.2051vw;
	}
	#notfound .tit01{
		/*margin-top: -5.8974vw;*/
		margin-top: -5.641vw;
		margin-bottom: 20.5128vw;
		max-width: 44.8718vw;
	}
	#notfound #content{
		padding-bottom: 15.3846vw;
	}
	#notfound #content .txt{
		font-size: 3.8462vw;
		line-height: 5.641vw;
		max-width: 100%;
		margin: 0 auto 15.3846vw auto;
		padding: 0 7.6923vw;
	}
	#notfound #content .txt p{
		margin-bottom: 5.1282vw;
	}
}