@charset "utf-8";


/* topMv
------------------------------------------------------------------------------------ */
section#topMv {
	position: relative;
	width: 100%;
	height:800px;
}
section#topMv:after {
	display: block;
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	width:100%;
	height:100%;
}
section#topMv ul#topMvSlider {
	width: 100%;
	height:800px;
}
section#topMv ul#topMvSlider li {
	height: 800px;
	animation: topMvZoom 30s 1;
	animation-fill-mode: forwards;
}
@keyframes topMvZoom {
	0% {
		transform: scale(1);
	}
	100% {
		transform: scale(1.15);
	}
}
section#topMv ul#topMvSlider li#topMvSlider01 {
	background: url(../../images/top_mv_01.jpg) 50% 50% no-repeat;
	background-size: cover;
}
section#topMv ul#topMvSlider li#topMvSlider02 {
	background: url(../../images/top_mv_02.jpg) 50% 50% no-repeat;
	background-size: cover;
}
section#topMv ul#topMvSlider li#topMvSlider03 {
	background: url(../../images/top_mv_03.jpg) 50% 50% no-repeat;
	background-size: cover;
}
section#topMv ul#topMvSlider li#topMvSlider04 {
	background: url(../../images/top_mv_04.jpg) 50% 50% no-repeat;
	background-size: cover;
}
section#topMv ul#topMvSlider li#topMvSlider05 {
	background: url(../../images/top_mv_05.jpg) 50% 50% no-repeat;
	background-size: cover;
}
section#topMv ul#topMvSlider li#topMvSlider06 {
	background: url(../../images/top_mv_06.jpg) 50% 50% no-repeat;
	background-size: cover;
}
section#topMv ul#topMvSlider li#topMvSlider07 {
	background: url(../../images/top_mv_07.jpg) 50% 50% no-repeat;
	background-size: cover;
}
section#topMv div.topMvText {
}
section#topMv div.topMvText h2#topMvText01 {
	position: absolute;
	right: 4%;
	top: 300px;
	width: 700px;
	z-index: 2;
}
section#topMv div.topMvText h2#topMvText02 {
	position: absolute;
	right: 4%;
	bottom: -67px;
	width: 700px;
	z-index: 2;
}


/* topIntro
------------------------------------------------------------------------------------ */
section#topIntro {
	position: relative;
	background-color: #e9e6e6;
	padding-top: 150px;
	padding-bottom: 120px;
}
section#topIntro div.topIntroBg {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 55%;
	max-width: 980px;
	pointer-events: none;
}
section#topIntro h2 {
}
section#topIntro h2 span.bgextend {
	font-size: 3.25rem;
	line-height: 1.5;
	font-weight: 900;
}
section#topIntro h2 span.bgappear {
	font-size: 3.25rem;
	line-height: 1.5;
	font-weight: 900;
	background: linear-gradient(
		90deg,
		#bb1d2b 0%,
		#fd3d34 25%,
		#f2420b 50%,
		#fd3d34 75%,
		#bb1d2b 100%
	);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
}
section#topIntro h2 span.bgLRextend::before {
	background: linear-gradient(
		90deg,
		#bb1d2b 0%,
		#fd3d34 25%,
		#f2420b 50%,
		#fd3d34 75%,
		#bb1d2b 100%
	);
}

