@charset "utf-8";

/* ===========================================
	common
============================================== */
.scroll-hint-icon {
	top: 15%;
}

.contact_area {
	margin-top: 0;
}

.article_area {
	padding-bottom: 17.3rem;
}

/* ============
	responsive
================ */

@media screen and (max-width: 768px) {
	.article_area {
		padding-bottom: 8rem;
	}
}

/* ===========================================
	breadcrumbs
============================================== */
.breadcrumbs {
	margin-bottom: 1.34rem;
	padding-right: 3.7rem;
}

.breadcrumbs_list {
	display: flex;
	justify-content: flex-end;
	align-items: flex-end;
	column-gap: 2.4rem;
	overflow-x: scroll;
	overflow-y: visible;
	white-space: nowrap;
	scrollbar-width: none;
	-ms-overflow-style: none;
}

.breadcrumbs_list::-webkit-scrollbar {
	display: none;
	/*Google Chrome、Safari、Microsoft Edge対応のスクロールバー非表示コード*/
}

.breadcrumbs_list li {
	display: flex;
	align-items: flex-end;
	position: relative;
	color: #333;
	font-size: 1.1rem;
	line-height: 1;
}

.breadcrumbs_list span {
	font-size: 1.1rem;
	line-height: 1;
}

.breadcrumbs_list span br {
	display: none;
}

.breadcrumbs_list span:last-of-type {
	margin-right: 0;
}

.breadcrumbs_list li + li::before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: -1.35rem;
	width: 0.5rem;
	height: 0.5rem;
	margin: auto;
	border-radius: 9999px;
	background-color: #333;
}

.breadcrumbs_list li a {
	color: #333;
	line-height: 1;
}

.breadcrumbs_list li a:hover {
	opacity: 0.7;
	border-bottom: solid 1px #333;
}

.breadcrumbs_list li:first-of-type a {
	width: 1.9rem;
	height: 1.754rem;
	background-image: url(../images/common/icon_home.svg);
	background-position: center;
	background-size: contain;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1024px) {
	.breadcrumbs {
		margin-bottom: 0.74rem;
		padding-right: 0;
	}
}

@media screen and (max-width: 640px) {
	.breadcrumbs_list {
		justify-content: flex-start;
	}
}

/* ===========================================
	under_ttl
============================================== */
.under_ttl_area {
	padding-top: 11.5rem;
	padding-bottom: 13.4rem;
}

.under_hero {
	height: 41.5rem;
	overflow: hidden;
	border-radius: 7rem;
}

.under_hero > picture,
.under_hero > picture > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.under_ttl_wrap {
	justify-content: center;
	align-items: flex-start;
	column-gap: 5.5rem;
	position: relative;
	max-width: 95rem;
	width: 100%;
	margin-top: -8.9rem;
	margin-right: auto;
}

.under_ttl_wrap::after {
	position: absolute;
	top: calc(100% - 18.8rem);
	left: 100%;
	z-index: -1;
	width: 39.75rem;
	height: 31.35rem;
	content: '';
	background-image: url(../images/common/cloud_gray03.png);
	background-position: center;
	background-size: contain;
}

.under_ttl {
	justify-content: center;
	align-items: center;
	width: 44.05rem;
	height: 28.8rem;
	padding-top: 1.5rem;
	background-image: url(../images/common/cloud_orange_under_ttl_bg.png);
	background-position: center;
	background-size: contain;
}

.under_ttl .en_sub {
	margin-bottom: 0.5rem;
	color: #7f86af;
	text-transform: capitalize;
}

.under_ttl .ja_ttl {
	font-size: 4.2rem;
	line-height: 1.24;
}

.under_ttl_txt {
	max-width: 42.6rem;
	width: 100%;
	padding-top: 20rem;
	font-size: 2rem;
	line-height: 2;
}

.fixed_btn {
	display: none;
	justify-content: center;
	align-items: center;
	position: fixed;
	right: 1.5vw;
    bottom: 16vw;
	z-index: 10;
	width: 10vw;
	height: 10vw;
	border-radius: 9999px;
	color: #fff;
}

