.sp {
	display: none;
}


/*------------------------------ 共通 ------------------------------*/
.container {
	max-width: 1390px;
}

.inner {
	max-width: 1200px;
}

.blue-heading {
	font-size: 5rem;
}

@media screen and (max-width: 1300px) {
	.blue-heading {
		font-size: clamp(4rem, calc(3.9vw), 4.9rem);
	}
}

@media screen and (max-width: 1000px) {
	.blue-heading {
		font-size: clamp(3.6rem, calc(4.6vw), 4rem);
	}
}

.white-heading {
	font-size: 5rem;
}

@media screen and (max-width: 1300px) {
	.white-heading {
		font-size: clamp(4rem, calc(3.9vw), 4.9rem);
	}
}

@media screen and (max-width: 1000px) {
	.white-heading {
		font-size: clamp(3.6rem, calc(4.6vw), 4rem);
	}
}

.dot-bg {
	background-size: 30px 30px;
}

/* オレンジボタン */
.orange-link {
	font-size: 3rem;
}

@media screen and (max-width: 1300px) {
	.orange-link {
		font-size: clamp(2rem, 2vw, 2.7rem);
	}
}

@media screen and (max-width: 1000px) {
	.orange-link {
		font-size: clamp(1.8rem, 2.3vw, 2rem);
	}
}

/* 青の四角ボタン */
.blue-square-link {
	font-size: 2.6rem;
}

@media screen and (max-width: 1100px) {
	.blue-square-link {
		font-size: clamp(2.3rem, 2vw, 2.6rem);
	}
}

@media screen and (max-width: 1000px) {
	.blue-square-link {
		font-size: clamp(2rem, 2.6vw, 2.3rem);
	}
}

.underline-arrow-link {
	font-size: 3.8rem;
}

@media screen and (max-width: 1000px) {
	.underline-arrow-link {
		font-size: clamp(3rem, 4vw, 3.7rem);
	}
}


/* パンくずリスト */
.breadcrumb {
	padding: 25px 30px;
	gap: 0 60px;
}

.breadcrumb li {
	font-size: 2.4rem;
}

.breadcrumb li a::after {
	right: -30px;
}

/* カテゴリ一覧 */
.category-list {
	padding: 70px 0 90px;
}

.category-list h2 {
	margin-bottom: 60px;
}

.category-list ul {
	margin-bottom: 60px;
}

.category-list ul li {
	width: 23%;
}

@media screen and (max-width: 1400px) {
	.category-list ul li {
		width: 48%;
	}
}

.category-list ul li a h3 {
	font-size: 2rem;
}

@media screen and (max-width: 1500px) {
	.category-list ul li a h3 {
		font-size: 1.8rem;
	}
}

/* 〇〇別検索 */
.another {
	padding: 90px 0 70px;
}

.another .inner {
	max-width: 800px;
}

.another .inner a .circle {
	margin-bottom: 25px;
}

.another .inner a p {
	font-size: 2.6rem;
}

/* ケアラボをもっと知りたい方へ */
.know {
	padding: 70px 0 90px;
}

.know h2 {
	margin-bottom: 60px;
}

.know .inner ul li {
	width: 47%;
}


/* まずはお悩み・課題をお教えください（フッター上共通パーツ） */
@media screen and (max-width: 1400px) {
	.on-footer .inner {
		width: 95%;
		margin-left: 5%;
	}
}

.on-footer .inner .heading-links {
	width: 50%;
}

@media screen and (max-width: 900px) {
	.on-footer .inner .heading-links {
		width: 57%;
	}
}

.on-footer .inner .heading-links h2 {
	font-size: 3rem;
}

@media screen and (max-width: 1200px) {
	.on-footer .inner .heading-links h2 {
		font-size: clamp(2.4rem, 2.4vw, 2.7rem);
	}
}

@media screen and (max-width: 900px) {
	.on-footer .inner .heading-links h2 {
		font-size: 2.2rem;
	}
}

.on-footer .inner .heading-links p {
	font-size: 2rem;
	margin-bottom: 30px;
}

@media screen and (max-width: 1200px) {
	.on-footer .inner .heading-links p {
		font-size: clamp(1.7rem, 1.7vw, 1.9rem);
	}
}

.on-footer .inner .heading-links .links {
	font-size: 2rem;
	justify-content: space-between;
}

.on-footer .inner .heading-links .links a {
	font-size: 2.1rem;
	width: 48%;
	height: 60px;
}

@media screen and (max-width: 1300px) {
	.on-footer .inner .heading-links .links a {
		font-size: clamp(1.5rem, 1.5vw, 1.8rem);
	}
}

.on-footer .inner .img {
	width: 41%;
}

@media screen and (max-width: 1200px) {
	.on-footer .inner .heading-links .links a::before {
		right: 37px;
	}

	.on-footer .inner .heading-links .links a::after {
		width: 20px;
	}
}

@media screen and (max-width: 900px) {
	.on-footer .inner .heading-links .links a::before {
		right: 32px;
	}

	.on-footer .inner .heading-links .links a::after {
		right: 15px;
	}
}


/* マウスストーカー */
#stkr {
	position: fixed;
	top: 0px;
	left: 0px;
	width: 15px;
	height: 15px;
	background: rgba(0, 0, 0, 0.5);
	border-radius: 50%;
	transition: 0.2s;
	transition-timing-function: ease-out;
	pointer-events: none;
	z-index: 9999;
	translate: none;
	rotate: none;
}


/*------------------------------ 下層 共通ファーストビュー ------------------------------*/
.c-fv {
	padding: 30px 30px 80px;
}

@media screen and (max-width: 1000px) {
	.c-fv {
		padding: 150px 30px 80px;
	}
}

.c-fv .fv-top {
	top: 0;
	filter: blur(30px);
}

@media screen and (max-width: 1000px) {
	.c-fv .fv-top {
		top: 50px;
	}
}

@media screen and (max-width: 1000px) {
	.c-fv .logo {
		display: none;
	}
}

.c-fv .ttl-img .c-left-figure {
	position: relative;
	left: -300px;
}

@media screen and (max-width: 1200px) {
	.c-fv .ttl-img .c-left-figure {
		left: -200px;
	}
}

.c-fv .ttl-img figure .img {
	margin-bottom: 22px;
}

@media screen and (max-width: 1000px) {
	.c-fv .ttl-img figure .img {
		margin-bottom: 15px;
	}
}

.c-fv .ttl-img figure figcaption h1 {
	font-size: 5rem;
}

@media screen and (max-width: 1400px) {
	.c-fv .ttl-img figure figcaption h1 {
		font-size: clamp(3.6rem, 3.6vw, 4.9rem);
	}
}

@media screen and (max-width: 1000px) {
	.c-fv .ttl-img figure figcaption h1 {
		font-size: clamp(3rem, 3.8vw, 3.5rem);
	}
}

/*------------------------------ メリット ------------------------------*/
.merit {
	padding: 37px 0;
}

.merit .container {
	justify-content: center;
	gap: 0 30px;
}

.merit .container .merit-img img {
	max-height: 470px;
}

.merit .container .ttl-txt {
	width: 40%;
}

@media screen and (max-width: 1400px) {
	.merit .container .ttl-txt {
		width: 100%;
	}
}

.merit .container .ttl-txt h2 {
	font-size: 3.6rem;
	/* margin-bottom: 25px; */
	/* padding: 5px 10px; */
}

@media screen and (max-width: 1400px) {
	.merit .container .ttl-txt h2 {
		font-size: clamp(3rem, 3vw, 3.6rem);
	}
}


/*------------------------------ 各機能詳細 ------------------------------*/
.anchor {
	padding: 80px 0 80px;
}

.anchor .anchor-link {
	margin-bottom: 100px;
}

.anchor .anchor-link a {
	width: 32%;
}

@media screen and (max-width: 1000px) {
	.anchor .anchor-link {
		gap: 28px 4%;
	}
}

@media screen and (max-width: 1000px) {
	.anchor .anchor-link a {
		width: 48%;
	}
}

@media screen and (max-width: 1350px) {
	.anchor .anchor-link a {
		gap: 0 10px;
	}
}

.anchor .anchor-link a::after {
	right: 20px;
}

.anchor .anchor-link a p {
	font-size: 2.4rem;
}

@media screen and (max-width: 1350px) {
	.anchor .anchor-link a p {
		font-size: clamp(1.6rem, 1.6vw, 2.3rem);
	}
}

.anchor .each-anchor {
	padding-top: 110px;
	max-width: 1200px;
	/* ↑画像狭くなる？ */
}

.anchor .each-anchor .anchor-bg {
	padding: 50px 45px 25px;
}

.anchor .each-anchor .anchor-icon {
	top: -60px;
	left: 45px;
}

.anchor .each-anchor h2 {
	font-size: 2.4rem;
	margin-bottom: 30px;
}

.anchor .each-anchor .explanation-img {
	justify-content: space-between;
	padding-bottom: 40px;
	margin-bottom: 25px;
	/* position: relative; */
}

.anchor .each-anchor .explanation-img .img img {
	margin-bottom: 15px;
}

.anchor .each-anchor .explanation-img .img .expansion {
	font-size: 1.6rem;
	line-height: 1;
	text-align: right;
}

/* .anchor .each-anchor:first-of-type .explanation-img .img {
	position: relative;
}

.anchor .each-anchor:first-of-type .explanation-img .img::after {
	position: absolute;
	content: "※画像はクリックで拡大いただけます";
	bottom: -30px;
	right: 0;
	font-size: 1.6rem;
} */

@media screen and (max-width: 1200px) {
	.anchor .each-anchor .explanation-img {
		flex-direction: column;
		gap: 50px 0;
	}
}

.anchor .each-anchor .explanation-img .explanation {
	width: 43%;
}

@media screen and (max-width: 1200px) {
	.anchor .each-anchor .explanation-img .explanation {
		width: 100%;
	}
}

.anchor .each-anchor .explanation-img .explanation h3 {
	font-size: 3.6rem;
	margin-bottom: 35px;
}