section#topIntro div.topIntroWrapper {
	display: flex;
	justify-content: space-between;
	margin-top: 40px;
}
section#topIntro div.topIntroWrapperLeft {
	display: flex;
	justify-content: space-between;
}
section#topIntro div.topIntroWrapperLeft p {
	line-height: 2;
}
section#topIntro ul.topIntroLinkList {
	width: 450px;
	margin-left: 150px;
}
section#topIntro ul.topIntroLinkList li {
	border-bottom: solid 2px #e73f4e;
}
section#topIntro ul.topIntroLinkList li:first-child {
	border-top: solid 2px #e73f4e;
}
section#topIntro ul.topIntroLinkList li a {
	position: relative;
	display: block;
	font-size: 1.375rem;
	line-height: 1;
	font-weight: 900;
	padding: 20px 0px 20px 5px;
	transition: all 0.4s ease;
	z-index: 1;
}
section#topIntro ul.topIntroLinkList li a::before {
	position: absolute;
	content: "\f178";
	right: 5px;
	top: 50%;
	transform: translateY(-50%);
	font-family: "Font Awesome 6 Sharp";
	font-size: 1rem;
	line-height: 1;
	font-weight: bold;
	z-index: 1;
}
section#topIntro ul.topIntroLinkList li a:hover {
	color: #FFF;
}
section#topIntro ul.topIntroLinkList li a::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 62px;
	background-color: #e73f4e;
	transform: scaleX(0);
	transform-origin: left top;
	transition: all 0.4s ease;
	z-index: -1;
}
section#topIntro ul.topIntroLinkList li a:hover::after {
	transform: scaleX(1);
	z-index: -1;
}