.fixed_btn:hover{
	opacity: 0.7;
}

.fixed_btn > span {
	position: relative;
	padding-top: 2rem;
	padding-bottom: 3rem;
	font-size: calc(1.125rem + ((1vw - 10.24px) * 0.4808));
	text-align: center;
	line-height: 1.15;
}

.fixed_btn > span::before{
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	width: 2.2rem;
	height: 2.144rem;
	margin: auto;
	background-image: url(../images/common/icon_arrow_right_white.svg);
	background-position: center;
	background-size: contain;
	content: '';
}

.training .training_btn,
.recruit .entry_btn{
	display: flex;
}

.training .training_btn {
	background-color: var(--navy_color);
}

.recruit .entry_btn{
	background-color: var(--orange_color);
}

.custom_ttl_wrap {
	margin-right: calc(50% - 50vw);
	margin-left: calc(50% - 50vw);
	padding: 6.85rem calc(50vw - 50%);
	border-radius: 7rem 7rem 0 0;
	background-color: var(--yellow_orange_color);
}

.single-daycare .custom_ttl_wrap {
	background-color: #eaf7d2;
}

.custom_ttl_inner {
	align-items: center;
	column-gap: 7.5rem;
}

.custom_ttl_hero {
	width: 49.5rem;
	aspect-ratio: 495 / 353;
}

.custom_ttl_hero > img {
	width: 100%;
	height: 100%;
	border-radius: 1.5rem;
	object-fit: cover;
}

.custom_ttl_cont_wrap {
	width: 52.8rem;
}

.custom_ttl_cont {
	margin-bottom: 2.9rem;
	padding-top: 0.9rem;
	padding-bottom: 0.9rem;
	padding-left: 2.3rem;
	border-left: solid 1.3rem #fff;
}

.custom_sub {
	margin-bottom: 1.5rem;
	font-size: 2.2rem;
}

.custom_ttl {
	font-weight: 500;
	font-size: 4.1rem;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1280px) {
	.under_ttl_wrap::after {
		right: calc(100% - 100vw);
		left: auto;
	}
}

@media screen and (max-width: 1024px) {
	.under_ttl_area {
		padding-top: 8.6rem;
		padding-bottom: 7.4rem;
	}

	.under_hero {
		border-radius: 5rem;
	}

	.under_ttl_wrap {
		margin-top: -8rem;
	}

	.under_ttl_wrap::after {
		right: -5rem;
		top: calc(100% - 6rem);
		left: auto;
		width: 18.4rem;
		height: 14.2rem;
	}

	.under_ttl {
		width: 27.4rem;
		height: 18.3rem;
	}

	.under_ttl .ja_ttl {
		font-size: 2.6rem;
	}

	.under_ttl_txt {
		padding-top: 13.5rem;
		font-size: 1.8rem;
		line-height: 1.56;
	}

	.custom_ttl_wrap {
		padding: 5.6rem 5rem 6rem;
		border-radius: 5rem 5rem 0 0;
	}

	.custom_ttl_inner {
		gap: 3rem;
	}

	.custom_ttl_hero {
		width: 40vw;
	}

	.custom_ttl_cont_wrap {
		width: calc(100% - 40vw - 3rem);
	}

	.custom_ttl_cont {
		padding-top: 0.6rem;
		padding-bottom: 0.6rem;
		padding-left: 1.5rem;
		border-left: solid 1rem #fff;
	}

	.custom_sub {
		margin-bottom: 1rem;
		font-size: 1.6rem;
	}

	.custom_ttl {
		font-size: 2.8rem;
	}
}

@media screen and (max-width: 880px) {
	.custom_ttl_inner {
		align-items: flex-start;
	}
}

@media screen and (max-width: 840px) {
	.under_ttl_wrap {
		column-gap: 3rem;
	}
	.under_ttl {
		margin-left: -1.8rem;
	}

	.under_ttl_txt {
		width: calc(100% - 3rem - 27.4rem);
	}
}

