.pc {
	display: none;
}

@media screen and (max-width: 500px) {
	.small-br {
		display: block;
	}
}

/*------------------------------ 共通 ------------------------------*/
.blue-heading {
	font-size: clamp(3.6rem, calc(4.6vw), 4rem);
}

.white-heading {
	font-size: clamp(3.6rem, calc(4.6vw), 4rem);
}

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

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

@media screen and (max-width: 400px) {
	.orange-link {
		font-size: 1.7rem;
	}
}

/* 青の四角ボタン */
.blue-square-link {
	font-size: clamp(2rem, 2.6vw, 2.3rem);
}

@media screen and (max-width: 350px) {
	.blue-square-link {
		font-size: 1.8rem;
	}
}

.underline-arrow-link {
	font-size: clamp(3rem, 4vw, 3.7rem);
}

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


/* パンくずリスト */
.breadcrumb {
	padding: 20px 15px;
	gap: 0 40px;
}

@media screen and (max-width: 400px) {
	.breadcrumb {
		padding: 20px 10px;
		gap: 0 30px;
	}
}

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

@media screen and (max-width: 400px) {
	.breadcrumb li {
		font-size: 1.3rem;
	}
}

.breadcrumb li.sp a {
	padding-bottom: 3px;
}

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

@media screen and (max-width: 400px) {
	.breadcrumb li a::after {
		right: -15px;
	}
}

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

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

@media screen and (max-width: 500px) {
	.category-list h2 {
		font-size: clamp(3.2rem, 10vw, 5rem);
	}
}

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

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

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


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

.another .inner {
	width: 100%;
}

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

.another .inner a p {
	font-size: clamp(1.8rem, 2.6vw, 2.2rem);
	line-height: 1.7;
}


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

.know h2 {
	margin-bottom: 40px;
	text-align: center;
}

@media screen and (max-width: 500px) {
	.know h2 {
		font-size: clamp(3.2rem, 10vw, 5rem);
	}
}

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


/* まずはお悩み・課題をお教えください（フッター上共通パーツ） */
.on-footer {
	position: relative;
	height: 820px;
	background-image: url(../img/common/on-footer-sp.png);
	position: relative;
	background-repeat: no-repeat;
	background-size: 680px 750px;
	background-position: center 50px;
}

.on-footer .on-footer-top {
	height: 187px;
	position: absolute;
	top: -11px;
	left: 0;
	width: 100%;
	background-image: url(../img/common/fv-top.png);
	background-size: cover;
	background-repeat: no-repeat;
	filter: blur(7px);
	background-color: rgba(255, 255, 255, .8);
}

@media screen and (max-width: 500px) {
	.on-footer .on-footer-top {
		height: 205px;
	}
}

.on-footer .inner .heading-links {
	position: relative;
	padding-top: 20px;
	width: 90%;
	margin-inline: auto;
}

.on-footer .inner .heading-links h2 {
	font-size: 2.7rem;
	font-weight: 700;
}

.on-footer .inner .heading-links p {
	font-size: 1.7rem;
	margin-bottom: 460px;
	line-height: 1.8;
}

@media screen and (max-width: 500px) {
	.on-footer .inner .heading-links p {
		margin-bottom: 432px;
	}
}

.on-footer .inner .heading-links .links {
	font-size: 2rem;
	flex-direction: column;
	gap: 30px 0;
}

.on-footer .inner .heading-links .links a {
	font-size: 2.4rem;
	height: 60px;
}

.on-footer .inner .heading-links .links a::before {
	right: 42px;
}

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


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

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

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

.c-fv .ttl-img figure figcaption h1 {
	font-size: clamp(3rem, 3.8vw, 3.5rem);
}

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


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

.merit .container {
	flex-direction: column-reverse;
	gap: 40px 0;
}

.merit .container .merit-img {
	width: 100%;
}

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

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


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

.anchor .anchor-link {
	gap: 25px 0;
	justify-content: flex-start;
	margin-bottom: 100px;
}

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

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

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

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

.anchor .each-anchor {
	padding-top: 90px;
}

.anchor .each-anchor .anchor-bg {
	padding: 30px 20px 25px;
}

@media screen and (max-width: 500px) {
	.anchor .each-anchor .anchor-bg {
		padding: 80px 20px 25px;
	}
}

.anchor .each-anchor .anchor-icon {
	top: -30px;
	left: 25px;
}

.anchor .each-anchor h2 {
	font-size: 2.4rem;
	margin-bottom: 25px;
	margin-left: 27%;
}

@media screen and (max-width: 500px) {
	.anchor .each-anchor h2 {
		margin-left: 0;
	}
}

@media screen and (max-width: 400px) {
	.anchor .each-anchor h2 {
		font-size: clamp(1.9rem, 6vw, 2.3rem);
	}
}

.anchor .each-anchor .explanation-img {
	justify-content: space-between;
	padding-bottom: 40px;
	margin-bottom: 25px;
	flex-direction: column;
	gap: 40px 0;
}

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

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

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

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

.anchor .each-anchor ul {
	gap: 15px 40px;
}

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


/* 各機能詳細 画像拡大モーダル */
#grayDisplay img {
	left: 0;
	width: 90%;
	margin-top: 70px;
}

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

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

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

.c-beside-fv .ttl-img {
	flex-direction: column;
	gap: 60px 0;
	width: 100%;
}

@media screen and (max-width: 600px) {
	.c-beside-fv .ttl-img {
		gap: 40px 0;
	}
}

