@charset "UTF-8";

.header-navList__link._outsourcing {
	color: var(--color-orange);
}

.swiper-button-next,
.swiper-button-prev {
	position: static;
	margin: 0;
}
.swiper-pagination {
	inset: auto !important;
}

.container .contactBtnWrap {
	max-width: 500px;
	margin-top: 80px;
	margin-inline: auto;
	transform: translateX(-18%);
}
.container .contactBtnTxt {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1.5em;
	color: var(--color-orange);
	font-size: 22px;
	font-weight: 500;
	letter-spacing: 0.08em;
	line-height: 1.7;
	text-align: center;
}
.container .contactBtnTxt::before,
.container .contactBtnTxt::after {
	content: '';
	display: block;
	width: 1px;
	height: 60px;
	background-color: var(--color-orange);
	margin-top: 10px;
}
.container .contactBtnTxt::before {
	transform: rotate(-20deg);
}
.container .contactBtnTxt::after {
	transform: rotate(20deg);
}
.container .contactBtn {
	height: auto;
	padding-block: .8em;
}
.container .contactBtnTxt + .contactBtn {
	margin-top: 30px;
}

@media screen and (max-width: 960px) {
	.container .contactBtnWrap {
		transform: translateX(0);
	}
}

@media screen and (max-width: 768px) {
	.main {
		overflow: hidden;
	}

	.container .contactBtnWrap {
		margin-top: 30px;
	}
	.container .contactBtnTxt {
		gap: 1em;
		font-size: 18px;
		line-height: 1.6;
	}
	.container .contactBtnTxt::before,
	.container .contactBtnTxt::after {
		height: 50px;
	}
	.container .contactBtnTxt + .contactBtn {
		margin-top: 20px;
	}
	.container .contactBtn {
		max-width: 290px;
		margin-inline: auto;
		padding-block: .5em;
	}
}

/* kv
---------------------------------------------- */
.kv {
	padding-bottom: 230px;
}

.kv__figure {
	position: absolute;
	top: 2%;
	right: -7%;
	width: calc(1165 / 1500 * 100%);
	/* mask-image: linear-gradient(195deg, transparent, transparent 41.6666666667%, rgba(0, 0, 0, 0.02) 43.3333333333%, rgba(0, 0, 0, 0.08) 45%, rgba(0, 0, 0, 0.18) 46.6666666667%, rgba(0, 0, 0, 0.32) 48.3333333333%, rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 0.68) 51.6666666667%, rgba(0, 0, 0, 0.82) 53.3333333333%, rgba(0, 0, 0, 0.92) 55%, rgba(0, 0, 0, 0.98) 56.6666666667%, #000 58.3333333333%, #000);
	-webkit-mask-position: center top;
	mask-position: center top;
	mask-size: 100% max(300%, 100vh);
	-webkit-mask-repeat: none;
	mask-repeat: none;
	transition: mask-position 1s .6s linear, -webkit-mask-position 1s .6s linear; */
	z-index: -1;
}

/* .loaded .kv__figure {
	mask-position: center 100%;
} */

.kv__circleImg01 {
  top: 260px;
  right: calc(140 / 1500 * 100%);
}
.kv__circleImg02 {
  top: 450px;
  right: calc(350 / 1500 * 100%);
  transition-delay: .3s;
}

#kv-svg {
  width: 100%;
	height: 100%;
}
#kv-svg image {
	width: 100%;
	height: 100%;
}
#kv-mask {
  stroke-dasharray: 4000px;
}
.kv-svg__cls-1 {
  fill: none;
  stroke: #fff;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 70px;
	transform: translate(7px, 10px);
}
.loaded #kv-mask {
  animation: write-move-kv 2s .6s both;
}

@keyframes write-move-kv {
  0% {
    stroke-dashoffset: 4000px;
  }

  100% {
    stroke-dashoffset: 0px;
  }
}