@media screen and (max-width: 1400px) {
	.anchor .each-anchor .explanation-img .explanation h3 {
		font-size: clamp(2.8rem, 2.4vw, 3.5rem);
	}
}

@media screen and (max-width: 1200px) {
	.anchor .each-anchor .explanation-img .explanation h3 {
		font-size: 3.6rem;
	}
}

.anchor .each-anchor .explanation-img .img {
	width: 55%;
}

@media screen and (max-width: 1200px) {
	.anchor .each-anchor .explanation-img .img {
		width: 100%;
	}
}

.anchor .each-anchor ul li {
	font-size: 2rem;
}

@media screen and (max-width: 900px) {
	.anchor .each-anchor ul li {
		font-size: 1.7rem;
	}
}

/* 各機能詳細 画像拡大モーダル */
#grayDisplay img {
	left: 80px;
	max-width: 1600px;
	width: 85%;
}

@media screen and (max-width: 1600px) {
	#grayDisplay img {
		width: 74%;
	}
}

@media screen and (max-width: 1000px) {
	#grayDisplay img {
		left: 0;
		margin-top: 90px;
		width: 85%;
	}
}

#grayDisplay::before {
	top: 50px;
}

@media screen and (max-width: 1000px) {
	#grayDisplay::before {
		top: 140px;
	}
}

#grayDisplay::after {
	top: 50px;
}

@media screen and (max-width: 1000px) {
	#grayDisplay::after {
		top: 140px;
	}
}



/*------------------------------ 横並び ファーストビュー ------------------------------*/
.c-beside-fv {
	padding: 30px 30px 0;
}

@media screen and (max-width: 1000px) {
	.c-beside-fv {
		padding: 120px 30px 0;
	}
}

.c-beside-fv .ttl-img {
	justify-content: center;
}

.c-beside-fv .ttl-img figure {
	width: 45%;
	margin-right: 5%;
}

.c-beside-fv .ttl-img .eye-catch {
	width: 55%;
	text-align: center;
	padding-top: 30px;
}

/*------------------------------ 福祉業界のDXを牽引します 共通 ------------------------------*/
.concept {
	padding: 60px 0 110px;
}

.concept .inner .dx-icon {
	position: relative;
}

.concept .inner .dx-icon .dx {
	width: 55%;
}

@media screen and (max-width: 1200px) {
	.concept .inner .dx-icon .dx {
		width: 100%;
	}
}

.concept .inner .dx-icon .dx h2 {
	font-size: 3.8rem;
	margin-bottom: 30px;
}

@media screen and (max-width: 1300px) {
	.concept .inner .dx-icon .dx h2 {
		font-size: 3.5rem;
	}
}

.concept .inner .dx-icon .dx h2 .bigger {
	font-size: 5rem;
}

@media screen and (max-width: 1300px) {
	.concept .inner .dx-icon .dx h2 .bigger {
		font-size: 4.5rem;
	}
}

.concept .inner .dx-icon .dx h2 .bigger-thicker {
	font-size: 7rem;
}

@media screen and (max-width: 1300px) {
	.concept .inner .dx-icon .dx h2 .bigger-thicker {
		font-size: 6.5rem;
	}
}

.concept .inner .dx-icon .dx .dx-text p:first-of-type {
	margin-bottom: 30px;
}

.concept .inner .dx-icon .dx .dx-text h3 {
	margin-bottom: 3px;

}

.concept .inner .dx-icon .icon {
	position: absolute;
	right: -235px;
	top: 0;
	background-image: url(../img/top/over-bg.svg);
	background-size: cover;
	width: 648px;
	height: 481px;
	animation: floating 1.8s ease-in-out infinite alternate-reverse;
}

@keyframes floating {
	0% {
		transform: translate(1%, -1%);
		opacity: 0.8;
	}

	100% {
		transform: translate(-1%, 1%);
		opacity: 1;
	}
}

@media screen and (max-width: 1200px) {
	.concept .inner .dx-icon .icon {
		display: none;
	}
}

.concept .inner .dx-icon .icon img {
	position: absolute;
	top: 204px;
	left: 70px;
}


/*------------------------------ DXソリューションを提供 共通 ------------------------------*/
.dx-solution {
	padding: 70px 0 30px;
}

.dx-solution .inner .logo-intro {
	justify-content: space-between;
	align-items: center;
	margin-bottom: 48px;
}

.dx-solution .inner .logo-intro .logo {
	width: 30%;
}

.dx-solution .inner .logo-intro .intro {
	width: 60%;
}

@media screen and (max-width: 900px) {
	.dx-solution .inner .logo-intro .intro {
		width: 62%;
	}
}

.dx-solution .inner .logo-intro .intro h2 {
	font-size: 5rem;
	margin-bottom: 31px;
}

@media screen and (max-width: 1400px) {
	.dx-solution .inner .logo-intro .intro h2 {
		font-size: clamp(3.5rem, calc(3.5vw), 4.8rem);
	}
}

@media screen and (max-width: 900px) {
	.dx-solution .inner .logo-intro .intro h2 {
		font-size: 3.1rem;
	}
}

.dx-solution .inner .offer .each-offer {
	width: 32%;
}

.dx-solution .inner .offer .each-offer .speech-bubble p {
	font-size: 5rem;
	top: 20px;
	left: 50%;
	transform: translateX(-50%);
}

.dx-solution .inner .offer .each-offer:first-of-type .speech-bubble p {
	top: 18px;
}

.dx-solution .inner .offer .each-offer .solution-img {
	margin-bottom: 18px;
	top: -7px;
	height: 259px;
	z-index: -1;
}

@media screen and (max-width: 900px) {
	.dx-solution .inner .offer .each-offer .text {
		letter-spacing: 0;
		font-size: 1.46rem;
	}
}

.dx-solution .thin-green {
	position: absolute;
	width: 100%;
	background-color: #EBF2F4;
	bottom: 0;
	left: 0;
	height: 293px;
}


/*------------------------------ お役立ちコラム ------------------------------*/
.useful-column {
	padding: 60px 0 70px;
}

.useful-column h2 {
	margin-bottom: 40px;
}


/*------------------------------ ヘッダー ------------------------------*/
header .container {
	max-width: 1500px;
	width: 84%;
}

header .container .logo-button-links {
	gap: 0 18%;
}

@media screen and (max-width: 1500px) {
	header .container .logo-button-links {
		gap: 0 13%;
	}
}

@media screen and (max-width: 1200px) {
	header .container .logo-button-links {
		gap: 0 9%;
	}
}

header .container .logo-button-links .close-button {
	position: absolute;
	top: -49px;
	right: 0;
	background-color: #fff;
	width: 39px;
	height: 39px;
	border-radius: 9999px;
	cursor: pointer;
}

header .container .logo-button-links .close-button::before {
	position: absolute;
	content: "";
	width: 24px;
	height: 2px;
	background-color: #152F58;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
}

header .container .logo-button-links .close-button::after {
	position: absolute;
	content: "";
	width: 24px;
	height: 2px;
	background-color: #152F58;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(-45deg);
}

header .container .logo-button-links .logo-button-main {
	flex-direction: column;
	gap: 80px 0;
}

header .container .logo-button-links .logo-button-main .logo-button h1 {
	margin-bottom: 85px;
	padding-top: 50px;
}

header .container .logo-button-links .logo-button-main .logo-button h1 a img {
	margin-inline: auto;
	transition: .5s;
}

header .container .logo-button-links .logo-button-main .logo-button h1 a:hover img {
	opacity: .6;
}

header .container .logo-button-links .logo-button-main .logo-button .arrow-move {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 314px;
	height: 52px;
	border-radius: 35px;
	border: 1px solid #fff;
	position: relative;
	font-size: 22px;
	transition: .3s;
}

header .container .logo-button-links .logo-button-main .logo-button .arrow-move:hover {
	border-radius: 0;
	transition: .5s;
}

header .container .logo-button-links .logo-button-main .logo-button .arrow-move::after {
	position: absolute;
	content: "→";
	left: 219px;
	transition: .3s;
}

header .container .logo-button-links .logo-button-main .logo-button .arrow-move:hover:after {
	left: 229px;
	transition: .5s;
}

header .container .logo-button-links .logo-button-main .logo-button .arrow-move {
	margin-bottom: 35px;
}

header .container .logo-button-links .logo-button-main .logo-button .arrow-move:last-of-type {
	margin-bottom: 0;
}

header .container .logo-button-links .logo-button-main .logo-button .arrow-move span {
	position: absolute;
	left: 76px;
}

header .container .logo-button-links .logo-button-main .main-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-inline: auto;
	gap: 35px 0;
	width: 314px;
}

header .container .logo-button-links .logo-button-main .main-links a {
	font-size: 18px;
	width: 50%;
}

header .container .logo-button-links .logo-button-main .main-links a.faq {
	height: 27px;
}

header .container .logo-button-links .heading-links .each-links h2 {
	font-size: 18px;
}

@media screen and (min-width: 1001px) {
	header .container .logo-button-links .heading-links .each-links a {
		margin-bottom: 35px;
	}
}

header .container .logo-button-links .heading-links .each-links a::after {
	left: 15px;
}


/* ハンバーガーメニュー */
header .container .hamburger {
	position: fixed;
	width: 80px;
	height: 100vh;
	background-color: #072E61;
	top: 0;
	left: 0;
	border-right: 1px solid #fff;
}

header .container .hamburger.h_active {
	border-right: 1px solid #072E61;
}

header .container .hamburger .hamburger-contents {
	position: relative;
	top: 50vh;
	left: 50%;
	transform: translate(-50%, -50%);
	margin-bottom: 15px;
	width: 40px;
	height: 30px;
}

header .container .hamburger .hamburger-contents span:first-of-type {
	position: absolute;
	content: "";
	width: 40px;
	height: 2px;
	background-color: #fff;
	top: 0;
	left: 0;
}