.c-beside-fv .ttl-img figure {
	width: 100%;
}

.c-beside-fv .ttl-img .eye-catch {
	width: 90%;
	text-align: right;
	margin-left: auto;
}


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

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

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

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

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

.concept .inner .dx-icon .dx h2 .bigger-thicker {
	font-size: 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 {
	display: none;
}

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


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

.dx-solution .inner .logo-intro {
	flex-direction: column;
	align-items: center;
	gap: 40px 0;
}

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

@media screen and (max-width: 500px) {
	.dx-solution .inner .logo-intro .intro h2 {
		font-size: clamp(2.1rem, 6.5vw, 3rem);
	}
}

.dx-solution .inner .offer {
	flex-direction: column;
}

.dx-solution .inner .offer .each-offer {
	margin-top: 60px;
}

.dx-solution .inner .offer .each-offer .speech-bubble {
	width: 70%;
	margin-inline: auto;
}

.dx-solution .inner .offer .each-offer .speech-bubble img {
	position: absolute;
	z-index: 2;
	top: -8px;
	left: -10%;
	width: 40%;
}

.dx-solution .inner .offer .each-offer .solution-img {
	margin-bottom: 18px;
	top: 37px;
	width: 70%;
	max-width: 440px;
	z-index: 1;
}

.dx-solution .inner .offer .each-offer .text {
	padding: 40px 5% 30px;
	background-color: #EBF2F4;
	width: 110%;
	position: relative;
	left: -5%;
}


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

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


/*------------------------------ ヘッダー ------------------------------*/
header::-webkit-scrollbar {
	display: none !important;
}

header .container .logo-button-links {
	left: 10%;
}

@media screen and (max-width: 500px) {
	header .container .logo-button-links {
		left: 5%;
	}
}

@media screen and (max-width: 400px) {
	header .container .logo-button-links {
		left: 3%;
	}
}

header .container .logo-button-links .logo-button-main .main-links {
	width: 180px;
	margin-right: 0;
}

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

header .container .logo-button-links .logo-button-main .main-links a {
	margin-bottom: 25px;
	width: calc(50% - 10px);
	line-height: 1.7;
}

@media screen and (max-width: 400px) {
	header .container .logo-button-links .logo-button-main .main-links a {
		font-size: 1.4rem;
	}
}

/* header .container .logo-button-links .logo-button-main .main-links a:last-of-type {
	margin-bottom: 0;
} */

header .container .logo-button-links .heading-links {
	gap: 25px 0;
}

header .container .logo-button-links .heading-links .each-links {
	width: 47.5%;
}

@media screen and (max-width: 800px) {
	header .container .logo-button-links .heading-links .each-links {
		width: 100%;
	}
}

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

header .container .logo-button-links .heading-links .each-links a {
	/* margin-bottom: 23px; */
}

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

@media screen and (max-width: 450px) {
	header .container .logo-button-links .heading-links .each-links a {
		font-size: 1.4rem;
		white-space: nowrap;
		letter-spacing: 0;
	}
}

@media screen and (max-width: 400px) {
	header .container .logo-button-links .office-manager .links li a {
		font-size: 1.4rem;
	}
}


/* ここから追加 */
header .container .sp-header {
	height: 70px;
}

header .container .sp-header h1 {
	margin-left: 20px;
}

header .container .sp-header h1 a img {
	width: 120px;
}

header .container .sp-header .icons .each-icon {
	width: 70px;
}

header .container .sp-header .icons .each-icon p {
	font-size: 11px;
}

header .container .sp-hamburger {
	width: 70px;
	height: 70px;
}

header .container .sp-hamburger .hamburger-contents {
	margin-bottom: 6px;
}


/*------------------------------ フッター ------------------------------*/
footer {
	padding-top: 100px;
	letter-spacing: 0.025em;
	font-size: 1.6rem;
}

footer .inner .func-office-manager {
  flex-direction: column;
	gap: 60px 0;
  margin-bottom: 60px;
}

@media screen and (max-width: 400px) {
	footer .inner .func-office-manager {
		gap: 50px 0;
		margin-bottom: 50px;
	}
}

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

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

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

@media screen and (max-width: 400px) {
  footer .inner .func-office-manager .func ul li {
    width: 100%;
  }
}

@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: 100%;
}

@media screen and (max-width: 400px) {
	footer .inner .func-office-manager .office-manager {
		flex-direction: column;
		gap: 50px 0;
	}
}

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

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

@media screen and (max-width: 500px) {
	footer .inner .order-change-links .links {
		flex-direction: column;
	}
}

footer .inner .order-change-links .links a {
	width: 48%;
	font-size: 1.8rem;
}

@media screen and (max-width: 500px) {
	footer .inner .order-change-links .links a {
		width: 100%;
	}
}

footer .inner .order-change-links .other-links {
	flex-direction: column;
	margin-bottom: 70px;
	gap: 25px 0;
}

footer .inner .order-change-links .other-links li a {
	font-size: 1.5rem;
}

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

footer .over-footer {
	padding: 38px 0 34px;
	letter-spacing: 0.03em;
}

footer .over-footer .container {
	flex-direction: column;
	text-align: center;
	gap: 15px 0;
}

footer .over-footer .container .logo-address {
	gap: 30px 0;
	flex-direction: column;
	align-items: center;
	line-height: 1.8;
}

footer .over-footer .container .logo-address img {
	width: 130px;
}