@media screen and (max-width: 768px) {
	.under_ttl_wrap::after {
		right: -3rem;
	}

	.fixed_btn{
		right: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 5rem;
		margin: auto;
		border-radius: 0;
	}

	.fixed_btn>span{
		padding:0 3rem 0 0;
		font-size: 2rem;
	}

	.fixed_btn>span::before{
		top: 0;
		left: auto;
	}

	.fixed_btn>span>br{
		display: none;
	}

	.custom_ttl_wrap {
		padding-right: 3rem;
		padding-left: 3rem;
	}

	.custom_ttl_hero {
		width: 35vw;
	}

	.custom_ttl_cont_wrap {
		width: calc(100% - 35vw - 3rem);
	}
}

@media screen and (max-width: 640px) {
	.under_ttl_wrap {
		flex-direction: column;
		row-gap: 2rem;
	}

	.under_ttl_txt {
		max-width: none;
		width: 100%;
		padding-top: 0;
	}

	.custom_ttl_inner {
		flex-direction: column;
		align-items: center;
	}

	.custom_ttl_hero {
		max-width: 31.5rem;
		width: 100%;
	}

	.custom_ttl_cont_wrap {
		width: 100%;
	}
}

@media screen and (max-width: 480px) {
	.under_hero {
		height: auto;
		aspect-ratio: 63 / 74;
	}
}

/* ===========================================
	pagination
============================================== */
.pagination_area {
	grid-column: 1 / 3;
	grid-row: 3 / 4;
	background-color: var(--pale_green_color);
}

.pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	height: 18rem;
	font-weight: 500;
}

.pagination span,
.pagination a {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 0.5rem;
	width: auto;
	font-family: 'Roboto', sans-serif;
	font-weight: 500;
	font-size: 1.6rem;
	color: #333;
	text-decoration: none !important;
	text-align: center;
	border-bottom: solid 2px transparent;
}

/* ページ番号 */
.pagination .pager,
.pagination .page-numbers {
	width: 2.4rem;
	height: 2.4rem;
}

/* ホバー時 & 現在のページ */
.pagination a:hover {
	border: solid 2px var(--light_green_color);
	border-radius: 9999px;
}

.pagination .current {
	border-radius: 50%;
	background-color: var(--light_green_color);
}

.pagination a.prev,
.pagination a.next {
	width: 3.6rem;
	height: 3.6rem;
	border-radius: 9999px;
	background-color: #f4dcb2;
}

.pagination a.prev::before,
.pagination a.next::after {
	content: '';
	width: 1.2rem;
	height: 1.17rem;
	background-image: url(../images/common/icon_arrow_right_brown.svg);
	background-position: center;
	background-size: contain;
}

.pagination a.prev::before {
	transform: scale(-1, 1);
}

/* 前へ */
.pagination a.prev {
	margin-right: 2rem;
}

/* 次へ */
.pagination a.next {
	margin-left: 2rem;
}

.pagination a.prev > img,
.pagination a.next > img {
	width: 1rem;
	height: auto;
}

/* Page x / y */
.pagination span.page_num {
	display: none;
}

/* =============
	responsive
================ */
@media screen and (max-width: 1024px) {
	.pagination {
		height: 11.3rem;
	}
}

@media screen and (max-width: 640px) {
	.pagination_area {
		grid-row: 4 / 5;
	}
}

/* ===========================================
	home,single
============================================== */
.post_area {
	padding-bottom: 16rem;
}

.post_inner {
	grid-template-columns: auto 38.3rem;
	grid-template-rows: 20rem auto 18rem;
	border-radius: 6rem 6rem 0 0;
	box-shadow: var(--shadow);
}

.blog_ttl_area {
	grid-column: 1 / 3;
	grid-row: 1 / 2;
	padding: 7rem 5rem 5.4rem;
	border-radius: 6rem 6rem 0 0;
	background-color: var(--pale_green_color);
}

.blog_ttl_area .en_sub {
	margin-bottom: 0.5rem;
	color: var(--gray_color);
}

.post_sidebar {
	grid-column: 2 / 3;
	grid-row: 2 / 3;
	padding: 6rem 2.8rem;
	background-color: #eaf7d2;
}