header .container .hamburger.h_active .hamburger-contents span:first-of-type {
	transition: .1s;
	transform: rotate(45deg);
	top: 50%;
}

header .container .hamburger .hamburger-contents span:nth-of-type(2) {
	position: absolute;
	content: "";
	width: 40px;
	height: 2px;
	background-color: #fff;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}

header .container .hamburger.h_active .hamburger-contents span:nth-of-type(2) {
	opacity: 0;
}

header .container .hamburger .hamburger-contents span:last-of-type {
	position: absolute;
	content: "";
	width: 40px;
	height: 2px;
	background-color: #fff;
	bottom: 0;
	left: 0;
	transform: translateY(-50%);
}

header .container .hamburger.h_active .hamburger-contents span:last-of-type {
	transition: .1s;
	transform: rotate(-45deg);
	top: 50%;
}

header .container .hamburger p {
	color: #fff;
	font-size: 14px;
	position: absolute;
	top: calc(50vh + 28px);
	left: 50%;
	transform: translateX(-50%);
	margin: 0;
}


/*------------------------------ フッター ------------------------------*/
footer {
	padding-top: 100px;
}

footer .inner .func-office-manager {
	justify-content: space-between;
	margin-bottom: 80px;
}

footer .inner .func-office-manager .func {
	width: 50%;
}

@media screen and (max-width: 1000px) {
	footer .inner .func-office-manager .func {
		width: 46%;
	}
}

footer .inner .func-office-manager .func h2 {
	top: -45px;
	left: 0;
}

@media screen and (max-width: 1000px) {
	footer .inner .func-office-manager .func h2 {
		left: -18px;
	}
}

footer .inner .func-office-manager .func ul {
	gap: 30px 0;
	padding-left: 20px;
}

@media screen and (max-width: 1000px) {
	footer .inner .func-office-manager .func ul {
		padding-left: 0;
	}
}

@media screen and (max-width: 1000px) {
	footer .inner .func-office-manager .func ul li a {
		font-size: 1.4rem;
	}
}

footer .inner .func-office-manager .office-manager {
	width: 50%;
}

@media screen and (max-width: 1000px) {
	footer .inner .func-office-manager .office-manager {
		width: 52%;
	}
}

footer .inner .func-office-manager .office-manager ul {
	gap: 35px 0;
}

footer .inner .order-change-links .links {
	justify-content: space-between;
	margin-bottom: 65px;
}

footer .inner .order-change-links .links a {
	width: 48%;
}

footer .inner .order-change-links .other-links {
	margin-bottom: 70px;
	align-items: center;

	flex-wrap: wrap;
	gap: 30px 45px;
	justify-content: center;
}

footer .inner .footer-logo {
	margin-bottom: 58px;
}

footer .over-footer {
	padding: 38px 0 34px;
}

footer .over-footer .container {
	justify-content: space-between;
	align-items: flex-end;
}

footer .over-footer .container .logo-address {
	justify-content: center;
	gap: 0 20px;
}

@media screen and (max-width: 1100px) {
	footer .over-footer .container .logo-address {
		gap: 0 15px;
	}
}

@media screen and (max-width: 1100px) {
	footer .over-footer .container .logo-address img {
		width: 130px;
	}
}

@media screen and (max-width: 900px) {
	footer .over-footer .container .logo-address {
		flex-direction: column;
		gap: 20px 0;
	}
}

footer .over-footer .container .copy {
	font-size: 1.4rem;
	margin-bottom: 3px;
}


/*------------------------------ トップページ ------------------------------*/

/* ファーストビュー */
#top .fv {
	margin-bottom: 30px;
	background-size: 1390px 827px;
	background-image: url(../img/top/fv.png);
}

#top .fv .fv-top {
	height: 353px;
}

#top .fv .fv-bottom {
	height: 280px;
}

#top .fv .container {
	height: 827px;
}

#top .fv .container .fv-parts {
	position: absolute;
	width: 1390px;
	height: 827px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

#top .fv .container .fv-parts1 {
	position: absolute;
	top: 304px;
	left: 288px;
	animation: fv-fuwa 1s 3.5s infinite ease-in-out alternate;
}

#top .fv .container .fv-parts2 {
	position: absolute;
	top: 397px;
	left: 554px;
	animation: fv-fuwa 1s 3.5s infinite ease-in-out alternate;
}

#top .fv .container .fv-parts3 {
	position: absolute;
	top: 393px;
	left: 762px;
	animation: fv-fuwa 1s 4.5s infinite ease-in-out alternate;
}

#top .fv .container .fv-parts4 {
	position: absolute;
	top: 140px;
	left: 675px;
	animation: fv-fuwa 1.5s 3.5s infinite ease-in-out alternate;
}

#top .fv .container .fv-parts5 {
	position: absolute;
	top: 608px;
	left: 725px;
	animation: fv-fuwa 1s 3.6s infinite ease-in-out alternate;
}

#top .fv .container .fv-parts6 {
	position: absolute;
	top: 347px;
	left: 1170px;
	animation: fv-fuwa 1s 3.5s infinite ease-in-out alternate;
}

#top .fv .container .fv-parts7 {
	position: absolute;
	top: 291px;
	left: 1181px;
	animation: fv-fuwa-side 1s 3.5s infinite ease-in-out alternate;
}

@keyframes fv-fuwa {
	0% {
		transform: translateY(0px);
	}

	100% {
		transform: translateY(7px);
	}
}

@keyframes fv-fuwa-side {
	0% {
		transform: translateX(0px);
	}

	100% {
		transform: translateX(-7px);
	}
}

#top .fv .container .top-heading {
	top: 145px;
	left: 9%;
}

@media screen and (max-width: 1200px) {
	#top .fv .container .top-heading {
		left: 4%;
	}
}

#top .fv .container .top-heading h1 {
	margin-bottom: 21px;
}

#top .fv .container .contact {
	position: fixed;
	right: -46px;
	bottom: 120px;
	background-image: url(../img/common/contact-bg.svg);
	background-size: cover;
	text-align: center;
	width: 229px;
	height: 170px;
	filter: drop-shadow(5px 2px 5px #aaa);
	animation: fv-fadein 1.3s 2.1s 1 forwards ease-in-out;
	opacity: 0;
	transition: .5s;
}

#top .fv .container .contact:hover {
	bottom: 125px;
	right: -41px;
}

#top .fv .container .contact figure {
	position: absolute;
	top: 39px;
	left: 34px;
}

#top .fv .container .contact figure figcaption {
	font-size: 2rem;
	color: #fff;
	margin-bottom: 9px;
	letter-spacing: 0.1em;
}

#top .fv .logo {
	position: absolute;
	bottom: 28px;
	right: 65px;
	z-index: 1;
	overflow: hidden;
}


/* 〇〇事業所の方 リンク */
#top .office {
	margin-bottom: 30px;
}

#top .office .container ul {
	justify-content: center;
	gap: 0 80px;
	align-items: center;
}

@media screen and (max-width: 1200px) {
	#top .office .container ul {
		gap: 0 50px;
	}
}

@media screen and (max-width: 900px) {
	#top .office .container ul {
		flex-wrap: wrap;
		gap: 20px 0;
	}
}

@media screen and (max-width: 900px) {
	#top .office .container ul li {
		width: 40%;
		text-align: center;
	}
}

#top .office .container ul li a {
	font-size: 2.4rem;
}

@media screen and (max-width: 1300px) {
	#top .office .container ul li a {
		font-size: clamp(1.8rem, calc(1.3rem + 0.625vw), 2.4rem);
	}
}

#top .office .container ul li a::after {
	right: -15px;
	width: 9px;
	height: 9px;
}


/* あなたの会社のシステムは快適ですか？ */
#top .problem {
	padding: 70px 0 150px;
}

@media screen and (max-width: 1000px) {
	#top .problem {
		padding: 70px 0 60px;
	}
}

#top .problem .container h2 {
	margin-bottom: 80px;
}

@media screen and (max-width: 1000px) {
	#top .problem .container h2 {
		margin-bottom: 40px;
	}
}

#top .problem .container .voice {
	justify-content: space-between;
	gap: 90px 0;
}

#top .problem .container .voice .each-voice {
	width: 49%;
	padding: 30px;
}

@media screen and (max-width: 1000px) {
	#top .problem .container .voice .each-voice {
		width: 100%;
	}
}

#top .problem .container .voice .each-voice:nth-of-type(even) {
	top: 100px;
}

@media screen and (max-width: 1000px) {
	#top .problem .container .voice .each-voice:nth-of-type(even) {
		top: inherit;
	}
}

#top .problem .container .voice .each-voice .heading-img {
	margin-bottom: 20px;
}

#top .problem .container .voice .each-voice .heading-img h3 {
	font-size: 3rem;
}

@media screen and (max-width: 1450px) {
	#top .problem .container .voice .each-voice .heading-img h3 {
		font-size: 2.6rem;
	}
}

@media screen and (max-width: 1300px) {
	#top .problem .container .voice .each-voice .heading-img h3 {
		font-size: clamp(2.2rem, calc(1.5rem + 0.625vw), 2.6rem);
		letter-spacing: 0;
	}
}

@media screen and (max-width: 1100px) {
	#top .problem .container .voice .each-voice .heading-img h3 {
		font-size: 1.9rem;
	}
}

@media screen and (max-width: 1000px) {
	#top .problem .container .voice .each-voice .heading-img h3 {
		font-size: 3rem;
	}
}

#top .problem .container .voice .each-voice:nth-of-type(even) .heading-img h3 {
	margin-left: 150px;
}

#top .problem .container .voice .each-voice .heading-img .white-circle {
	width: 150px;
	height: 150px;
	top: -80px;
	right: -30px;
}

#top .problem .container .voice .each-voice:nth-of-type(even) .heading-img .white-circle {
	left: -30px;
}


/* ケアラボが選ばれる理由 */
#top .reason {
	padding: 90px 0 90px;
}

@media screen and (max-width: 1000px) {
	#top .reason {
		padding: 70px 0 90px;
	}
}