@media screen and (max-width: 350px) {
	footer .over-footer .container .logo-address {
		font-size: 1.5rem;
	}
}

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

footer .inner .order-change-links {
	display: flex;
	flex-direction: column-reverse;
}

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

/* ファーストビュー */
#top .fv {
	margin-bottom: 30px;
}

#top .fv .fv-top {
	height: 190px;
	z-index: 1;
}

#top .fv .fv-bottom {
	height: 240px;
	filter: blur(30px);
	background-color: rgba(255, 255, 255, .8);
	z-index: 1;
}

#top .fv .container {
	height: 100vh;
}

#top .fv .container .fv-parts {
	position: absolute;
	width: 700px;
	height: 853px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background-size: 700px 853px;
	background-image: url(../img/top/fv-sp.png);
	background-position: center bottom;
}

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

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

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

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

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

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

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

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

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

#top .fv .container .top-heading {
	left: 5%;
	/* position: fixed; */
	position: absolute;
	bottom: 15px;
}

#top .fv .container .top-heading h1 {
	margin-bottom: 20px;
	justify-content: flex-start;
}

#top .fv .container .top-heading h1 img {
	width: 95%;
}

@media screen and (max-width: 450px) {
	#top .fv .container .top-heading .en-sub-heading {
		font-size: clamp(1.2rem, 3.8vw, 1.6rem);
	}
}

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

#top .office .container ul {
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 20px 0;
	align-items: center;
}

#top .office .container ul li {
	width: 45%;
	text-align: left;
}

#top .office .container ul li a {
	font-size: clamp(1.9rem, calc(1.3rem + 0.625vw), 2.4rem);
}

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

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

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

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

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

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

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

@media screen and (max-width: 500px) {
	#top .problem .container .voice .each-voice {
		padding: 70px 20px 20px;
	}
}

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

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

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

@media screen and (max-width: 700px) {
	#top .problem .container .voice .each-voice .heading-img h3 {
		font-size: clamp(2rem, 4vw, 2.7rem);
	}
}

@media screen and (max-width: 500px) {
	#top .problem .container .voice .each-voice .heading-img h3 {
		text-align: center;
		justify-content: center;
	}
}

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

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

@media screen and (max-width: 500px) {
	#top .problem .container .voice .each-voice:nth-of-type(even) .heading-img h3 {
		margin-left: 0;
	}
}

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

@media screen and (max-width: 500px) {
	#top .problem .container .voice .each-voice .heading-img .white-circle {
		width: 120px;
		height: 120px;
		top: -120px;
		left: 50%;
		transform: translateX(-50%) !important;
	}
}

@media screen and (max-width: 500px) {
	#top .problem .container .voice .each-voice .heading-img .white-circle img {
		width: 50%;
	}
}

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

@media screen and (max-width: 500px) {
	#top .problem .container .voice .each-voice:nth-of-type(even) .heading-img .white-circle {
		left: 50%;
	}
}


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

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

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

#top .reason .inner .all-reason .each-reason {
	width: 50%;
	padding: 15px;
	border-right: dashed 2px #C9C9C9;
}

@media screen and (max-width: 600px) {
	#top .reason .inner .all-reason .each-reason {
		width: 100%;
		border-right: none;
	}
}

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

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

#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;
}

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

#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 {
	display: none;
}

#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;
}

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

#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;
}

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

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

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

#top .reason .inner .all-reason .each-reason h3 {
	font-size: clamp(2rem, 2vw, 2.8rem);
	margin-bottom: 30px;
}

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

@media screen and (max-width: 600px) {
	#top .reason .inner .all-reason .each-reason img {
		height: auto;
	}
}

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

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

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

#top .by-office .inner .types .each-type {
	width: 100%;
	padding: 20px 15px;
}

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

#top .by-office .inner .types .each-type .text {
	margin-bottom: 15px;
}

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

/* #top .by-office .inner .types .each-type .person-imgs img {
	width: 60px;
} */

#top .by-office .inner .types .each-type:last-of-type {
	border-bottom: none;
}


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

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

@media screen and (max-width: 500px) {
	#top .manager .inner .manager-heading p {
		font-size: 2rem;
	}
}

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

#top .manager .inner .manager-wrap .each-manager {
	padding: 30px;
	margin-bottom: 62px;
	align-items: center;
	flex-direction: column;
	gap: 30px 0;
}

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

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

#top .manager .inner .manager-wrap .each-manager .icon-manager h3 {
	font-size: 2.2rem;
}

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

#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 {
	width: 25px;
	right: -35px;
}

#top .manager .inner .manager-wrap .each-manager .tag-comment .tag-wrap {
	gap: 20px;
	margin-bottom: 20px;
	line-height: 1;
}

#top .manager .inner .manager-wrap .each-manager .tag-comment .tag-wrap a {
	font-size: clamp(1.6rem, 1.6vw, 2rem);
}

#top .manager .inner .manager-wrap .each-manager .tag-comment .text {
	margin-bottom: 25px;
}

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

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

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

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

#top .category .container .category-wrap a {
	width: 48%;
	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.2rem;
	top: 72%;
}

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

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

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

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

#top .video .video-inner .links {
	flex-direction: column;
	margin-bottom: 53px;
	gap: 30px 0;
}

#top .video .video-inner .links a {
	width: 90%;
	margin-inline: auto;
	height: 56px;
	font-size: clamp(2.1rem, 2.8vw, 2.6rem);
}