/* topWages
------------------------------------------------------------------------------------ */
section#topWages {
	position: relative;
	background-color: #c00d1c;
	overflow: hidden;
	padding-top: 100px;
	padding-bottom: 50px;
}
section#topWages div.topWagesBg {
	position: absolute;
	inset: 0;
	opacity: 0.6;
	z-index: 1;
	pointer-events: none;
}
section#topWages div.sectionInner {
	position: relative;
	max-width: 1140px;
	z-index: 2;
}
section#topWages h2 {
	width: 70%;
	margin: 0 auto;
}
section#topWages div.topWagesLargeBlock {
	background-color: #FFF;
	padding: 60px 50px;
	margin-top: 70px;
}
section#topWages div.topWagesLargeBlock div.topWagesLargeBlockWrapper {
	display: flex;
	justify-content: center;
}
section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper01 p.topWagesLargeBlockWrapperIcon {
	width: 200px;
	margin-right: 50px;
}
section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper02 p.topWagesLargeBlockWrapperIcon {
	width: 60px;
	margin-right: 20px;
}
section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper02 div {
	margin-right: 50px;
}
section#topWages div.topWagesLargeBlock div.topWagesTextWrapper {
	display: flex;
	align-items: center;
}
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper01 {
	margin-bottom: 20px;
}
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper01 p:has(img) {
	width: 20px;
}
section#topWages div.topWagesLargeBlock div.topWagesTextWrapper p {
	font-size: 1.25rem;
	line-height: 1.35;
	font-weight: 500;
}
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper01 p:not(:last-child),
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper02 p:first-child,
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper03 p:first-child,
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper04 p:first-child {
	margin-right: 15px;
}
section#topWages div.topWagesLargeBlock div.topWagesTextWrapper p:first-child span {
	font-size: .85rem;
	vertical-align: super;
}
section#topWages div.topWagesLargeBlock div.topWagesTextWrapper p span.topWagesTextWrapperValue {
	font-family: "Poppins", sans-serif;
	letter-spacing: 0.01em;
	font-variant-numeric: tabular-nums;/* 数字だけ等幅*/
}
section#topWages div.topWagesLargeBlock div.topWagesTextWrapper p span.topWagesTextWrapperValue.counter {
	display: inline-block;
	min-width: 6ch;/* 6文字分の幅*/
	text-align: right;
}
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper01 p span.topWagesTextWrapperValue {
	font-size: 6rem;
	font-size: 2.25rem;
	line-height: 1;
	font-weight: 500;
}
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper02 p span.topWagesTextWrapperValue {
	font-style: italic;
	font-size: 6rem;
	line-height: 1;
	font-weight: bold;
	color: #c00d1c;
}
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper03 p span.topWagesTextWrapperValue,
section#topWages div.topWagesLargeBlock div#topWagesTextWrapper04 p span.topWagesTextWrapperValue {
	font-style: italic;
	font-size: 3rem;
	line-height: 1;
	font-weight: bold;
	color: #c00d1c;
}
section#topWages div.topWagesLargeBlock div.topWagesTextWrapper p span.topWagesTextWrapperValue span {
	font-family: "Noto Sans JP", sans-serif;
	font-style: italic;
	font-size: 0.6em;
	line-height: 1;
	font-weight: 900;
	color: #c00d1c;
}
section#topWages div.topWagesLargeBlock p.topWagesLargeBlockSubText {
	text-align: center;
	border-bottom: solid 2px #e9e6e6;
	padding-bottom: 40px;
	margin: 20px auto 30px;
}
section#topWages div.topWagesLargeBlock p.topWagesLargeBlockSubText span.topWagesLargeBlockSubTextStrong {
	font-size: 1.25rem;
	font-weight: bold;
	color: #c00d1c;
}
section#topWages div.topWagesLargeBlock p.topWagesLargeBlockSubText span.topWagesLargeBlockSubTextStar {
	font-size: .75rem;
	vertical-align: super;
}
section#topWages div.topWagesSmallBlockWrapper {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 15px;
	margin-top: 15px;
}
section#topWages div.topWagesSmallBlockWrapper div.topWagesSmallBlock {
	background-color: #FFF;
	padding: 25px 30px;
}
section#topWages div.topWagesSmallBlockWrapper div.topWagesSmallBlock div.topWagesSmallBlockIconWrapper {
	display: flex;
	justify-content: center;
	max-width: 180px;
	margin: 0 auto;
}
section#topWages div.topWagesSmallBlockWrapper div.topWagesSmallBlock div.topWagesSmallBlockIconWrapper div {
	width: 50%;
}
section#topWages p.topWagesBtmText {
	font-size: 1.25rem;
	line-height: 1.75;
	font-weight: 500;
	text-align: center;
	color: #FFF;
	margin-top: 40px;
}
section#topWages div.topWagesSmallBlockWrapper div.topWagesSmallBlock p:has(img) {
	margin: 0 auto;
}
section#topWages div.topWagesSmallBlockWrapper div#topWagesSmallBlock01 p:has(img) {
	width: 40px;
}
section#topWages div.topWagesSmallBlockWrapper div#topWagesSmallBlock02 p:has(img) {
	width: 200px;
}
section#topWages div.topWagesSmallBlockWrapper div#topWagesSmallBlock03 p:has(img) {
	width: 80px;
}
section#topWages div.topWagesSmallBlockWrapper div#topWagesSmallBlock04 p:has(img) {
	width: 80px;
}
section#topWages div.topWagesSmallBlockWrapper div.topWagesSmallBlock p.topWagesSmallBlockNum {
	font-size: 1.5rem;
	line-height: 1;
	font-weight: bold;
	text-align: center;
	color: #c00d1c;
	margin-top: 25px;
}
section#topWages div.topWagesSmallBlockWrapper div#topWagesSmallBlock01 p.topWagesSmallBlockNum {
	margin-top: 10px;
}
section#topWages div.topWagesSmallBlockWrapper div.topWagesSmallBlock p.topWagesSmallBlockNum span {
	font-family: "Poppins", sans-serif;
	font-size: 2rem;
	line-height: 1;
	font-weight: 500;
	font-style: normal;
	text-align: center;
}
section#topWages div.topWagesSmallBlockWrapper div.topWagesSmallBlock p.topWagesSmallBlockTitle {
	font-size: 1.125rem;
	line-height: 1;
	font-weight: bold;
	text-align: center;
	margin-top: 15px;
}
section#topWages div.topWagesSmallBlockWrapper div.topWagesSmallBlock p.topWagesSmallBlockText {
	font-size: 0.875rem;
	line-height: 1.75;
	margin-top: 10px;
}
section#topWages div.topWagesSmallBlockWrapper div#topWagesSmallBlock01 div.topWagesSmallBlockIconWrapper div p:nth-child(2) {
	line-height: 1;
	font-weight: 500;
	text-align: center;
	color: #c00d1c;
	margin-top: 10px;
}