@media screen and (max-width: 768px) {
	.kv {
		padding-bottom: 50px;
	}

	.kv__figure {
		top: 15%;
		right: -25%;
		width: calc(421 / 375 * 100%);
	}

	.kv__circleImg01 {
    top: 250px;
    right: calc(25 / 375 * 100%);
  }
  .kv__circleImg02 {
    top: 70px;
    right: calc(45 / 375 * 100%);
  }
}

/* container
---------------------------------------------- */
.container {
	display: flex;
	justify-content: space-between;
}

.sideNav {
	flex-shrink: 0;
	/* width: 130px; */
	padding-left: min(3.334vw, 50px);
	/* padding-top: 180px; */
}

.sideNavList {
	position: sticky;
	top: 180px;
	z-index: 10;
}
.sideNavList > li + li {
	margin-top: 1em;
}

.sideNavList__link {
	position: relative;
	color: #a3a3a3;
	font-size: 15px;
	letter-spacing: 0.1em;
	line-height: 1.4;
	padding-left: 1em;
	transition: color .4s;
	z-index: 0;
}
.sideNavList__link::before {
	content: '';
	position: absolute;
	top: .5em;
	left: 0;
	display: block;
	width: 7px;
	border-radius: 50%;
	aspect-ratio: 1;
	background-color: var(--color-orange);
	transform: scale(0);
	transition: transform .4s;
	z-index: 0;
}

.sideNavList__link.is-active {
	color: var(--color-orange);
}
.sideNavList__link.is-active::before {
	transform: scale(1);
}

.contents {
	width: calc(1305 / 1500 * 100%);
	margin-left: -6.5%;
}

.section + .section {
	margin-top: 150px;
}

.section {
	padding-block: 130px 160px;
}
.sectionType01::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #faf6eb;
	border-radius: 200px 0 0 200px;
	z-index: -1;
}
.sectionType02::before {
	content: '';
	position: absolute;
	top: 0;
	left: var(--adjustment);
	width: 100%;
	height: 100%;
	background-color: #faf6eb;
	border-radius: 0 200px 200px 0;
	margin-left: var(--adjustment);
	z-index: -1;
}

.section__inner {
	position: relative;
	padding-inline: calc(185 / 1305 * 100%) calc(195 / 1305 * 100%);
	/* width: 90%; */
	/* margin-left: calc(185 / 1305 * 100%); */
	z-index: 0;
}
.sectionType02 .section__inner {
	padding-right: 0;
}

@media screen and (max-width: 1024px) {
	.section__inner {
		padding-inline: calc(100 / 1305 * 100%) calc(60 / 1305 * 100%);
	}
}

@media screen and (max-width: 960px) {
	.sideNav {
		display: none;
	}
	.contents {
		width: 100%;
		margin-left: 0;
	}
	.section__inner {
		padding-inline: calc(100 / 1305 * 100%);
	}
}

@media screen and (max-width: 768px) {
	.section {
		padding-block: 70px;
	}
	.section + .section {
		margin-top: 80px;
	}
	.section__inner {
		padding-inline: 0;
		width: calc(335 / 375 * 100%);
		margin-inline: auto;
	}
	.sectionType01::before {
		border-radius: 80px 0 0 80px;
	}
	.sectionType02::before {
		border-radius: 0 80px 80px 0;
		margin-left: 0;
	}

	.section__ttl {
		text-align: center;
	}
}

/* reason
---------------------------------------------- */
.reasonList {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 80px calc(85 / 925 * 100%);
	margin-top: 70px;
}

.reasonList > li:nth-child(even) {
	margin-top: 80px;
}

.reasonList .cardItem__num {
	width: calc(80 / 520 * 100%);
}

.reasonList .cardItem__ttl {
	width: calc(360 / 420 * 100%);
	font-size: clamp(18px, -0.87rem + 2.67vw, 26px);
	padding-block: 1em .5em;
}

.reasonList__txt {
	margin-top: 1em;
}