@media screen and (max-width: 450px) {
	#top .video .video-inner .links a::before {
		right: 42px;
	}

	#top .video .video-inner .links a::after {
		right: 15px;
	}
}

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

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

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

@media screen and (max-width: 400px) {
	#top .improvement .inner h2 {
		font-size: 3rem;
	}
}

#top .improvement .inner .improvement-wrap {
	justify-content: space-between;
	gap: 40px 0;
}

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

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

#top .improvement .inner .improvement-wrap .each-improvement h3 {
	font-size: clamp(1.9rem, 3vw, 2.8rem);
}

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

@media screen and (max-width: 400px) {
	#top .improvement .inner .improvement-wrap .each-improvement .improvement-tags {
		margin-bottom: 40px;
	}
}


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

#top .information .inner {
	position: relative;
}

#top .information .inner .heading-info {
	align-items: center;
	flex-direction: column;
}

#top .information .inner .heading-info h2 {
	margin-bottom: 20px;
}

#top .information .inner .to-all-info {
	margin-left: auto;
}

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

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

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

#top .information .inner .heading-info .info-wrap a {
	margin-bottom: 21px;
	padding: 14px 30px 14px 15px;
	flex-wrap: wrap;
	gap: 10px 0;
}

@media screen and (max-width: 600px) {
	#top .information .inner .heading-info .info-wrap a {
		font-size: 1.5rem;
	}
}

@media screen and (max-width: 500px) {
	#top .information .inner .heading-info .info-wrap a {
		font-size: 1.4rem;
	}
}

@media screen and (max-width: 400px) {
	#top .information .inner .heading-info .info-wrap a {
		letter-spacing: 0;
	}
}

@media screen and (max-width: 600px) {
	#top .information .inner .heading-info .info-wrap a::after {
		right: 20px;
	}
}

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

#top .information .inner .heading-info .info-wrap a .info-tag {
	margin-right: 10px;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 26px;
	padding: 0 5px;
}

#top .information .inner .heading-info .info-wrap a h3 {
	width: 100%;
	justify-content: flex-start;
}

/*------------------------------ コラム 投稿 共通 ------------------------------*/
.column .inner .column-wrap {
	flex-direction: column;
	margin-bottom: 40px;
	gap: 50px 0;
}

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

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

.column .inner .column-wrap .each-column a .img-date {
	margin-bottom: 20px;
	max-width: 440px;
	margin-inline: auto;
}

.column .inner .column-wrap .each-column a .img-date img {
	width: 100%;
	object-fit: cover;
}

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

.column .inner .column-wrap .each-column a h3 {
	font-size: 2rem;
	color: #072E61;
}

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


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

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


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



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



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



/*------------------------------ 機能カテゴリー 一覧 ------------------------------*/
#function .search-list .container {
	gap: 80px 0;
	flex-direction: column;
}

#function .search-list .container .search-bar .checks h2 {
	position: relative;
	margin-bottom: 0;
	padding: 25px 20px;
	cursor: pointer;
}

#function .search-list .container .search-bar .checks h2::after {
	position: absolute;
	content: "";
	top: 50%;
	transform: translateY(-50%);
	right: 25px;
	width: 34px;
	height: 34px;
	border-radius: 9999px;
	background-color: #F2AC4E;
}

#function .search-list .container .search-bar .checks h2::before {
	position: absolute;
	content: "＋";
	right: 28px;
	z-index: 1;
	color: #fff;
	font-size: 2.6rem;
	top: 50%;
	transform: translateY(-50%);
	line-height: 1;
}

#function .search-list .container .search-bar .checks h2.active::before {
	position: absolute;
	content: "";
	background-color: #fff;
	width: 16px;
	height: 2px;
	top: 50%;
	right: 34px;
	transform: translateY(-50%);
	z-index: 1;
}

#function .search-list .container .search-bar .checks .check-wrap {
	display: none;
	padding: 0px 25px 20px;
}

#function .search-list .container .search-bar .checks .check-wrap.active {
	display: block;
}

#function .search-list .container .search-bar .checks {
	padding: 0;
}

#function .search-list .container .list {
	gap: 30px 0;
}

#function .search-list .container .list article {
	width: 100%;
	padding: 30px 20px 20px;
}

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

#function .search-list .container .list article .img-heading {
	display: flex;
	align-items: center;
	gap: 0 40px;
	margin-bottom: 30px;
}

@media screen and (max-width: 500px) {
	#function .search-list .container .list article .img-heading {
		gap: 0 20px;
		margin-bottom: 10px;
	}
}

#function .search-list .container .list article .img {
	max-width: 104px;
	text-align: center;
}

@media screen and (max-width: 500px) {
	#function .search-list .container .list article .img {
		max-width: 70px;
	}
}

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

@media screen and (max-width: 500px) {
	#function .search-list .container .list article h2 {
		font-size: 1.7rem;
	}
}

#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;
}


#function .search-list .container .list article .view-more {
  right: 20px;
}


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

.info .inner .tax-btn a {
	width: 100%;
}


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

#information .info .inner .info-wrap a {
	margin-bottom: 21px;
	padding: 14px 30px 14px 15px;
	flex-wrap: wrap;
	gap: 10px 0;
}

@media screen and (max-width: 600px) {
	#information .info .inner .info-wrap a {
		font-size: 1.5rem;
	}
}

@media screen and (max-width: 500px) {
	#information .info .inner .info-wrap a {
		font-size: 1.4rem;
	}
}