#top .reason h2 {
	margin-bottom: 50px;
}

@media screen and (max-width: 1000px) {
	#top .reason h2 {
		margin-bottom: 40px;
	}
}

#top .reason .inner {
	padding: 20px;
}

#top .reason .inner .all-reason .each-reason {
	width: calc(100% / 3);
	padding: 20px;
	border-right: dashed 2px #C9C9C9;
}

@media screen and (max-width: 1000px) {
	#top .reason .inner .all-reason .each-reason {
		width: 50%;
	}
}

#top .reason .inner .all-reason .each-reason:nth-of-type(3n) {
	border-right: none;
}

@media screen and (max-width: 1000px) {
	#top .reason .inner .all-reason .each-reason:nth-of-type(3n) {
		border-right: dashed 2px #C9C9C9;
	}
}

@media screen and (max-width: 1000px) {
	#top .reason .inner .all-reason .each-reason:nth-of-type(even) {
		border-right: none;
	}
}

#top .reason .inner .all-reason .each-reason:nth-of-type(1) {
	position: relative;
}

#top .reason .inner .all-reason .each-reason:nth-of-type(1)::after {
	position: absolute;
	content: "";
	width: 42px;
	height: 42px;
	background-color: #fff;
	bottom: -22px;
	right: -22px;
	z-index: 1;
}

#top .reason .inner .all-reason .each-reason:nth-of-type(2) {
	position: relative;
}

#top .reason .inner .all-reason .each-reason:nth-of-type(2)::after {
	position: absolute;
	content: "";
	width: 42px;
	height: 42px;
	background-color: #fff;
	bottom: -22px;
	right: -22px;
	z-index: 1;
	border: 1px solid #fff;
}

@media screen and (max-width: 1000px) {
	#top .reason .inner .all-reason .each-reason:nth-of-type(2)::after {
		display: none;
	}
}

@media screen and (max-width: 1000px) {
	#top .reason .inner .all-reason .each-reason:nth-of-type(3) {
		position: relative;
	}

	#top .reason .inner .all-reason .each-reason:nth-of-type(3)::after {
		position: absolute;
		content: "";
		width: 42px;
		height: 42px;
		background-color: #fff;
		bottom: -22px;
		right: -22px;
		z-index: 1;
		border: 1px solid #fff;
	}
}

#top .reason .inner .all-reason .each-reason:nth-of-type(4) {
	border-bottom: none;
}

@media screen and (max-width: 1000px) {
	#top .reason .inner .all-reason .each-reason:nth-of-type(4) {
		border-bottom: dashed 2px #C9C9C9;
	}
}

#top .reason .inner .all-reason .each-reason:nth-of-type(5) {
	border-bottom: none;
}

#top .reason .inner .all-reason .each-reason:nth-of-type(6) {
	border-bottom: none;
}

#top .reason .inner .all-reason .each-reason .number {
	width: 94px;
	height: 94px;
	font-size: 5rem;
	margin-bottom: 13px;
}

#top .reason .inner .all-reason .each-reason h3 {
	font-size: 3rem;
	margin-bottom: 30px;
}

@media screen and (max-width: 1400px) {
	#top .reason .inner .all-reason .each-reason h3 {
		font-size: clamp(2rem, 2vw, 2.8rem);
	}
}

#top .reason .inner .all-reason .each-reason img {
	margin-bottom: 20px;
	height: 197px;
}

/* 事業所別おすすめ機能 */
#top .by-office {
	padding: 110px 0 90px;
}

@media screen and (max-width: 1000px) {
	#top .by-office {
		padding: 70px 0 90px;
	}
}

#top .by-office .inner h2 {
	margin-bottom: 40px;
}

#top .by-office .inner .types {
	flex-wrap: wrap;
	margin-bottom: 60px;
}

#top .by-office .inner .types .each-type {
	width: 50%;
	padding: 40px;
}

@media screen and (max-width: 1000px) {
	#top .by-office .inner .types .each-type {
		padding: 20px;
	}
}

#top .by-office .inner .types .each-type .text {
	height: 100px;
}

#top .by-office .inner .types .each-type:nth-of-type(1) {
	border-bottom: 1px solid#C4C4C4;
	border-right: 1px solid#C4C4C4;
}

#top .by-office .inner .types .each-type:nth-of-type(2) {
	border-bottom: 1px solid#C4C4C4;
}

#top .by-office .inner .types .each-type:nth-of-type(3) {
	border-right: 1px solid#C4C4C4;
}

/* ご担当別おすすめ機能 */
#top .manager {
	padding: 60px 0 90px;
}

#top .manager .inner .manager-heading p {
	font-size: 2.6rem;
}

#top .manager .inner .manager-heading h2 {
	margin-bottom: 40px;
}

#top .manager .inner .manager-wrap .each-manager {
	padding: 40px;
	margin-bottom: 62px;
	justify-content: space-between;
	align-items: center;
}

@media screen and (max-width: 1000px) {
	#top .manager .inner .manager-wrap .each-manager {
		padding: 30px;
	}
}

#top .manager .inner .manager-wrap .each-manager:last-of-type {
	margin-bottom: 60px;
}

#top .manager .inner .manager-wrap .each-manager .icon-manager {
	width: 25%;
}

@media screen and (max-width: 1000px) {
	#top .manager .inner .manager-wrap .each-manager .icon-manager {
		width: 27%;
	}
}

#top .manager .inner .manager-wrap .each-manager .icon-manager img {
	margin-bottom: 40px;
}

#top .manager .inner .manager-wrap .each-manager .icon-manager h3 {
	font-size: 2.6rem;
	margin-bottom: 27px;
}

@media screen and (max-width: 1300px) {
	#top .manager .inner .manager-wrap .each-manager .icon-manager h3 {
		font-size: clamp(1.9rem, 1.9vw, 2.4rem);
	}
}

@media screen and (max-width: 1000px) {
	#top .manager .inner .manager-wrap .each-manager .icon-manager h3 {
		font-size: clamp(1.7rem, 2.1vw, 1.9rem);
	}
}

#top .manager .inner .manager-wrap .each-manager .icon-manager a {
	font-size: 2.2rem;
	padding-bottom: 3px;
}

@media screen and (max-width: 1000px) {
	#top .manager .inner .manager-wrap .each-manager .icon-manager a {
		font-size: 2rem;
	}
}

#top .manager .inner .manager-wrap .each-manager .icon-manager a::before {
	background-color: #fff;
	right: -13px;
}

#top .manager .inner .manager-wrap .each-manager .icon-manager a::after {
	right: -40px;
}

@media screen and (max-width: 1000px) {
	#top .manager .inner .manager-wrap .each-manager .icon-manager a::after {
		width: 25px;
		right: -35px;
	}
}

#top .manager .inner .manager-wrap .each-manager .tag-comment {
	width: 70%;
}

@media screen and (max-width: 768px) {
	#top .manager .inner .manager-wrap .each-manager .tag-comment {
		width: 68%;
	}
}

#top .manager .inner .manager-wrap .each-manager .tag-comment .tag-wrap {
	gap: 10px 42px;
	margin-bottom: 20px;
}

@media screen and (max-width: 1400px) {
	#top .manager .inner .manager-wrap .each-manager .tag-comment .tag-wrap {
		gap: 10px 28px;
	}
}

@media screen and (max-width: 1300px) {
	#top .manager .inner .manager-wrap .each-manager .tag-comment .tag-wrap {
		gap: 10px 17px;
	}
}

#top .manager .inner .manager-wrap .each-manager .tag-comment .tag-wrap a {
	font-size: 2.2rem;
}

@media screen and (max-width: 1400px) {
	#top .manager .inner .manager-wrap .each-manager .tag-comment .tag-wrap a {
		font-size: clamp(1.6rem, 1.6vw, 2rem);
	}
}

/* カテゴリから探す */
#top .category {
	padding: 90px 0 90px;
}

@media screen and (max-width: 1000px) {
	#top .category {
		padding: 73px 0 66px;
	}
}

#top .category .container h2 {
	margin-bottom: 50px;
}

#top .category .container .category-wrap {
	gap: 27px 0;
	margin-bottom: 60px;
}

@media screen and (max-width: 1000px) {
	#top .category .container .category-wrap {
		gap: 20px 0;
	}
}

#top .category .container .category-wrap a {
	width: 23%;
	aspect-ratio: 292 / 273;
}

#top .category .container .category-wrap a:first-of-type figure img {
	top: 23%;
	width: 37%;
}

#top .category .container .category-wrap a:nth-of-type(2) figure img {
	top: 20%;
	width: 31%;
}

#top .category .container .category-wrap a:nth-of-type(3) figure img {
	top: 26%;
	width: 47%;
}

#top .category .container .category-wrap a:nth-of-type(4) figure img {
	top: 18%;
	width: 33%;
}

#top .category .container .category-wrap a:nth-of-type(5) figure img {
	top: 26%;
	width: 40%;
}

#top .category .container .category-wrap a:nth-of-type(6) figure img {
	top: 20%;
	width: 45%;
}

#top .category .container .category-wrap a:nth-of-type(7) figure img {
	top: 19%;
	width: 28%;
}

#top .category .container .category-wrap a:nth-of-type(8) figure img {
	top: 30%;
	width: 33%;
}

#top .category .container .category-wrap a figure figcaption {
	font-size: 2.6rem;
	top: 72%;
}

@media screen and (max-width: 1400px) {
	#top .category .container .category-wrap a figure figcaption {
		font-size: clamp(1.7rem, 1.7vw, 2.3rem);
	}
}

@media screen and (max-width: 900px) {
	#top .category .container .category-wrap a figure figcaption {
		font-size: 1.5rem;
	}
}

/* 1分でわかるケアラボ */
#top .video {
	padding: 90px 0 60px;
}

@media screen and (max-width: 1000px) {
	#top .video {
		padding: 70px 0 60px;
	}
}

#top .video h2 {
	margin-bottom: 40px;
}

#top .video .video-inner {
	max-width: 918px;
}