/* topWork
------------------------------------------------------------------------------------ */
section#topWork {
	position: relative;
	padding-top: 100px;
	padding-bottom: 100px;
}
section#topWork::before {
	content: "";
	position: absolute;
	inset: 0;
	height: 300px;
	background: url("../../images/top_wages_bg_tri.png") top center no-repeat;
	background-size: auto;
}
section#topWork div.sectionInner p.topWorkFirstText{
	text-align: center;
}
section#topWork div.sectionInner div.topWorkWrapper {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
	margin-top: 80px;
}
section#topWork div.sectionInner div.topWorkWrapper a {
	position: relative;
	display: block;
	flex: 1;
	overflow: hidden;
	height: 650px;
	border-radius: 20px 20px 0 20px;
}
section#topWork div.sectionInner div.topWorkWrapper a span.topWorkCardBg {
	position: absolute;
	inset: 0;
	transition: transform 0.4s ease;
	pointer-events: none;
}
section#topWork div.sectionInner div.topWorkWrapper a#topWorkCard01 span.topWorkCardBg {
	background: url("../../images/top_work_01.jpg") center / cover no-repeat;
}
section#topWork div.sectionInner div.topWorkWrapper a#topWorkCard02 span.topWorkCardBg {
	background: url("../../images/top_work_02.jpg") center / cover no-repeat;
}
section#topWork div.sectionInner div.topWorkWrapper a#topWorkCard03 span.topWorkCardBg {
	background: url("../../images/top_work_03.jpg") center / cover no-repeat;
}
section#topWork div.sectionInner div.topWorkWrapper a:hover span.topWorkCardBg {
	transform: scale(1.1);
}
section#topWork div.sectionInner div.topWorkWrapper a::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(62,36,36,0.3);
	mix-blend-mode: multiply;
	transition: background 0.4s ease;
	z-index: 1;
}
section#topWork div.sectionInner div.topWorkWrapper a:hover::before {
	background: rgba(62,36,36,0.8);
}
section#topWork div.sectionInner div.topWorkWrapper a div.topWorkCardText {
	position: absolute;
	bottom: 80px;
	left: 50%;
	transform: translateX(-50%);
	width: 95%;
	text-align: center;
	color: #fff;
	z-index: 2;
}
section#topWork div.sectionInner div.topWorkWrapper a div.topWorkCardText h3.topWorkCardTitle {
	font-size: 1.75rem;
	line-height: 2;
	letter-spacing: 0.1em;
	font-weight: bold;
	margin-bottom: 15px;
}
section#topWork div.sectionInner div.topWorkWrapper a div.topWorkCardText p {
	font-size: 1.25rem;
	line-height: 1.5;
	letter-spacing: 0.1em;
	font-weight: 500;
}
section#topWork div.sectionInner div.topWorkWrapper a p.topWorkCardTag {
	position: absolute;
	bottom: 0;
	right: 0;
	letter-spacing: 0.1em;
	color: #FFF;
	background-color: #c00d1c;
	padding: 10px 80px;
	clip-path: polygon(30px 0,100% 0,100% 100%,0 100%);
	z-index: 2;
}
section#topWork div.sectionInner div.topWorkWrapper a p.topWorkCardTag::after {
	position: absolute;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
	content: "\f054";
	font-family: "Font Awesome 6 Sharp";
	font-weight: 300;
	color: #f7f7f7;
	font-size: 1.5rem;
}


 /* topFaq
------------------------------------------------------------------------------------ */
section#topFaq {
	padding-top: 100px;
	padding-bottom: 100px;
}
section#topFaq div.sectionInner div.topFlowWrapper {
	width:100%;
	max-width:920px;
	margin: 50px auto 0;
}

/*その他class cssに記載*/





@media screen and (max-width:960px) {


/* topMv SP
------------------------------------------------------------------------------------ */
	section#topMv {
		height:800px;
		background: url(../../images/top_mv_01_sp.jpg) 50% 50% no-repeat;
		background-size: cover;
	}
	section#topMv div.topMvText h2#topMvText01Sp {
		position: absolute;
		left: 50%;
		top: 55px;
		transform: translateX(-50%);
		width: 155px;
		z-index: 2;
	}
	section#topMv div.topMvText h2#topMvText02Sp {
		position: absolute;
		left: 50%;
		bottom: -54px;
		transform: translateX(-50%);
		width: 145px;
		z-index: 2;
	}
	section#topMv div.topMvText h2#topMvText01Sp span,
	section#topMv div.topMvText h2#topMvText02Sp span {
		display: inline-block;
	}