@media screen and (max-width: 400px) {
	#information .info .inner .info-wrap a {
		letter-spacing: 0;
	}
}

@media screen and (max-width: 600px) {
	#information .info .inner .info-wrap a::after {
		right: 20px;
	}
}

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

#information .info .inner .info-wrap a .info-tag {
	margin-right: 10px;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 26px;
	padding: 0 5px;
}

#information .info .inner .info-wrap a h3 {
	width: 100%;
	justify-content: flex-start;
}


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

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

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

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

@media screen and (max-width: 500px) {
	#single-information .info article h2 {
		font-size: 2.4rem;
	}
}

@media screen and (max-width: 500px) {
	#single-information .info .to-all-info {
		gap: 0 50px;
	}
}


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

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

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

.pagination a.prev::after {
	width: 9px;
	height: 9px;
	left: 15px;
}

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


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



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

#single-column .column .inner {
	padding: 20px 20px 40px;
	margin-bottom: 40px;
}

@media screen and (max-width: 500px) {
	#single-column .column .inner {
		padding: 20px 15px 40px;
	}
}

#single-column .column .inner .date-tag {
	gap: 10px 0;
	margin-bottom: 20px;
	text-align: left;
	flex-direction: column;
}

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

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

@media screen and (max-width: 500px) {
	#single-column .column .inner .post-title {
		font-size: 2.2rem;
		margin-bottom: 20px;
	}
}

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

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

#single-column .column .inner .table-of-contents {
	padding: 25px 20px;
}

@media screen and (max-width: 500px) {
	#single-column .column .inner .table-of-contents {
		padding: 20px 15px;
	}
}

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

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

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

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

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

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

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

@media screen and (max-width: 500px) {
	#single-column .column .inner article h2 {
		font-size: 2rem;
	}
}

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

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

#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 20px 40px;
}

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

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

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

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

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

@media screen and (max-width: 500px) {
	#single-column .column .inner .check .square-arrow-link {
		width: 100%;
	}
}

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

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

@media screen and (max-width: 500px) {
	#single-column .column .pagination-all {
		gap: 0 25px;
	}
}


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

@media screen and (max-width: 500px) {
	#single-column .column .to-all-column {
		width: 150px;
	}
}


/*------------------------------ お問い合わせ 共通 ------------------------------*/
.contact-step {
	margin-bottom: 80px;
	flex-direction: column;
	gap: 60px 0;
}

.contact-step li {
	width: 100%;
	max-width: 400px;
}

.contact-step li::after {
	border-right: 18px solid transparent;
	border-left: 18px solid transparent;
	border-top: 25px solid #fff;
	border-bottom: 0;
	bottom: -43px;
	left: 50%;
	transform: translateX(-50%);
}

.contact-step li.current-step::after {
	border-top: 25px solid #39c1d8;
}


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

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

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

@media screen and (max-width: 400px) {
	#contact .content .inner .contact-form .items {
		padding: 30px 10px;
	}
}

#contact .content .inner .contact-form .items dl {
	font-size: 1.8rem;
	margin-bottom: 30px;
	flex-direction: column;
	gap: 10px 0;
}

#contact .content .inner .contact-form .items dl dt {
	width: 100%;
}

#contact .content .inner .contact-form .items dl dd {
	width: 100%;
}

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

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

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

@media screen and (max-width: 500px) {
	#contact .content .inner .contact-form .confirm::before {
		font-size: 2.7rem;
	}
}


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

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

#contact-confirm .content .inner .contact-form .items dl {
	font-size: 1.8rem;
	margin-bottom: 30px;
	flex-direction: column;
	gap: 5px 0;
}

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

#contact-confirm .content .inner .contact-form .items dl dd {
	width: 100%;
}

#contact-confirm .content .inner .contact-form .edit {
	flex-direction: column;
	gap: 30px 0;
}

#contact-confirm .content .inner .contact-form .edit .form-prev {
	width: 100%;
	max-width: 533px;
	margin-inline: auto;
}

#contact-confirm .content .inner .contact-form .edit .form-next {
	width: 100%;
	max-width: 533px;
	margin-inline: auto;
}

#contact-confirm .content .inner .contact-form .edit .form-next p:first-of-type {
	width: 100%;
	max-width: 533px;
	margin-inline: auto;
}



/*------------------------------ サポート体制 ------------------------------*/
#support .system {
	padding: 80px 0 60px;
}

#support .system .inner h2 {
	font-size: clamp(2.4rem, calc(7vw), 4rem);
	margin-bottom: 50px;
}

#support .system .inner .line {
	margin-bottom: 60px;
	flex-direction: column;
	gap: 20px 0;
}

#support .system .inner .line .number-heading {
	gap: 0 25px;
}

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

#support .system .inner .line .number-heading .number {
	width: 50px;
	height: 50px;
	font-size: 3rem;
	position: relative;
}

/* #support .system .inner .line .number-heading .number::after {
	position: absolute;
	content: "";
	bottom: -25px;
	left: 50%;
	transform: translateX(-50%);
	width: 3px;
	height: 20px;
	background-color: #F2AC4E;
} */

/* #support .system .inner .line .number-heading:last-of-type .number::after {
	display: none;
} */

#support .system .inner .each-support {
	margin-bottom: 50px;
	padding: 90px 20px 40px;
}

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

#support .system .inner .each-support .ellipse::before {
	font-size: 4.8rem;
	top: 57px;
	left: 38px;
}