#top .video .video-inner .links {
	justify-content: space-between;
	margin-bottom: 53px;
}

#top .video .video-inner .links a {
	width: 48%;
	height: 56px;
	font-size: 2.6rem;
}

@media screen and (max-width: 900px) {
	#top .video .video-inner .links a {
		font-size: clamp(2.1rem, 2.8vw, 2.6rem);
	}
}

#top .video .video-inner .logo {
	text-align: center;
}

/* ケアラボで実現したアップデートされた日常業務をご紹介！ */
#top .improvement {
	padding: 90px 0 90px;
}

@media screen and (max-width: 1000px) {
	#top .improvement {
		padding: 70px 0 80px;
	}
}

#top .improvement .inner h2 {
	margin-bottom: 50px;
}

#top .improvement .inner .improvement-wrap {
	justify-content: space-between;
}

@media screen and (max-width: 1000px) {
	#top .improvement .inner .improvement-wrap {
		gap: 40px 0;
	}
}

#top .improvement .inner .improvement-wrap .each-improvement {
	width: 32%;
	padding: 40px;
}

@media screen and (max-width: 1400px) {
	#top .improvement .inner .improvement-wrap .each-improvement {
		padding: 30px;
	}
}

@media screen and (max-width: 1000px) {
	#top .improvement .inner .improvement-wrap .each-improvement {
		width: 48%;
	}
}

#top .improvement .inner .improvement-wrap .each-improvement h3 {
	font-size: 2.8rem;
}

@media screen and (max-width: 1400px) {
	#top .improvement .inner .improvement-wrap .each-improvement h3 {
		font-size: clamp(1.8rem, 1.8vw, 2.8rem);
	}
}

@media screen and (max-width: 1000px) {
	#top .improvement .inner .improvement-wrap .each-improvement h3 {
		font-size: clamp(2.5rem, 2.9vw, 3rem);
	}
}

#top .improvement .inner .improvement-wrap .each-improvement .text {
	margin-bottom: 10px;
}

/* お知らせ */
#top .information {
	padding: 80px 0 110px;
}

@media screen and (max-width: 1000px) {
	#top .information {
		padding: 70px 0 100px;
	}
}

@media screen and (max-width: 1200px) {
	#top .information .inner {
		position: relative;
	}
}

#top .information .inner .heading-info {
	align-items: center;
	justify-content: space-between;
}

@media screen and (max-width: 1200px) {
	#top .information .inner .heading-info {
		flex-direction: column;
	}
}

@media screen and (max-width: 1200px) {
	#top .information .inner .heading-info h2 {
		margin-bottom: 20px;
	}
}

#top .information .inner .to-all-info a {
	font-size: 2.4rem;
	margin-right: 40px;
	margin-bottom: 13px;
}

@media screen and (max-width: 1200px) {
	#top .information .inner .to-all-info a {
		position: absolute;
		top: 25px;
		right: 49px;
	}
}

@media screen and (max-width: 900px) {
	#top .information .inner .to-all-info a {
		top: 20px;
	}
}

#top .information .inner .to-all-info a::after {
	right: -30px;
}

#top .information .inner .heading-info .info-wrap {
	width: 71%;
}

@media screen and (max-width: 1200px) {
	#top .information .inner .heading-info .info-wrap {
		width: 100%;
	}
}

#top .information .inner .heading-info .info-wrap a {
	margin-bottom: 21px;
	padding: 14px 50px 14px 30px;
}

@media screen and (max-width: 1000px) {
	#top .information .inner .heading-info .info-wrap a {
		padding: 14px 30px 14px 15px;
	}
}

#top .information .inner .heading-info .info-wrap a .date {
	margin-right: 12px;
}

@media screen and (max-width: 1000px) {
	#top .information .inner .heading-info .info-wrap a .date {
		margin-right: 10px;
	}
}

#top .information .inner .heading-info .info-wrap a .info-tag {
	margin-right: 12px;
	width: 135px;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 32px;
}


/*------------------------------ コラム 投稿 共通 ------------------------------*/
.column .inner .column-wrap {
	justify-content: space-between;
	margin-bottom: 60px;
}

.column .inner .column-wrap .each-column {
	width: 31%;
}

.column .inner .column-wrap .each-column a .img-date {
	margin-bottom: 20px;
}

.column .inner .column-wrap .each-column a .img-date img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 370 / 290;
}

.column .inner .column-wrap .each-column a .img-date .date {
	padding: 7px 16px;
}

.column .inner .column-wrap .each-column a h3 {
	font-size: 2.6rem;
}

@media screen and (max-width: 1300px) {
	.column .inner .column-wrap .each-column a h3 {
		font-size: clamp(1.9rem, 1.9vw, 2.5rem);
	}
}

.column .inner .column-wrap .each-column .column-tags {
	gap: 5px 15px;
}


/* コラム */
#top .column {
	padding: 70px 0 90px;
}

@media screen and (max-width: 1000px) {
	#top .column {
		padding: 70px 0 70px;
	}
}

#top .column .inner h2 {
	margin-bottom: 40px;
}


/*------------------------------ 機能カテゴリー 詳細 ------------------------------*/



/*------------------------------ 事業所別おすすめ機能 詳細 ------------------------------*/



/*------------------------------ ご担当別おすすめ機能 詳細------------------------------*/



/*------------------------------ 機能カテゴリー 一覧 ------------------------------*/
#function .c-beside-fv .ttl-img .eye-catch {
	padding-bottom: 40px;
}

#function .search-list .container {
	gap: 0 40px;
	width: 95%;
}

#function .search-list .container .search-bar {
	width: 230px;
}

#function .search-list .container .list {
	justify-content: flex-start;
	gap: 30px 2%;
	width: calc(100% - 270px);
	padding-top: 60px;
}

@media screen and (max-width: 1300px) {
	#function .search-list .container .list {
		gap: 30px 4%;
	}
}

#function .search-list .container .list article {
	width: 32%;
	padding: 30px 20px 20px;
	max-height: 600px;
}

@media screen and (max-width: 1300px) {
	#function .search-list .container .list article {
		width: 48%;
	}
}

@media screen and (max-width: 1000px) {
	#function .search-list .container .list article {
		padding: 30px 15px 20px;
	}
}

#function .search-list .container .list article .img {
	margin-bottom: 30px;
	margin-bottom: 30px;
	height: 112px;
	display: flex;
	align-items: flex-end;
	justify-content: center;
}

#function .search-list .container .list article h2 {
	font-size: 2rem;
	margin-bottom: 15px;
}

@media screen and (max-width: 1000px) {
	#function .search-list .container .list article h2 {
		font-size: clamp(1.7rem, 2.2vw, 2rem);
	}
}

#function .search-list .container .list article .text {
	padding-bottom: 20px;
	margin-bottom: 20px;
}

#function .search-list .container .list article ul {
	gap: 10px 20px;
}

#function .search-list .container .list article ul li {
	font-size: 1.6rem;
}

/*------------------------------ お知らせ 一覧と詳細 共通 ------------------------------*/
.info .inner .tax-btn {
	justify-content: center;
	gap: 0 30px;
}

.info .inner .tax-btn a {
	width: 348px;
}


/*------------------------------ お知らせ一覧 ------------------------------*/
#information .info {
	padding: 58px 0 93px;
}

@media screen and (max-width: 1000px) {
	#information .info {
		padding: 118px 0 93px;
	}
}

#information .info .inner .info-wrap a {
	margin-bottom: 21px;
	padding: 14px 30px;
}

@media screen and (max-width: 1000px) {
	#information .info .inner .info-wrap a {
		padding: 14px 15px;
	}
}

#information .info .inner .info-wrap a .date {
	margin-right: 12px;
}

@media screen and (max-width: 1000px) {
	#information .info .inner .info-wrap a .date {
		margin-right: 10px;
	}
}

#information .info .inner .info-wrap a .info-tag {
	margin-right: 12px;
	width: 135px;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 32px;
}


/*------------------------------ お知らせ詳細 ------------------------------*/
#single-information .info {
	padding: 58px 0 93px;
}

#single-information .info article {
	padding: 30px;
}

#single-information .info article .date-tag {
	margin-bottom: 20px;
}

#single-information .info article h2 {
	font-size: 3.6rem;
	margin-bottom: 25px;
}

@media screen and (max-width: 1000px) {
	#single-information .info {
		padding: 118px 0 93px;
	}
}

/*------------------------------ ページネーション ------------------------------*/
.pagination {
	gap: 28px;
}

.pagination .current {
	width: 40px;
	height: 40px;
}

.pagination a.page-numbers {
	width: 40px;
	height: 40px;
}

.pagination a.prev::after {
	width: 12px;
	height: 12px;
	left: 20px;
}

.pagination a.next::after {
	width: 12px;
	height: 12px;
	right: 15px;
	right: 20px;
}


/*------------------------------ お知らせ一覧 ------------------------------*/



/*------------------------------ コラム 詳細 ------------------------------*/
#single-column .column {
	padding: 60px 0 70px;
}

#single-column .column .inner {
	padding: 40px 20px 70px;
	margin-bottom: 80px;
	max-width: 900px;
}

#single-column .column .inner .date-tag {
	gap: 0 40px;
	margin-bottom: 30px;
	align-items: center;
}

#single-column .column .inner .date-tag .column-tags {
	gap: 0 20px;
}

#single-column .column .inner .post-title {
	font-size: 3.6rem;
	margin-bottom: 20px;
}

#single-column .column .inner .main-img-text {
	margin-bottom: 40px;
}

#single-column .column .inner .main-img-text img {
	margin-bottom: 30px;
}

#single-column .column .inner .table-of-contents {
	max-width: 700px;
	padding: 30px;
}

#single-column .column .inner .table-of-contents h2 {
	font-size: 2.8rem;
	margin-bottom: 20px;
}

#single-column .column .inner .table-of-contents ul li {
	margin-bottom: 5px;
}

#single-column .column .inner .table-of-contents ul li a {
	font-size: 2rem;
}