@media screen and (max-width: 768px) {
	.reasonList {
		grid-template-columns: 1fr;
		row-gap: 70px;
		width: calc(300 / 335 * 100%);
		margin-top: 45px;
		margin-inline: auto;
	}

	.reasonList > li:nth-child(even) {
		margin-top: 0;
	}

	.reasonList .cardItem__num {
		width: 60px;
	}

	.reasonList .cardItem__ttl {
		width: calc(270 / 300 * 100%);
		padding-block: .8em .1em;
		padding-left: 0;
	}
}

/* voice
---------------------------------------------- */
.voiceBox {
	margin-top: 70px;
}

.voiceBox__copy {
	font-size: clamp(17px, 0.6rem + 0.96vw, 24px);
	font-weight: 500;
	letter-spacing: 0.1em;
	line-height: 1.6;
}
.voiceBox__copy .small {
	font-size: 75%;
}
.voiceBox__inner {
	align-items: center;
	column-gap: calc(35 / 925 * 100%);
	margin-top: 20px;
}

.voiceBox:nth-child(odd) .voiceBox__inner {
	flex-direction: row-reverse;
}

.voiceBox__comment {
	position: relative;
	flex: 1;
	background-color: #fff;
	border-radius: 20px;
	padding: min(calc(45 / 925 * 100%), 45px);
	z-index: 0;
}
.voiceBox__comment::before {
	content: '';
	position: absolute;
	bottom: 20%;
	right: -20px;
	width: 20px;
	height: 20px;
	background: url(../img/figure_balloon-tri.svg) center/contain no-repeat;
	z-index: 0;
}
.voiceBox:nth-child(odd) .voiceBox__comment::before {
	right: auto;
	left: -20px;
	transform: scaleX(-1);
}

.voiceBox__txt::before {
	content: '';
	display: inline-block;
	width: 9px;
	aspect-ratio: 1;
	background-color: var(--color-orange);
	border-radius: 50%;
	vertical-align: 2px;
	margin-right: .5em;
}

.voiceBox__img {
	width: calc(150 / 925 * 100%);
}

.voice .snsBox::before,
.voice .snsBox::after {
	background-image: url(../../img/common/txt_quotation-beige.svg);
}
.voice .snsBox__inner {
	background-color: #faf6eb;
}
.voice .snsBox__info .account {
	font-size: clamp(16px, 0rem + 1.33vw, 20px);
}

.voice .section__figure {
	position: absolute;
	top: -19%;
	left: -17%;
	width: calc(529 / 1305 * 100%);
	height: 432px;
	z-index: 1;
}

@media screen and (min-width: 769px) {
	.voice .snsBox__inner {
		padding-inline: calc(60 / 920 * 100%);
	}
}

@media screen and (max-width: 768px) {
	.voiceBox {
		margin-top: 30px;
	}

	.voiceBox__copy {
		line-height: 1.8;
	}
	.voiceBox__inner {
		display: block;
		margin-top: 15px;
	}

	.voiceBox__comment {
		border-radius: 10px;
		padding: 30px calc(25 / 335 * 100%);
	}
	.voiceBox__comment::before {
		bottom: -20px;
		right: 150px;
		transform: rotate(90deg);
	}
	.voiceBox:nth-child(odd) .voiceBox__comment::before {
		left: 150px;
		transform: scaleX(-1) rotate(90deg);
	}

	.voiceBox__img {
		position: relative;
		width: 100px;
		margin-top: -30px;
		margin-inline: auto 40px;
		z-index: 1;
	}
	.voiceBox:nth-child(odd) .voiceBox__img {
		margin-inline: 40px auto;
	}

	.voice .snsBox {
		margin-top: 70px;
	}

	.voice .section__figure {
		top: -7%;
		left: -12%;
		width: calc(264 / 375 * 100%);
		height: 216px;
	}
}

/* flow
---------------------------------------------- */
.flow .section__inner {
	display: flex;
	column-gap: calc(40 / 925 * 100%);
}

.flowBox {
	display: grid;
	grid-template-columns: 1fr 50%;
	grid-template-rows: 80px 1fr;
	column-gap: calc(100 / 1000 * 100%);
}
.flowBox + .flowBox {
	margin-top: 80px;
}