#support .system .inner .each-support .img-intro {
	gap: 30px 0;
	margin-bottom: 15px;
	flex-direction: column-reverse;
}

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

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

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

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

#support .system .inner .each-support .img-intro .intro h3 {
	font-size: 3rem;
	margin-bottom: 5px;
}

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

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

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

#support .security {
	padding: 60px 0 90px;
}

#support .security .inner .logo-intro {
	flex-direction: column;
	align-items: center;
	gap: 40px 0;
}

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

#support .security .inner .logo-intro .intro {
	width: 100%;
	margin-bottom: 31px;
}

#support .security .inner .logo-intro .intro h2 {
	font-size: 3.5rem;
}

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

#support .security .inner .security-wrap {
	flex-direction: column;
	gap: 70px 0;
}

#support .security .inner .security-wrap .each-security {
	width: 100%;
	position: relative;
	padding-bottom: 15px;
}

#support .security .inner .security-wrap .each-security::after {
	position: absolute;
	content: "";
	width: 110%;
	height: 400px;
	background-color: #EBF2F4;
	bottom: 0;
	left: -5%;
	z-index: -1;
}

#support .security .inner .security-wrap .each-security .img {
	margin-bottom: 10px;
	max-width: 440px;
	margin-inline: auto;
}

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

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

@media screen and (max-width: 350px) {
	#support .security .inner .security-wrap .each-security h3 {
		font-size: 1.9rem;
	}
}


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

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

#faq .about article {
	margin-bottom: 0;
	padding-top: 50px;
}

#faq .about article .inner {
	padding: 50px 0 30px;
	width: 100%;
}

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

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

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

@media screen and (max-width: 500px) {
	#faq .about article h2 {
		font-size: clamp(3.3rem, calc(10vw), 5rem);
	}
}

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

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

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

@media screen and (max-width: 450px) {
	#faq .about article .accordion label span {
		font-size: clamp(1.4rem, calc(3.8vw), 1.6rem);
	}
}

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

#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;
}

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


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

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

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


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

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

#price .unity .inner .merit-list li {
	border: 10px solid #F2AC4E;
	width: 100%;
	padding: 20px;
	font-size: 2rem;
	border-bottom: none;
}

@media screen and (max-width: 400px) {
	#price .unity .inner .merit-list li {
		padding: 10px;
		font-size: 1.8rem;
		letter-spacing: 0.05em;
	}
}

#price .unity .inner .merit-list li:last-of-type {
	border-bottom: 10px solid #F2AC4E;
}

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

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

#price .unity .inner .anchor-link {
	gap: 28px 0;
}

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

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

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

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

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

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

@media screen and (max-width: 350px) {
	#price .unity .inner .composition .intro-month .each-compo .heading {
		padding: 0 15px;
	}
}

#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 {
  line-height: 1.6;
}

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

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

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

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

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

#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 {
	flex-direction: column;
}

#price .unity .inner .discount .table .discount-wrap .each-discount {
	width: 90%;
	padding: 30px 0;
	border-bottom: dashed 2px #C9C9C9;
	margin-inline: auto;
}

#price .unity .inner .discount .table .discount-wrap .each-discount:last-of-type {
	border-bottom: none;
}

#price .unity .inner .discount .table .discount-wrap .each-discount h3 {
	font-size: clamp(1.8rem, calc(1.8vw), 2.4rem);
	margin-bottom: 10px;
}

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

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

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

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

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

/* @media screen and (max-width: 400px) {
	#price .comparison .inner {
		width: 100%;
	}
} */

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

#price .comparison .sp-list {
	background-color: #F7F7F7;
}

#price .comparison .sp-list .inner .each-list {
	margin-bottom: 50px;
}

#price .comparison .sp-list .inner .each-list:last-of-type {
	margin-bottom: 0;
}

#price .comparison .sp-list .inner .each-list h3 {
	background-color: #DDEAED;
	justify-content: center;
	border-radius: 10px;
	font-size: 3rem;
	align-items: center;
	height: 80px;
	color: #37B0CC;
	padding-left: 25px;
	margin-bottom: 20px;
	font-weight: 700;
	margin-inline: auto;
}

@media screen and (max-width: 600px) {
	#price .comparison .sp-list .inner .each-list h3 {
		font-size: 2.6rem;
		height: 70px;
		padding-left: 15px;
	}
}

@media screen and (max-width: 400px) {
	#price .comparison .sp-list .inner .each-list h3 {
		width: 90%;
		padding-left: 0;
		height: 65px;
		font-size: 2.4rem;
	}
}

#price .comparison .sp-list .inner .each-list dl {
	border-bottom: 1px solid #D0D0D0;
	align-items: center;
	background-color: #fff;
}

#price .comparison .sp-list .inner .each-list dl:last-of-type {
	border-bottom: none;
}

#price .comparison .sp-list .inner .each-list dl.our {
	background-color: #37B0CC;
	color: #fff;
}

#price .comparison .sp-list .inner .each-list dl.our dt {
	border-right: 1px solid #fff;
	font-size: 1.6rem;
	font-weight: 700;
}

#price .comparison .sp-list .inner .each-list dl dt {
	font-size: 2.6rem;
	border-right: 1px solid #D0D0D0;
	width: 30%;
	height: 68px;
	display: flex;
	align-items: center;
	padding-left: 25px;
}

@media screen and (max-width: 600px) {
	#price .comparison .sp-list .inner .each-list dl dt {
		font-size: 1.8rem;
		height: 60px;
		padding-left: 15px;
	}
}