.post_sidebar_item + .post_sidebar_item {
	margin-top: 4.6rem;
}

.post_sidebar_ttl {
	position: relative;
	margin-bottom: 1.35rem;
	padding-left: 2.4rem;
	color: var(--navy_color);
	font-weight: 500;
	font-size: 2.2rem;
}

.post_sidebar_ttl::before {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 1.3rem;
	height: calc(100% + 1rem);
	margin: auto;
	background-color: var(--navy_color);
	content: '';
}

.post_sidebar_list {
	padding-left: 3rem;
}

.post_sidebar_list > li,
.post_sidebar_list > li > ul > li {
	font-size: 1.6rem;
	line-height: 1.5625;
}

.post_sidebar_list > li.parent {
	font-size: 1.9rem;
}

.year_archive_item .post_sidebar_list > li > ul {
	padding-left: 3rem;
}

.year_archive_item .post_sidebar_list > li > ul > li,
.post-type-archive-splus
	.year_archive_item
	.post_sidebar_list
	> li:not(.archive_parent),
.single-splus .year_archive_item .post_sidebar_list > li:not(.archive_parent) {
	display: flex;
	align-items: center;
}

.post_sidebar_list > li > a,
.post_sidebar_list > li > ul > li > a {
	display: inline-block;
	position: relative;
	padding: 1.05rem 0.5em 1.05rem 2.8rem;
	color: var(--navy_color);
}

.post_sidebar_list > li.parent > a {
	margin-top: 1.35rem;
	margin-bottom: 0.35rem;
	padding-left: 1.45rem;
}

.post_sidebar_list > li > a::before,
.post_sidebar_list > li > ul > li > a::before {
	position: absolute;
	top: 1.05rem;
	left: 0;
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	content: '\f0a9';
}

.post_sidebar_list > li.parent > a::before {
	content: '-';
}

.year_archive_item .post_sidebar_list > li > ul > li > a::before {
	content: '\f061';
}

.year_archive_item .post_sidebar_list > li.archive_parent > a::before {
	content: '\f055';
}

.year_archive_item .post_sidebar_list > li.archive_parent > a.open::before {
	content: '\f056';
}

.post_sidebar_list > li:not(.parent):not(.archive_parent) > a::after,
.post_sidebar_list > li > ul > li > a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 1px;
	background-color: var(--navy_color);
	content: '';
	transition: all 0.4s;
}

.post_sidebar_list > li:not(.parent):not(.archive_parent) > a:hover::after,
.post_sidebar_list > li > ul > li > a:hover::after {
	width: 100%;
}

.article_post_wrap {
	grid-column: 1 / 2;
	grid-row: 2 / 3;
	padding: 5.6rem 5rem 10rem;
	background-color: #fff;
}

.dotted_ttl + .staff_blog_contents {
	margin-top: 5.6rem;
}

.staff_blog_contents {
	grid-template-columns: 1fr 1fr;
	column-gap: 3.8rem;
	width: 100%;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1180px) {
	.post_inner {
		grid-template-columns: auto 32vw;
	}
}

@media screen and (max-width: 1024px) {
	.post_area {
		padding-bottom: 8.7rem;
	}

	.post_inner {
		grid-template-rows: 13.5rem auto 11.3rem;
		border-radius: 5rem 5rem 0 0;
	}

	.blog_ttl_area {
		padding: 5rem 3rem 3rem;
		border-radius: 5rem 5rem 0 0;
	}

	.post_sidebar_ttl {
		font-size: 1.8rem;
	}

	.dotted_ttl + .staff_blog_contents {
		margin-top: 4.3rem;
	}

	.article_post_wrap {
		padding: 6.7rem 3rem 13rem;
	}

	.staff_blog_contents {
		column-gap: 2rem;
	}
}

@media screen and (max-width: 880px) {
	.post_inner {
		grid-template-columns: auto 25.5rem;
	}

	.staff_blog_contents {
		grid-template-columns: 1fr;
	}

	.post_sidebar_list {
		padding-left: 0;
	}
}