#single-column .column .inner .table-of-contents ul li a .number {
	width: 25px;
}

#single-column .column .inner article {
	padding-top: 70px;
}

@media screen and (max-width: 1000px) {
	#single-column .column .inner article {
		padding-top: 90px;
	}
}

#single-column .column .inner article:last-of-type {
	margin-bottom: 80px;
}

#single-column .column .inner article h2 {
	font-size: 2.8rem;
	margin-bottom: 20px;
}

#single-column .column .inner article .main-text {
	margin-bottom: 40px;
}

#single-column .column .inner article .img {
	max-width: 700px;
	margin-bottom: 40px;
}

#single-column .column .inner article h3 {
	margin-bottom: 10px;
}

#single-column .column .inner article h3 span {
	padding: 5px 10px;
}

#single-column .column .inner .check {
	max-width: 700px;
	padding: 20px 30px 50px;
}

#single-column .column .inner .check h2 {
	font-size: 2.8rem;
	margin-bottom: 20px;
}

#single-column .column .inner .check p:first-of-type {
	margin-bottom: 30px;
}

#single-column .column .inner .check p:last-of-type {
	margin-bottom: 40px;
}

#single-column .column .inner .check .logo {
	margin-bottom: 25px;
}

#single-column .column .inner .check .square-arrow-link {
	width: 284px;
	height: 60px;
}

#single-column .column .inner .check .square-arrow-link::before {
	right: 52px;
}

#single-column .column .inner .check .square-arrow-link::after {
	right: 25px;
}

#single-column .column .to-all-column {
	width: 200px;
	height: 50px;
	font-size: 2.4rem;
}


/*------------------------------ お問い合わせ 共通 ------------------------------*/
.contact-step {
	justify-content: space-between;
	margin-bottom: 100px;
}

.contact-step li {
	width: 28%;
}

.contact-step li::after {
	border-top: 25px solid transparent;
	border-bottom: 25px solid transparent;
	border-left: 36px solid #fff;
	border-right: 0;
	top: 0;
	right: -36px;
}

.contact-step li.current-step::after {
	border-left: 36px solid #39C1D8;
}


/*------------------------------ お問い合わせ ------------------------------*/
#contact .content {
	padding: 60px 0 110px;
}

#contact .content .inner .caution {
	margin-bottom: 50px;
}

#contact .content .inner .wpcf7 form .wpcf7-response-output {
	margin-bottom: 60px;
}

#contact .content .inner .contact-form .items {
	padding: 30px;
	margin-bottom: 80px;
}

#contact .content .inner .contact-form .items dl {
	font-size: 2rem;
	margin-bottom: 30px;
	justify-content: space-between;
}

#contact .content .inner .contact-form .items dl:last-of-type {
	align-items: flex-start;
}

#contact .content .inner .contact-form .items dl dt {
	width: 300px;
}

#contact .content .inner .contact-form .items dl dd {
	width: calc(100% - 300px);
}

#contact .content .inner .contact-form .items dl dd .wpcf7-radio {
	gap: 20px 30px;
}

#contact .content .inner .contact-form .items .radio-dl {
	align-items: flex-start;
}

#contact .content .inner .contact-form .accept {
	margin-bottom: 30px;
}


/*------------------------------ お問い合わせ 確認 ------------------------------*/
#contact-confirm .content {
	padding: 60px 0 110px;
}

#contact-confirm .content .inner .contact-form .items {
	padding: 30px;
	margin-bottom: 80px;
}

#contact-confirm .content .inner .contact-form .items dl {
	font-size: 2rem;
	margin-bottom: 30px;
	justify-content: space-between;
	align-items: center;
}

#contact-confirm .content .inner .contact-form .items dl dt {
	width: 300px;
}

#contact-confirm .content .inner .contact-form .items dl dd {
	width: calc(100% - 250px);
}

#contact-confirm .content .inner .contact-form .edit {
	justify-content: space-between;
}

#contact-confirm .content .inner .contact-form .edit .form-prev {
	width: 48%;
}

#contact-confirm .content .inner .contact-form .edit .form-next {
	width: 48%;
}

#contact-confirm .content .inner .contact-form .edit .form-next p:first-of-type {
	width: 100%;
}


/*------------------------------ サポート体制 ------------------------------*/
@media screen and (max-width: 850px) {
	.support-br {
		display: block;
	}
}

#support .c-beside-fv .ttl-img .eye-catch {
	text-align: right;
}

#support .c-beside-fv .ttl-img .eye-catch img {
	width: 80%;
}

#support .system {
	padding: 100px 0 80px;
}

#support .system .inner h2 {
	font-size: 5rem;
	margin-bottom: 70px;
}

#support .system .inner .line {
	justify-content: space-between;
	max-width: 1014px;
	margin-inline: auto;
	margin-bottom: 100px;
}

#support .system .inner .line .number-heading {
	flex-direction: column;
	gap: 20px 0;
}

#support .system .inner .line .number-heading .heading {
	font-size: 3rem;
}

@media screen and (max-width: 1100px) {
	#support .system .inner .line .number-heading .heading {
		font-size: clamp(2.2rem, calc(2.9vw), 3rem);
	}
}

#support .system .inner .line .number-heading .number {
	width: 70px;
	height: 70px;
	font-size: 3.7rem;
}

#support .system .inner .each-support {
	margin-bottom: 60px;
	padding: 50px 30px 30px;
}

#support .system .inner .each-support .ellipse {
	top: -48px;
	right: -33px;
	width: 186px;
	height: 186px;
}

#support .system .inner .each-support .ellipse::before {
	font-size: 6.1rem;
	top: 69px;
	left: 66px;
}

#support .system .inner .each-support .img-intro {
	gap: 0 34px;
	align-items: center;
	margin-bottom: 30px;
}

@media screen and (max-width: 1000px) {
	#support .system .inner .each-support .img-intro {
		gap: 0 25px;
	}
}

#support .system .inner .each-support .img-intro .img {
	width: 30%;
}

#support .system .inner .each-support .img-intro .intro {
	width: 70%;
}

#support .system .inner .each-support .img-intro .intro h3 {
	font-size: 3.6rem;
}

@media screen and (max-width: 900px) {
	#support .system .inner .each-support .img-intro .intro h3 {
		font-size: 3rem;
	}
}

#support .system .inner .each-support .img-intro .intro .en-sub {
	margin-bottom: 30px;
}

#support .system .inner .each-support .img-intro .intro h4 {
	font-size: 2.4rem;
}

#support .security {
	padding: 73px 0 30px;
}

#support .security .inner .logo-intro {
	justify-content: space-between;
	align-items: center;
	margin-bottom: 48px;
}

#support .security .inner .logo-intro .logo {
	width: 30%;
}

#support .security .inner .logo-intro .intro {
	width: 60%;
}

#support .security .inner .logo-intro .intro h2 {
	font-size: 5rem;
	margin-bottom: 31px;
}

@media screen and (max-width: 1400px) {
	#support .security .inner .logo-intro .intro h2 {
		font-size: clamp(3.5rem, calc(3.5vw), 4.8rem);
	}
}

#support .security .inner .security-wrap {
	justify-content: space-between;
}

#support .security .inner .security-wrap .each-security {
	width: 31%;
}

#support .security .inner .security-wrap .each-security .img {
	margin-bottom: 10px;
}

#support .security .inner .security-wrap .each-security h3 {
	height: 80px;
	font-size: 2.4rem;
	margin-bottom: 10px;
}

@media screen and (max-width: 1000px) {
	#support .security .inner .security-wrap .each-security h3 {
		font-size: clamp(2rem, calc(2.5vw), 2.4rem);
	}
}

#support .security .thin-green {
	position: absolute;
	width: 100%;
	background-color: #EBF2F4;
	bottom: 0;
	left: 0;
	height: 457px;
}


/*------------------------------ FAQ ------------------------------*/
#faq .about {
	padding-bottom: 100px;
}

#faq .about article {
	margin-bottom: 60px;
}

@media screen and (max-width: 1000px) {
	#faq .about article {
		margin-bottom: 0;
		padding-top: 60px;
	}
}

#faq .about article .inner {
	padding: 50px;
}

@media screen and (max-width: 1000px) {
	#faq .about article .inner {
		padding: 70px 50px 50px;
	}
}

#faq .about article:last-of-type {
	margin-bottom: 100px;
}

#faq .about article .img {
	margin-bottom: 20px;
}

#faq .about article h2 {
	font-size: 5rem;
	margin-bottom: 60px;
}

#faq .about article .accordion label {
	gap: 0 30px;
}

#faq .about article .accordion label .ques {
	font-size: 3rem;
	width: 60px;
	height: 60px;
}

#faq .about article .accordion label span {
	padding-right: 30px;
	width: calc(100% - 90px);
}

#faq .about article .accordion .content {
	padding: 0 20px 0 90px;
	gap: 0 5px;
}

#faq .about article .accordion .content .answer {
	padding-top: 10px;
}

#faq .words .inner {
	max-width: 1000px;
}

#faq .words .inner h2 {
	padding-left: 55px;
	font-size: 3.6rem;
	margin-bottom: 25px;
}

#faq .words .inner h2::before {
	width: 40px;
	height: 2px;
}

#faq .words .inner .accordion label {
	height: 60px;
	padding: 0 30px 0 60px;
}

#faq .words .inner .accordion label::after {
	left: 23px;
	width: 11px;
	height: 11px;
}

#faq .words .inner .accordion .content {
	padding: 0 20px 0 60px;
}

#faq .about .words .toggle:checked+.Label+.content {
	padding: 20px 20px 20px 60px;
}


/* アコーディオンメニュー */
#faq .about .Label {
	align-items: center;
}

#faq .about .Label::before {
	right: 20px;
}

#faq .about .toggle:checked+.Label+.content {
	padding: 20px 20px 20px 90px;
}


/*------------------------------ 料金について------------------------------*/
#price .unity {
	padding: 100px 0;
}

#price .unity .inner .merit-list {
	margin-bottom: 90px;
}