/* topIntro SP
------------------------------------------------------------------------------------ */
	section#topIntro {
		position: relative;
		background-color: #e9e6e6;
		padding-top: 90px;
		padding-bottom: 30%;
	}
	section#topIntro div.topIntroBg {
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		width: 100%;
	}
	section#topIntro h2 span.bgextend,
	section#topIntro h2 span.bgappear {
		font-size: 2.25rem;
		line-height: 1.5;
		text-align: center;
	}
	section#topIntro div.sectionInner div.topIntroWrapper {
		display: block;
	}
	section#topIntro div.sectionInner div.topIntroWrapper ul.topIntroLinkListSp {
		display: flex!important;
		gap: 15px;
		margin-top: 35px;
	}
	section#topIntro div.sectionInner div.topIntroWrapper ul.topIntroLinkListSp li {
		flex: 1;
	}
	section#topIntro div.sectionInner div.topIntroWrapper ul.topIntroLinkListSp li a {
		position: relative;
		display: flex;
		justify-content: center;
		width: 100%;
		box-sizing: border-box;
		font-weight: 500;
		color: #FFF;
		background-color: #111;
		padding: 15px;
		border-radius: 50px;
	}
	section#topIntro div.sectionInner div.topIntroWrapper ul.topIntroLinkListSp li a::before {
		position: absolute;
		content: "\f054";
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
		font-family: "Font Awesome 6 Sharp";
		font-size: 1rem;
		line-height: 1;
		font-weight: 500;
		color: #f7f7f7;
	}


/* topWages SP
------------------------------------------------------------------------------------ */
	section#topWages {
		position: relative;
		padding-top: 60px;
		padding-bottom: 40px;
	}
	section#topWages h2 {
		width: 100%;
		max-width: 750px;
	}
	section#topWages div.topWagesLargeBlock {
		padding: 40px 25px;
		margin-top: 30px;
	}
	section#topWages div.topWagesLargeBlock div.topWagesLargeBlockWrapper {
		display: block;
	}
	section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper01 p.topWagesLargeBlockWrapperIcon {
		width: 100px;
		margin: 0 auto 20px;
	}
	section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper02 {
		display: block;
	}
	section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper02 div {
		margin-right: 0;
	}
	section#topWages div.topWagesLargeBlock div.topWagesTextWrapper {
		justify-content: center;
	}
	section#topWages div.topWagesLargeBlock div.topWagesTextWrapper p {
		font-size: 1rem;
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper02,
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper03,
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper04 {
		display: block;
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper01 p:not(:last-child),
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper02 p:first-child,
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper03 p:first-child,
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper04 p:first-child {
		margin-right: 10px;
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper02 p:first-child,
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper03 p:first-child,
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper04 p:first-child {
		margin-right: 0;
		margin-bottom: 5px;
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper02 p,
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper03 p,
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper04 p {
		text-align: center;
	}
	section#topWages div.topWagesLargeBlock div.topWagesTextWrapper p span.topWagesTextWrapperValue {
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper01 p span.topWagesTextWrapperValue {
		font-size: 6rem;
		font-size: 2.25rem;
		line-height: 1;
		font-weight: 500;
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper02 p span.topWagesTextWrapperValue {
		font-size: 3.25rem;
		line-height: 1;
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper03 p span.topWagesTextWrapperValue,
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper04 p span.topWagesTextWrapperValue {
		font-size: 2.5rem;
		line-height: 1;
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper03 {
		border-bottom: solid 2px #e9e6e6;
		padding-bottom: 15px;
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper04 {
		margin-top: 15px;
	}
	section#topWages div.topWagesLargeBlock p.topWagesLargeBlockSubText {
		position: relative;
		text-align: left;
		border-bottom: none;
		padding-bottom: 0;
		margin: 20px auto 25px;
	}
	section#topWages div.topWagesLargeBlock p.topWagesLargeBlockSubText span.topWagesLargeBlockSubTextStrong {
		font-size: 1rem;
	}
	section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper02 p.topWagesLargeBlockWrapperIcon {
		position: relative;
		width: 100%;
		margin-bottom: 20px;
		z-index: 1;
	}
	section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper02 p.topWagesLargeBlockWrapperIcon::after {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
		width: 100%;
		height: 2px;
		background-color: #c00d1c;
		z-index: 0;
	}
	section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper02 p.topWagesLargeBlockWrapperIcon img {
		position: relative;
		left: 50%;
		transform: translateX(-50%);
		width: 200px;
		z-index: 1;
	}
	section#topWages div.topWagesLargeBlock div#topWagesTextWrapper02 p span.topWagesTextWrapperValue {
		font-size: 3.25rem;
		line-height: 1;
	}
	section#topWages div.topWagesLargeBlock div#topWagesLargeBlockWrapper01 div p.align-r {
		font-size: .75rem;
		line-height: 1;
		margin-top: 5px;
	}
	section#topWages div.topWagesSmallBlockWrapper {
		grid-template-columns: 1fr;
		gap: 10px;
		margin-top: 10px;
	}
	section#topWages div.topWagesSmallBlockWrapper div.topWagesSmallBlock div.topWagesSmallBlockIconWrapper div {
		width: 50%;
	}
	section#topWages p.topWagesBtmText {
		font-size: 1rem;
		line-height: 1.75;
		letter-spacing: 0.06em;
		margin-top: 30px;
	}