@media screen and (max-width: 400px) {
	#price .comparison .sp-list .inner .each-list dl dt {
		padding-left: 10px;
	}
}

#price .comparison .sp-list .inner .each-list dl dd {
	height: 68px;
	align-items: center;
	gap: 0 20px;
	padding: 0 20px;
}

@media screen and (max-width: 600px) {
	#price .comparison .sp-list .inner .each-list dl dd {
		height: 60px;
		gap: 0 15px;
		padding: 0 15px;
	}
}

@media screen and (max-width: 350px) {
	#price .comparison .sp-list .inner .each-list dl dd {
		padding-right: 0;
		padding-left: 12px;
		gap: 0 12px;
	}
}

#price .comparison .sp-list .inner .each-list dl dd p {
	font-size: 2.2rem;
}

@media screen and (max-width: 600px) {
	#price .comparison .sp-list .inner .each-list dl dd p {
		font-size: 1.8rem;
	}
}

@media screen and (max-width: 400px) {
	#price .comparison .sp-list .inner .each-list dl dd p {
		font-size: 1.6rem;
	}
}

#price .comparison .sp-list .inner .each-list dl dd .ai-text {
	font-size: 2rem;
	line-height: 1.3;
}

@media screen and (max-width: 600px) {
	#price .comparison .sp-list .inner .each-list dl dd .ai-text {
		font-size: 1.6rem;
	}
}

@media screen and (max-width: 400px) {
	#price .comparison .sp-list .inner .each-list dl dd .ai-text {
		font-size: 1.3rem;
	}
}

#price .comparison .sp-list .inner .each-list dl dd .figure {
	width: 30px;
	height: 30px;
}

#price .comparison .sp-list .inner .each-list dl dd .circle {
	border-radius: 9999px;
	border: 4px solid #fff;
	margin-inline: auto;
}

#price .comparison .sp-list .inner .each-list dl dd .circle-black {
	border: 4px solid #5B5B5B;
}

#price .comparison .sp-list .inner .each-list dl dd .circle-orange {
	border: 4px solid #F2AC4E;
	position: relative;
}

#price .comparison .sp-list .inner .each-list dl dd .circle-orange::before {
	position: absolute;
	content: "";
	border-radius: 9999px;
	border: 4px solid #F2AC4E;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 16px;
	height: 16px;
}

#price .comparison .sp-list .inner .each-list dl dd .nothing {
	position: relative;
}

#price .comparison .sp-list .inner .each-list dl dd .nothing::before {
	position: absolute;
	content: "";
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background-color: #D0D0D0;
	height: 4px;
	width: 30px;
}

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

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

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

#price .flow .inner .flow-wrap .each-flow {
	gap: 30px 0;
	flex-direction: column;
	position: relative;
}

#price .flow .inner .flow-wrap .each-flow::after {
	position: absolute;
	content: "";
	border-right: 18px solid transparent;
	border-left: 18px solid transparent;
	border-top: 25px solid #DDEAED;
	border-bottom: 0;
	bottom: -45px;
	left: 50%;
	transform: translateX(-50%) translateY(-5px);
	animation: flow-triangle .8s alternate ease-in-out infinite;
}

@keyframes flow-triangle {
	0% {}

	100% {
		transform: translateX(-50%) translateY(0);
	}
}

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

#price .flow .inner .flow-wrap .each-flow .illust {
	width: 180px;
	height: 180px;
	position: relative;
	margin-inline: auto;
	margin-bottom: 15px;
}

#price .flow .inner .flow-wrap .each-flow .heading-text {
	width: 100%;
	max-width: 420px;
}

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


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

#philosophy .continuation .inner {
	gap: 50px 0;
	flex-direction: column;
}

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

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

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

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

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

#philosophy .development {
	padding: 20px 0 50px;
}

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

@media screen and (max-width: 600px) {
	#philosophy .development .container h2 {
		font-size: clamp(3rem, 8vw, 5rem);
	}
}

#philosophy .development .container .img-slider {
	flex-direction: column;
}

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

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

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

@media screen and (max-width: 500px) {
	#philosophy .development .container .img-slider .slider .detail {
		padding-right: 50px;
	}
}

#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: 400px) {
	#philosophy .development .container .img-slider .slider .detail h3 {
		font-size: clamp(3.2rem, 10vw, 3.6rem);
	}
}

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

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

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

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

#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;
	}
}

@media screen and (max-width: 600px) {
	#philosophy .development .container .img-slider .slider .progress .number.slider-active::after {
		width: 160px;
		animation: slideWidth160 1.2s forwards infinite;
	}
}

@keyframes slideWidth160 {
	from {
		width: 0;
	}

	to {
		width: 160px;
	}
}

@media screen and (max-width: 450px) {
	#philosophy .development .container .img-slider .slider .progress .number.slider-active::after {
		width: 110px;
		animation: slideWidth110 1.2s forwards infinite;
	}
}

@keyframes slideWidth110 {
	from {
		width: 0;
	}

	to {
		width: 110px;
	}
}

#philosophy .president {
	padding: 80px 0 50px;
}

#philosophy .president .container .blue-bg {
	width: 2000px;
	height: 800px;
	transform: rotate(-5deg);
}

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

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

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

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

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

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

#philosophy .president .container .img-heading {
	gap: 30px 0;
	margin-bottom: 110px;
	flex-direction: column;
}

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

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

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

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

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

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