@media screen and (max-width: 640px) {
	.post_inner {
		grid-template-columns: 1fr;
		grid-template-rows: 13.5rem auto auto 11.3rem;
	}

	.post_sidebar {
		grid-column: 1 / 2;
		grid-row: 2 / 3;
		padding: 5rem 3rem 0;
		background-color: transparent;
	}

	.post_sidebar_item + .post_sidebar_item {
		margin-top: 3rem;
	}

	.post_sidebar_ttl,
	.post_sidebar_list_wrap {
		padding: 2.1rem 2.3rem 1.8rem;
		background-color: #eaf7d2;
	}

	.post_sidebar_ttl {
		margin-bottom: 0;
	}

	.post_sidebar_ttl::before {
		content: none;
	}

	.post_sidebar_ttl::after {
		position: absolute;
		top: 0;
		right: 0.5rem;
		bottom: 0;
		width: 3rem;
		height: 3rem;
		margin: auto;
		color: var(--orange_color);
		font-weight: 700;
		font-size: 3rem;
		content: '＋';
		transition: all 0.3s;
	}

	.post_sidebar_ttl.open::after {
		transform: rotate(45deg);
	}

	.post_sidebar_list_wrap {
		padding-top: 1rem;
	}

	.article_post_wrap {
		grid-column: 1 / 2;
		grid-row: 3 / 4;
	}
}

@media screen and (max-width: 480px) {
	.post_inner {
		margin-right: -3rem;
		margin-left: -3rem;
	}
}

/* ===========================================
	splus
============================================== */
.post-type-archive-splus .blog_ttl_area,
.single-splus .blog_ttl_area,
.post-type-archive-splus .pagination_area {
	background-color: var(--light_orange_color);
}

.post-type-archive-splus .blog_ttl_area .en_sub,
.single-splus .blog_ttl_area .en_sub {
	color: var(--orange_color);
}

.post-type-archive-splus .post_sidebar,
.single-splus .post_sidebar {
	background-color: #ffeec7;
}

.splus_contents_wrap {
	grid-template-columns: 1fr 1fr;
	grid-auto-rows: 39rem;
	gap: 5.5rem 3.6rem;
}

.post-type-archive-splus .splus_contents {
	padding-top: 2.3rem;
	padding-bottom: 2.3rem;
}

.post-type-archive-splus .splus_cover {
	width: 15.9rem;
	height: 22.3rem;
	margin-bottom: 2.3rem;
}

.splus_btn {
	padding-top: 2.3rem;
	padding-right: 3.9rem;
	font-size: 1.8rem;
	text-align: right;
}

.splus_btn::after {
	top: 2.1rem;
	right: 0;
	bottom: auto;
	width: 2.8rem;
	height: 2.8rem;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1290px) {
	.post-type-archive-splus .post_inner {
		grid-template-columns: auto 28rem;
	}

	.splus_contents_wrap {
		column-gap: 2rem;
	}
}

@media screen and (max-width: 1180px) {
	.splus_ttl {
		height: 6rem;
		padding-right: 1.75rem;
		padding-left: 1.75rem;
		font-size: 2rem;
		text-align: left;
	}

	.splus_ttl::before {
		width: 2.952rem;
		height: 2.296rem;
	}

	.post-type-archive-splus .splus_contents {
		padding: 2rem 1.75rem 2.4rem;
	}

	.splus_btn {
		padding-top: 2rem;
		font-size: 1.7rem;
	}

	.splus_btn::after {
		width: 2.3rem;
		height: 2.3rem;
	}
}

@media screen and (max-width: 1024px) {
	.splus_cover {
		aspect-ratio: 140 / 197;
	}

	.splus_cover > img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
}

@media screen and (max-width: 940px) {
	.splus_contents_wrap {
		grid-template-columns: 1fr;
		row-gap: 6rem;
	}
}

@media screen and (max-width: 640px) {
	.post-type-archive-splus .post_inner {
		grid-template-columns: 1fr;
	}

	.post-type-archive-splus .post_sidebar,
	.single-splus .post_sidebar {
		background-color: transparent;
	}

	.post-type-archive-splus .post_sidebar_ttl,
	.single-splus .post_sidebar_ttl,
	.post-type-archive-splus .post_sidebar_list_wrap,
	.single-splus.post_sidebar_list_wrap {
		background-color: #ffeec7;
	}
}