/* topWork SP
------------------------------------------------------------------------------------ */
	section#topWork {
		padding-top: 60px;
		padding-bottom: 60px;
	}
	section#topWork::before {
		height: 80px;
		background-size: 150px auto;
	}
	section#topWork div.sectionInner p.topWorkFirstText{
		text-align: left;
	}
	section#topWork div.sectionInner div.topWorkWrapper {
		position: relative;
		left: auto;
		margin-left: calc(-5%);
		margin-right: calc(-5%);
		transform: none;
		width: calc(100% + 10%);
		
		grid-template-columns: 1fr;
		margin-top: 40px;
	}
	section#topWork div.sectionInner div.topWorkWrapper a {
		height: 220px;
		border-radius: 0;
	}
	section#topWork div.sectionInner div.topWorkWrapper a#topWorkCard01 span.topWorkCardBg {
		background: url("../../images/top_work_01_sp.jpg") center / cover no-repeat;
	}
	section#topWork div.sectionInner div.topWorkWrapper a#topWorkCard02 span.topWorkCardBg {
		background: url("../../images/top_work_02_sp.jpg") center / cover no-repeat;
	}
	section#topWork div.sectionInner div.topWorkWrapper a#topWorkCard03 span.topWorkCardBg {
		background: url("../../images/top_work_03_sp.jpg") center / cover no-repeat;
	}
	section#topWork div.sectionInner div.topWorkWrapper a div.topWorkCardText {
		position: absolute;
		bottom: 90px;
		left: 50%;
		transform: translateX(-50%);
		width: 100%;
		text-align: center;
		color: #fff;
		z-index: 2;
	}
	section#topWork div.sectionInner div.topWorkWrapper a div.topWorkCardText h3.topWorkCardTitle {
		font-size: 1.5rem;
		line-height: 1;
		margin-bottom: 10px;
	}
	section#topWork div.sectionInner div.topWorkWrapper a div.topWorkCardText p {
		font-size: 1rem;
	}
	section#topWork div.sectionInner div.topWorkWrapper a p.topWorkCardTag {
		bottom: 15px;
		padding: 10px 50px;
	}
	section#topWork div.sectionInner div.topWorkWrapper a p.topWorkCardTag::after {
		font-size: 1.25rem;
	}


 /* topFaq SP
------------------------------------------------------------------------------------ */
	section#topFaq {
		padding-top: 60px;
		padding-bottom: 100px;
	}
	section#topFaq div.sectionInner div.topFlowWrapper {
		width:100%;
		max-width:920px;
		margin: 50px auto 0;
	}

/*その他class cssに記載*/











}