#price .unity .inner .merit-list li {
	border: 20px solid #F2AC4E;
	width: 50%;
	padding: 30px;
	font-size: 2.8rem;
}

@media screen and (max-width: 1000px) {
	#price .unity .inner .merit-list li {
		border: 10px solid #F2AC4E;
	}
}

@media screen and (max-width: 1200px) {
	#price .unity .inner .merit-list li {
		padding: 20px;
		font-size: 2.3rem;
	}
}

@media screen and (max-width: 1000px) {
	#price .unity .inner .merit-list li {
		font-size: 1.9rem;
	}
}

#price .unity .inner .merit-list li span {
	font-size: 3.6rem;
}

@media screen and (max-width: 1200px) {
	#price .unity .inner .merit-list li span {
		font-size: 3rem;
	}
}

@media screen and (max-width: 1000px) {
	#price .unity .inner .merit-list li span {
		font-size: 2.4rem;
	}
}

#price .unity .inner .merit-list li:first-of-type {
	border-right: none;
	border-bottom: none;
}

#price .unity .inner .merit-list li:nth-of-type(2) {
	border-bottom: none;
}

#price .unity .inner .merit-list li:nth-of-type(3) {
	border-right: none;
}

#price .unity .inner .anchor-link {
	justify-content: space-between;
}

@media screen and (max-width: 1000px) {
	#price .unity .inner .anchor-link {
		gap: 28px 0;
	}
}

#price .unity .inner .anchor-link a {
	width: 23%;
	font-size: 2.4rem;
}

@media screen and (max-width: 1300px) {
	#price .unity .inner .anchor-link a {
		font-size: clamp(1.6rem, 1.5vw, 2.4rem);
	}
}

@media screen and (max-width: 1000px) {
	#price .unity .inner .anchor-link a {
		width: 48%;
	}
}

#price .unity .inner .composition {
	padding-top: 100px;
}

#price .unity .inner .composition h2 {
	font-size: 5rem;
	margin-bottom: 60px;
}

#price .unity .inner .composition .intro-month {
	flex-direction: column;
	gap: 60px 0;
}

#price .unity .inner .composition .intro-month .each-compo {
	width: 100%;
}

#price .unity .inner .composition .intro-month .each-compo .heading {
	justify-content: center;
}

#price .unity .inner .composition .intro-month .each-compo .heading h3 {
	font-size: 3.6rem;
}

@media screen and (max-width: 1100px) {
	#price .unity .inner .composition .intro-month .each-compo .heading h3 {
		font-size: 3rem;
		white-space: nowrap;
	}
}

#price .unity .inner .composition .intro-month .each-compo .heading p {
	margin-top: 15px;
	line-height: 1;
}

#price .unity .inner .composition .intro-month .each-compo .ul-text {
	padding: 30px;
}

#price .unity .inner .composition .intro-month .each-compo .ul-text ul {
	border-right: 1px solid #D0D0D0;
}

#price .unity .inner .composition .intro-month .intro .heading {
	gap: 0 20px;
}

#price .unity .inner .composition .intro-month .intro::before {
	bottom: -32px;
	left: 50%;
	transform: translateX(-50%);
}

#price .unity .inner .composition .intro-month .intro::after {
	bottom: -42px;
	left: 50%;
	transform: translateX(-50%);
}

#price .unity .inner .composition .intro-month .intro .ul-text {
	display: flex;
	align-items: center;
}

#price .unity .inner .composition .intro-month .intro .ul-text ul {
	width: 240px;
}

#price .unity .inner .composition .intro-month .intro .ul-text p {
	width: calc(100% - 240px);
	padding: 30px;
}

#price .unity .inner .discount {
	padding-top: 90px;
}

#price .unity .inner .discount .table {
	margin-bottom: 30px;
}

#price .unity .inner .discount .table h2 {
	font-size: 3.6rem;
}

#price .unity .inner .discount .table .discount-wrap {
	justify-content: space-between;
}

#price .unity .inner .discount .table .discount-wrap .each-discount {
	width: calc(100% / 3);
	padding: 30px 15px;
}

#price .unity .inner .discount .table .discount-wrap .each-discount h3 {
	font-size: 2.4rem;
	margin-bottom: 10px;
}

@media screen and (max-width: 1300px) {
	#price .unity .inner .discount .table .discount-wrap .each-discount h3 {
		font-size: clamp(1.8rem, calc(1.8vw), 2.4rem);
		letter-spacing: 0.05em;
	}
}

#price .unity .inner .text.note {
	margin-bottom: 30px;
}

#price .unity .inner .square-arrow-link {
	font-size: 2.1rem;
	width: 285px;
}

#price .unity .inner .square-arrow-link::before {
	right: 47px;
}

#price .unity .inner .square-arrow-link::after {
	right: 20px;
}

#price .comparison {
	padding: 80px 0 100px;
}

#price .comparison .inner h2 {
	font-size: 5rem;
	margin-bottom: 50px;
}

#price .comparison .inner table {
	border-collapse: separate;
	border-spacing: 5px 0;
	text-align: center;
}

#price .comparison .inner table .thead th {
	border-radius: 10px 10px 0 0;
	height: 90px;
	font-size: 2.8rem;
	font-weight: 400;
	vertical-align: middle;
	background-color: #fff;
}

#price .comparison .inner table .thead th:first-of-type {
	border-radius: 0;
	background-color: transparent;
}

#price .comparison .inner table tr td {
	box-shadow: 7px 7px 5px rgb(0 0 0 / 4%);
	height: 130px;
	vertical-align: bottom;
	width: 24%;
}

#price .comparison .inner table tr td p {
	padding: 20px 0;
}

#price .comparison .inner table tr td.nothing {
	position: relative;
}

#price .comparison .inner table tr td.nothing::before {
	position: absolute;
	content: "";
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background-color: #D0D0D0;
	height: 4px;
	width: 38px;
}

#price .comparison .inner table tr .middle-circle {
	vertical-align: middle;
}

#price .comparison .inner table tr td .circle {
	width: 38px;
	height: 38px;
}

#price .comparison .inner table tr td .circle-orange::before {
	width: 20px;
	height: 20px;
}


#price .comparison .inner table tr .ai-td p {
	padding-bottom: 14px;
	padding-top: 10px;
}

@media screen and (max-width: 850px) {
	#price .comparison .inner table tr .ai-td p {
		line-height: 1.2;
		padding: 8px 5px 15px;
	}
}

#price .comparison .inner table tr td .circle {
	border-radius: 9999px;
	border: 4px solid #fff;
	margin-inline: auto;
}

#price .comparison .inner table tr td .circle-black {
	border: 4px solid #5B5B5B;
}

#price .comparison .inner table tr td .circle-orange {
	border: 4px solid #F2AC4E;
	position: relative;
}

#price .comparison .inner table tr td .circle-orange::before {
	position: absolute;
	content: "";
	border-radius: 9999px;
	border: 4px solid #F2AC4E;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

#price .comparison .inner table tr .ttl-td {
	width: 100%;
	letter-spacing: 0.005em;
	text-align: left;
	color: #37B0CC;
	display: flex;
	align-items: center;
	background-color: #fff;
	font-size: 2.6rem;
	padding: 0 20px;
}

#price .comparison .inner table tr:nth-of-type(even) .ttl-td {
	background-color: #DDEAED;
}

#price .comparison .inner table tr:nth-of-type(odd) td {
	background-color: #fff;
}

#price .comparison .inner table tr:nth-of-type(even) td {
	background-color: #EDF7F9;
}

#price .comparison .inner table tr .our {
	color: #fff;
}

#price .comparison .inner table tr:nth-of-type(odd) .our {
	background-color: #37B0CC;
}

#price .comparison .inner table tr:nth-of-type(even) .our {
	background-color: #54BBD3;
}

#price .flow {
	padding: 100px 0 120px;
}

#price .flow .inner h2 {
	font-size: 5rem;
	margin-bottom: 85px;
}

#price .flow .inner .flow-wrap {
	gap: 60px 0;
}

#price .flow .inner .flow-wrap .each-flow {
	gap: 0 30px;
}

#price .flow .inner .flow-wrap .each-flow .illust {
	width: 180px;
	height: 180px;
	position: relative;
}

#price .flow .inner .flow-wrap .each-flow .illust::after {
	position: absolute;
	content: "";
	bottom: -60px;
	left: 50%;
	transform: translateX(-50%);
	width: 7px;
	height: 60px;
	background-color: #DDEAED;
}

#price .flow .inner .flow-wrap .each-flow:last-of-type .illust::after {
	display: none;
}

#price .flow .inner .flow-wrap .each-flow .heading-text {
	width: calc(100% - 210px);
}

#price .flow .inner .flow-wrap .each-flow .heading-text h3 {
	font-size: 2.8rem;
	padding-bottom: 5px;
	margin-bottom: 20px;
}


/*------------------------------ 経営理念 ------------------------------*/
#philosophy .continuation {
	padding: 60px 0;
}

#philosophy .continuation .inner {
	gap: 0 30px;
}

#philosophy .continuation .inner .img {
	width: 50%;
}

#philosophy .continuation .inner .heading-text {
	width: 50%;
}

#philosophy .continuation .inner .heading-text h2 {
	font-size: 3.6rem;
	margin-bottom: 50px;
}

@media screen and (max-width: 950px) {
	#philosophy .continuation .inner .heading-text h2 {
		font-size: clamp(2.9rem, calc(3.8vw), 3.5rem);
	}
}

#philosophy .development {
	padding: 80px 0 70px;
}

#philosophy .development .container h2 {
	font-size: 5rem;
	margin-bottom: 60px;
}

#philosophy .development .container .img-slider {
	justify-content: space-between;
}

#philosophy .development .container .img-slider .img {
	width: 40%;
}

#philosophy .development .container .img-slider .slider {
	width: 55%;
}

#philosophy .development .container .img-slider .slider .detail {
	padding-right: 70px;
	padding-bottom: 100px;
}