.flowBox__num {
	width: fit-content;
	font-size: 16px;
	text-align: center;
}
.flowBox__num .num {
	display: block;
	font-size: 70px;
}

.flowBox__img {
	grid-area: 1/2/3/3;
}
.flowBox__img img {
	border-radius: 40px 0 0 40px;
}

.flowBox__body {
	grid-area: 2/1/3/2;
	margin-top: 40px;
}
.flowBox__txt {
	margin-top: 1em;
	text-align: justify;
}

.flowBox:nth-child(1) .flowBox__num {
	color: var(--color-orange);
}
.flowBox:nth-child(2) .flowBox__num {
	color: var(--color-pink);
}
.flowBox:nth-child(3) .flowBox__num {
	color: var(--color-green);
}
.flowBox:nth-child(4) .flowBox__num {
	color: var(--color-blue);
}

.flow .section__figure01 {
	position: absolute;
	top: -4%;
	right: 13%;
	width: calc(652 / 1305 * 100%);
	height: 198px;
	z-index: 1;
}

.flow .section__figure02 {
	position: absolute;
	bottom: 13%;
	left: -24%;
	width: calc(634 / 1305 * 100%);
	height: 217px;
	z-index: 1;
}

@media screen and (max-width: 768px) {
	.flow .section__inner {
		display: block;
	}

	.flow .section__ttl {
		writing-mode: horizontal-tb;
	}

	.flowBox {
		display: block;
		width: calc(300 / 335 * 100%);
		margin-top: 45px;
		margin-inline: auto;
	}
	.flowBox + .flowBox {
		margin-top: 40px;
	}

	.flowBox__num {
		position: relative;
		margin-bottom: -30px;
		margin-left: 5px;
		z-index: 1;
	}

	.flowBox__img {
		margin-right: var(--adjustment);
	}
	.flowBox__img img {
		border-radius: 20px 0 0 20px;
	}

	.flowBox__body {
		margin-top: 30px;
	}
	.flowBox__copy {
		font-size: 22px;
	}

	.flow .contactBtnWrap {
		margin-top: 110px;
	}

	.flow .section__figure01 {
		top: -2%;
		right: -9%;
		width: calc(326 / 375 * 100%);
		height: 99px;
	}

	.flow .section__figure02 {
		bottom: 8.5%;
		left: -35%;
		width: calc(317 / 375 * 100%);
		height: 108px;
	}
}

/* faq
---------------------------------------------- */
.faqWrapper {
	margin-top: 80px;
}

.faqBox + .faqBox {
	margin-top: 40px;
}

.question {
	display: flex;
	align-items: flex-start;
	gap: 1.5em;
	background-color: #faf6eb;
	border-radius: 30px;
	padding: 30px calc(50 / 925 * 100%);
}
.question__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	aspect-ratio: 1;
	background-color: var(--color-orange);
	border-radius: 50%;
	color: #fff;
	font-size: 23px;
}
.question__txt {
	flex: 1;
	font-size: clamp(17px, 0.73rem + 0.68vw, 22px);
	font-weight: 500;
	letter-spacing: 0.1em;
	line-height: 1.8;
}

.answer {
	margin-top: 1.5em;
	padding-inline: 1.5em;
}

.faq .section__figure {
	position: absolute;
	top: 2%;
	right: -5%;
	width: calc(507 / 1305 * 100%);
	height: 208px;
	z-index: 1;
}

@media screen and (max-width: 768px) {
	.faqWrapper {
		margin-top: 40px;
	}

	.faqBox + .faqBox {
		margin-top: 30px;
	}

	.question__txt {
		margin-top: 0.3em;
	}

	.question {
		gap: 1em;
		border-radius: 15px;
		padding: 15px calc(20 / 335 * 100%);
	}

	.faq .section__figure {
		top: -3%;
		right: -1%;
		width: calc(253 / 375 * 100%);
		height: 104px;
	}
}