/* ===========================================
	blog_slide
============================================== */
.blog_slide_area {
	margin: 13.2rem calc(50% - 50vw) 12.2rem;
	padding-top: 7rem;
	padding-bottom: 5.2rem;
	background-color: var(--light_orange_color);
}

.single-daycare .blog_slide_area {
	background-color: var(--pale_green_color);
}

.blog_slide_ttl_wrap {
	text-align: center;
}

.blog_slide_ttl {
	display: inline-block;
	position: relative;
	margin-bottom: 1.3rem;
	padding: 3.2rem 1.3rem 1rem;
	background-image: url(../images/common/dotted_line_brown.svg);
	background-position: center bottom;
	background-size: auto;
	color: #413529;
	font-weight: 500;
	font-size: 3.2rem;
}

.blog_slide_ttl::before,
.blog_slide_ttl::after {
	position: absolute;
	content: '';
	background-position: center;
	background-size: contain;
}

.blog_slide_ttl::before {
	left: -8rem;
	bottom: -1.3rem;
	width: 8rem;
	height: 8.7rem;
	background-image: url(../images/common/blog_slider_ttl_img01.svg);
}

.blog_slide_ttl::after {
	right: -5.386rem;
	bottom: 0;
	width: 5.386rem;
	height: 5.371rem;
	background-image: url(../images/common/blog_slider_ttl_img02.svg);
}

.blog_slider .swiper-wrapper {
	padding-top: 4.6rem;
	padding-bottom: 4.3rem;
	transition-timing-function: linear;
}

.blog_slider .swiper-slide {
	width: 33.9rem;
}

.blog_slider .staff_blog_item > a {
	color: #333;
}

.blog_slider .staff_blog_item .staff_blog_post_ttl_wrap {
	text-align: left;
}

.staff_blog_btn_wrap {
	display: flex;
	justify-content: center;
	width: 17.8rem;
	height: 6.6rem;
	margin-left: auto;
	margin-right: auto;
	border-radius: 9999px;
	box-shadow: var(--shadow);
	background-color: #fff;
}

.staff_blog_btn_next,
.staff_blog_btn_prev {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 8.9rem;
	height: 6.6rem;
}

.staff_blog_btn_next > img {
	transform: scale(-1, 1);
}

.blog_slider .no_post {
	margin-left: auto;
	margin-right: auto;
}

/* ============
	responsive
================ */
@media screen and (max-width: 1024px) {
	.blog_slide_area {
		margin-top: 12rem;
		margin-bottom: 8rem;
		padding-top: 7rem;
		padding-bottom: 7rem;
	}

	.blog_slide_ttl {
		margin-bottom: 0.3rem;
		padding: 2rem 0.6rem 1rem 3.5rem;
		font-size: 2.2rem;
	}

	.blog_slide_ttl::before {
		bottom: -0.3rem;
		left: -2.6rem;
		width: 4.8rem;
		height: 5.3rem;
	}

	.blog_slide_ttl::after {
		right: -3.3rem;
		width: 3.3rem;
		height: 3.2rem;
	}

	.blog_slider .swiper-wrapper {
		padding-top: 5rem;
		padding-bottom: 5rem;
	}

	.blog_slider .swiper-slide {
		width: 31.5rem;
	}

	.staff_blog_btn_wrap,
	.staff_blog_btn_next,
	.staff_blog_btn_prev {
		height: 5.7rem;
	}

	.staff_blog_btn_next,
	.staff_blog_btn_prev {
		width: 9rem;
	}

	.staff_blog_btn_next {
		justify-content: flex-start;
		padding-left: 2.8rem;
	}

	.staff_blog_btn_prev {
		justify-content: flex-end;
		padding-right: 2.8rem;
	}

	.staff_blog_btn_next > img,
	.staff_blog_btn_prev > img {
		width: 1.2rem;
		height: 1.8rem;
	}
}