#philosophy .development .container .img-slider .slider .detail .number {
	font-size: 7.6rem;
	margin-bottom: 20px;
}

#philosophy .development .container .img-slider .slider .detail h3 {
	font-size: 3.6rem;
	margin-bottom: 35px;
}

@media screen and (max-width: 1100px) {
	#philosophy .development .container .img-slider .slider .detail h3 {
		font-size: clamp(2.5rem, calc(3.2vw), 3.6rem);
	}
}

#philosophy .development .container .img-slider .slider .progress {
	width: 600px;
}

@media screen and (max-width: 1300px) {
	#philosophy .development .container .img-slider .slider .progress {
		width: 500px;
	}
}

#philosophy .development .container .img-slider .slider .progress .number.slider-active::after {
	width: 240px;
}

@keyframes slideWidth {
	from {
		width: 0;
	}

	to {
		width: 240px;
	}
}

@media screen and (max-width: 1300px) {
	#philosophy .development .container .img-slider .slider .progress .number.slider-active::after {
		width: 210px;
		animation: slideWidthShort 1.5s forwards infinite;
	}
}

@keyframes slideWidthShort {
	from {
		width: 0;
	}

	to {
		width: 210px;
	}
}

#philosophy .president {
	padding: 100px 0 40px;
}

#philosophy .president .container {
	width: 100%;
}

#philosophy .president .container .blue-bg {
	width: 4000px;
	height: 475px;
	transform: rotate(-3deg);
}

@media screen and (max-width: 1300px) {
	#philosophy .president .container .blue-bg {
		height: 370px;
	}
}

#philosophy .president .container .img-heading {
	gap: 0 40px;
	margin-bottom: 130px;
}

@media screen and (max-width: 1300px) {
	#philosophy .president .container .img-heading {
		margin-bottom: 125px;
	}
}

@media screen and (max-width: 900px) {
	#philosophy .president .container .img-heading .img {
		width: 50%;
	}
}

#philosophy .president .container .img-heading .heading {
	margin-top: 190px;
}

#philosophy .president .container .img-heading .heading h2 {
	font-size: 5rem;
	margin-bottom: 20px;
}

@media screen and (max-width: 1300px) {
	#philosophy .president .container .img-heading .heading h2 {
		font-size: clamp(3rem, calc(3vw), 5rem);
	}
}

#philosophy .president .container .img-heading .heading p {
	font-size: 2.6rem;
	padding-top: 10px;
}

#philosophy .president .container .career-us {
	gap: 0 30px;
	width: 90%;
	margin-inline: auto;
}

#philosophy .president .container .career-us .career {
	gap: 25px 0;
	width: 305px;
	padding-top: 60px;
}

#philosophy .president .container .career-us .career .img {
	top: -270px;
	left: 0;
}

#philosophy .president .container .career-us .us {
	width: calc(100% - 335px);
}

#philosophy .president .container .career-us .us .text {
	margin-bottom: 25px;
}

#philosophy .president .container .career-us .us .last-text {
	margin-bottom: 5px;
}


/*------------------------------ pc 固定リンク ------------------------------*/
.pc-fixed-link {
	position: relative;
	text-align: right;
	transition: opacity 0.5s;
	opacity: 0;
	pointer-events: none;
}

.pc-fixed-link.fixed_active_pc {
	opacity: 1;
	pointer-events: auto;
}

.pc-fixed-link .contact {
	position: fixed;
	bottom: 120px;
	background-image: url(../img/common/contact-bg.svg);
	background-size: cover;
	text-align: center;
	width: 180px;
	height: 134px;
	filter: drop-shadow(5px 2px 5px #aaa);
	z-index: 2;
	animation: contact-fuwa 3s infinite ease-in-out;
	transition: .3s;
	right: -25px;
}

@keyframes contact-fuwa {
	0% {
		transform: translateY(0px);
	}

	50% {
		transform: translateY(-7px);
	}

	100% {
		transform: translateY(0px);
	}
}

.pc-fixed-link .contact:hover {
	width: 185px;
	height: 137px;
	margin-left: -113px;
}

.pc-fixed-link .contact figure {
	position: absolute;
	top: 36px;
	left: 23px;
}

.pc-fixed-link .contact figure img {
	width: 50px;
}

.pc-fixed-link .contact figure figcaption {
	font-size: 1.8rem;
	color: #fff;
	margin-bottom: 3px;
	letter-spacing: 0.1em;
}


/*------------------------------ トップに戻る ------------------------------*/
#page-top {
	bottom: 20px;
	right: 20px;
}

#page-top a {
	width: 60px;
	height: 60px;
}

#page-top a::after {
	width: 60px;
	height: 60px;
}

#page-top a:before {
	width: 17px;
	height: 17px;
	border-width: 5px 0 0 5px;
}


/*------------------------------ 404 ------------------------------*/
#not-found .dot-bg .inner .number-text {
	font-size: 15rem;
}



/*------------------------------ 販売代理店募集中 ------------------------------*/
#partner h2 {
  font-size: 5rem;
}

@media screen and (max-width: 1000px) {
	#partner .us .inner {
		flex-direction: column;
		gap: 66px 0;
	}
}

#partner .us .inner .texts {
  width: 64%;
}

@media screen and (max-width: 1000px) {
	#partner .us .inner .texts {
		width: 100%;
	}
}

#partner .us .inner .texts h2 {
  font-size: 3.6rem;
}

@media screen and (max-width: 1200px) {
	#partner .us .inner .texts h2 {
		font-size: 3.1rem;
	}
}

#partner .feature .inner .each-feature {
  width: 50%;
  padding: 45px;
}

@media screen and (max-width: 1000px) {
	#partner .feature .inner .each-feature {
		padding: 25px;
	}
}

#partner .feature .inner .each-feature:first-of-type {
  border-right: dashed 2px #C9C9C9;
  border-bottom: dashed 2px #C9C9C9;
}

#partner .feature .inner .each-feature:first-of-type::after {
  position: absolute;
  content: "";
  width: 42px;
  height: 42px;
  background-color: #fff;
  bottom: -22px;
  right: -22px;
  z-index: 1;
}

#partner .feature .inner .each-feature:nth-of-type(2) {
  border-bottom: dashed 2px #C9C9C9;
}

#partner .feature .inner .each-feature:nth-of-type(3) {
  border-right: dashed 2px #C9C9C9;
}

#partner .feature .inner .each-feature .img {
  height: 209px;
}

#partner .support .inner .each-support {
  justify-content: space-between;
}

@media screen and (max-width: 1000px) {
	#partner .support .inner .each-support {
		padding: 25px 0;
	}
}

#partner .support .inner .each-support figure {
  width: 25%;
}

#partner .support .inner .each-support figure figcaption {
  font-size: 2.6rem;
}

@media screen and (max-width: 1000px) {
	#partner .support .inner .each-support figure figcaption {
		font-size: 2.4rem;
	}
}

#partner .support .inner .each-support .texts {
  width: 71%;
}

@media screen and (max-width: 1000px) {
	#partner .support .inner .each-support .texts {
		width: 69%;
	}
}

#partner .recruit-detail .inner {
  padding: 20px 45px;
  max-width: 1000px;
}

#partner .recruit-detail .inner dl dt {
  width: 183px;
}

#partner .recruit-detail .inner dl dt::before {
  top: 8.5px;
}

#partner .charm .inner {
	padding: 0 45px;
}

#partner .charm .inner .each-charm {
  justify-content: space-between;
}

#partner .charm .inner .each-charm .img {
  width: 25%;
}

#partner .charm .inner .each-charm .texts {
  width: 72%;
}

@media screen and (max-width: 1000px) {
	#partner .charm .inner .each-charm .texts {
		width: 69%;
	}
}

#partner .effect .inner {
  padding: 45px 20px;
}

#partner .effect .inner .each-effect h3 {
	font-size: 2.2rem;
}

@media screen and (min-width: 1001px) and (max-width: 1400px) {
	#partner .effect .inner .each-effect h3 .effect-br {
		display: block;
	}
}

#partner .flow {
  padding: 110px 0 135px;
}

#partner .flow .inner {
	gap: 60px 0;
}

#partner .flow .inner .each-flow {
	gap: 0 30px;
}

#partner .flow .inner .each-flow .illust {
	width: 180px;
	height: 180px;
	position: relative;
}

#partner .flow .inner .each-flow .illust::after {
	position: absolute;
	content: "";
	bottom: -60px;
	left: 50%;
	transform: translateX(-50%);
	width: 7px;
	height: 60px;
	background-color: #DDEAED;
}

#partner .flow .inner .each-flow:last-of-type .illust::after {
	display: none;
}

#partner .flow .inner .each-flow .heading-text {
	width: calc(100% - 210px);
}

#partner .flow .inner .each-flow .heading-text h3 {
	font-size: 2.8rem;
	padding-bottom: 5px;
	margin-bottom: 20px;
}

#partner .faq article {
	margin-bottom: 60px;
}

@media screen and (max-width: 1000px) {
	#partner .faq article {
		margin-bottom: 0;
		padding-top: 60px;
	}
}

#partner .faq article:last-of-type {
	margin-bottom: 100px;
}

#partner .faq article .img {
	margin-bottom: 20px;
}

#partner .faq article h2 {
	font-size: 5rem;
	margin-bottom: 60px;
}

#partner .faq article .accordion label {
	gap: 0 30px;
}

#partner .faq article .accordion label .ques {
	font-size: 3rem;
	width: 60px;
	height: 60px;
}

#partner .faq article .accordion label span {
	padding-right: 30px;
	width: calc(100% - 90px);
}

#partner .faq article .accordion .content {
	padding: 0 20px 0 90px;
	gap: 0 5px;
}

#partner .faq article .accordion .content .answer {
	padding-top: 10px;
}
#partner .faq .Label {
	align-items: center;
}

#partner .faq .Label::before {
	right: 20px;
}

#partner .faq .toggle:checked+.Label+.content {
	padding: 20px 20px 20px 90px;
}