#philosophy .president .container .img-heading .img {
	text-align: right;
	position: relative;
}

#philosophy .president .container .img-heading .img .smile-img {
	position: absolute;
	bottom: -26%;
	left: -10%;
	width: 50%;
}

@media screen and (max-width: 500px) {
	#philosophy .president .container .img-heading .img .smile-img {
		bottom: -12%;
	}
}

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

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

#philosophy .president .container .img-heading .heading p {
	font-size: 2.6rem;
	text-align: right;
	margin-bottom: 40px;
}

@media screen and (max-width: 600px) {
	#philosophy .president .container .img-heading .heading p {
		font-size: clamp(2rem, calc(6vw), 2.6rem);
		margin-bottom: 30px;
	}
}

#philosophy .president .container .career-us {
	gap: 0;
	flex-direction: column-reverse;
}

#philosophy .president .container .career-us .career {
	gap: 25px 0;
	width: 100%;
	padding-top: 40px;
	letter-spacing: 0.1em;
	line-height: 1.5;
}

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

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

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


/*------------------------------ sp 固定リンク ------------------------------*/
.sp-fixed-links {
	align-items: center;
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	z-index: 2;
	display: flex;
	transition: opacity 0.5s;
	opacity: 0;
	pointer-events: none;
}

.sp-fixed-links.fixed_active {
	opacity: 1;
	pointer-events: auto;
}

.sp-fixed-links a {
	width: 50%;
	background-color: #152F58;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	padding: 10px 0;
	transition: .5s;
}

.sp-fixed-links a:hover {
	background-color: #F2AC4E;
}

.sp-fixed-links a:first-of-type {
	position: relative;
}

.sp-fixed-links a:first-of-type::after {
	position: absolute;
	content: "";
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 2px;
	height: 70%;
	background-color: #fff;
}

.sp-fixed-links a p {
	font-size: 3rem;
	color: #fff;
	letter-spacing: 0.1em;
}

@media screen and (max-width: 500px) {
	.sp-fixed-links a p {
		font-size: 2rem;
		font-size: clamp(2rem, 4.7vw, 3rem);
	}
}

.sp-fixed-links a .img {
	height: 45px;
	width: 20%;
	display: flex;
	justify-content: center;
}


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

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

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

#page-top a:before {
  width: 15px;
  height: 15px;
  border-width: 4px 0 0 4px;
}


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



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

@media screen and (max-width: 400px) {
	#partner .square-arrow-link {
		width: 90%;
	}
}

	#partner .us .inner {
		flex-direction: column;
		gap: 66px 0;
	}

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


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

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

#partner .feature .inner .each-feature {
  width: 100%;
	padding: 45px 20px;
	border-bottom: dashed 2px #C9C9C9;
}

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

#partner .feature .inner .each-feature:last-of-type {
  border-bottom: none;
}

#partner .support .inner .each-support {
	flex-direction: column;
	align-items: center;
	gap: 25px 0;
}

#partner .support .inner .each-support figure {
  width: 100%;
	flex-direction: column-reverse;
	gap: 25px 0;
}

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

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

#partner .recruit-detail .inner {
  padding: 20px 25px;
}

#partner .recruit-detail .inner dl {
	flex-direction: column;
	gap: 20px 0;
}

#partner .recruit-detail .inner dl dt::before {
  top: 50%;
	transform: translateY(-50%);
}

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

#partner .charm .inner .each-charm {
  flex-direction: column;
	gap: 25px 0;
}

@media screen and (max-width: 400px) {
	#partner .effect h2 {
		font-size: 3rem;
	}
}

#partner .effect .inner {
  padding: 25px;
}

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

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

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

@media screen and (max-width: 400px) {
	#partner .flow h2 {
		font-size: 3rem;
	}
}

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

#partner .flow .inner .each-flow {
	gap: 30px 0;
	flex-direction: column;
	position: relative;
}

#partner .flow .inner .each-flow::after {
	position: absolute;
	content: "";
	border-right: 18px solid transparent;
	border-left: 18px solid transparent;
	border-top: 25px solid #DDEAED;
	border-bottom: 0;
	bottom: -45px;
	left: 50%;
	transform: translateX(-50%) translateY(-5px);
	animation: flow-triangle .8s alternate ease-in-out infinite;
}

@keyframes flow-triangle {
	0% {}

	100% {
		transform: translateX(-50%) translateY(0);
	}
}

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

#partner .flow .inner .each-flow .illust {
	width: 180px;
	height: 180px;
	position: relative;
	margin-inline: auto;
	margin-bottom: 15px;
}

#partner .flow .inner .each-flow .heading-text {
	width: 100%;
	max-width: 420px;
}

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

#partner .faq article {
	margin-bottom: 0;
	padding-top: 50px;
}

#partner .faq article .inner {
	/* padding: 50px 0 30px; */
	width: 100%;
	padding: 0 25px;
}

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

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

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

@media screen and (max-width: 500px) {
	#partner .faq article h2 {
		font-size: clamp(3.3rem, calc(10vw), 5rem);
	}
}

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

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

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

@media screen and (max-width: 450px) {
	#partner .faq article .accordion label span {
		font-size: clamp(1.4rem, calc(3.8vw), 1.6rem);
	}
}

#partner .faq article .accordion .content {
	padding: 0 20px;
	gap: 0 5px;
}
#partner .faq .Label {
	align-items: center;
}

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

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