/* --------　ABOUT-「ごあいさつ」　-------- */

.greeting_area,
.hadashi_area {
	text-align: center;
}

.greeting_back_cloud {
	position: relative;
}

.greeting_back_cloud::before {
	content: '';
	position: absolute;
	display: inline-block;
	width: 870px;
	height: 545px;
	background: url(../img/about_greeting01.png);
	background-size: contain;
	background-repeat: no-repeat;
	top: -180px;
	left: 0;
}

.greeting_back_cloud::after {
	content: '';
	position: absolute;
	display: inline-block;
	width: 870px;
	height: 550px;
	background: url(../img/about_greeting02.png);
	background-size: contain;
	background-repeat: no-repeat;
	bottom: -200px;
	right: 0;
	z-index: 0;
}

.greeting_p {
	padding-bottom: 80px;
	font-weight: 500;
	position: relative;
	z-index: 1;
}

.greeting_p p {
	font-size: 125%;
	padding-top: 20px;
}

/* --------　ABOUT-「保育目標」　-------- */

.objective_area {
	margin-top: 170px;
}

.objective_box {
	display: flex;
	justify-content: center;
	gap: 70px;
}

.objective_area .page_box {
	position: relative;
}

.objective_area .page_box::after {
	position: absolute;
	content: '';
	display: inline-block;
	width: 80px;
	height: 146px;
	background: url(../img/objective_himawari01.png) center center / contain no-repeat;
	bottom: -20px;
	left: -40px;
	z-index: 0;
}

.objective_area .page_box::before {
	position: absolute;
	content: '';
	display: inline-block;
	width: 150px;
	height: 162px;
	background: url(../img/objective_himawari02.png) center center / contain no-repeat;
	bottom: 0px;
	right: -35px;
	z-index: 0;
}

.objective_box img {
	width: 250px;
	padding-bottom: 15px;
}

.objective_down {
	padding-top: 80px;
}

.slogan_box {
	padding-top: 40px;
}

.slogan_box dl dt {
	font-size: 125%;
	display: inline-block;
	background-color: #FEEFAB;
	border-radius: 10px;
	padding: 5px 60px;
}

.slogan_box dl dt:nth-of-type(2) {
	background-color: #FFE0DB;
	margin-top: 30px;
}

.slogan_box dl dt:nth-of-type(3) {
	margin-top: 30px;
	background-color: #DEEFFF;
	padding: 5px 49px;
}

.slogan_box dl dd {
	text-align: center;
	font-size: 112.5%;
	padding-top: 15px;
	margin-bottom: 0;
}

.sl {
	display: none;
}

/* --------　ABOUT-「はだし保育」　-------- */

.hadashi_area .about_box {
	position: sticky;
	z-index: 2;
}

.h_img img {
	width: 180px;
	height: 100%;
}

.hadashi_box {
	position: relative;
}

.hadashi_p {
	position: absolute;
	top: 0px;
	left: calc(50% - 350px);
}

.hadashi_p p {
	font-size: 112.5%;
	padding-bottom: 20px;
}

.hadashi_p p:last-of-type {
	padding-bottom: 0;
}

.hadashi_merit {
	padding: 30px 0 0;
	max-width: 920px;
	margin: 0 auto;
}

.hadashi_merit h3 {
	font-size: 150%;
	display: block;
	background-color: #FFF2EA;
	padding: 15px 0 15px 45px;
	border-radius: 10px;
	text-align: left;
	position: relative;
}

.hadashi_merit h3::before {
	position: absolute;
	content: '';
	width: 25px;
	height: 25px;
	background: url(../img/hadashi_merit.png) center center / contain no-repeat;
	top: 13px;
	left: 13px;
}

.hadashi_merit dl dt {
	font-size: 125%;
	text-align: left;
	padding: 30px 0 10px 35px;
	position: relative;
}

.hadashi_merit dl dt::before {
	position: absolute;
	content: '';
	width: 25px;
	height: 25px;
	background: url(../img/hadashi_star.png) center center / contain no-repeat;
	top: 36px;
	left: 5px;
}

.hadashi_merit dl dd {
	margin: 0;
	padding: 0 20px 0 35px;
	font-size: 112.5%;
	text-align: left;
}

.hadashi_img {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	width: 100%;
	gap: 40px;
	margin-top: 50px;
	position: relative;
}

.hadashi_img::after {
	position: absolute;
	content: '';
	display: inline-block;
	width: 320px;
	height: 400px;
	background: url(../img/hadashi_back02.png) center center / contain no-repeat;
	bottom: -40px;
	right: -80px;
	z-index: -1;
}

.hadashi_img img {
	width: 440px;
}

.ha,
.ol {
	display: none;
}

/* --------　ABOUT-「概要」　-------- */

.outline_list .dd_car img {
	padding-top: 20px;
	width: 80%;
	max-width: 100%;
	box-sizing: border-box;
}

/* --------　ABOUT-「入退園案内」　-------- */

.history_area .page_box {
	padding-bottom: 0px;
	margin-bottom: 0;
}

.guidance_area {
	font-weight: bold;
}

.history_area .page_box .about_h2 {
	padding-top: 70px;
}

.guidance_imgbox {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.guidance_img {
	width: 50%;
}

.guidance_p,
.guidance_out_p,
.guidance_add {
	text-align: justify;
	width: 50%;
}

.guidance_img img {
	width: 250px;
}

/* --------　「入園」　-------- */

.guidance_p p {
	padding-top: 25px;
}

.guidance_box {
	border-radius: 20px;
	padding: 25px 20px 50px;
	margin-bottom: 50px;
}

.guidance_box.in {
	background: #FFFAFC;
	margin-top: 20px;
}

.guidance_h3 {
	font-size: 150%;
	margin-bottom: 30px;
	padding: 10px;
	background: #FFE0DB;
	border-radius: 14px;
}

.guidance_box.in .guidance_imgbox .guidance_img img {
	padding-top: 30px;
}

.page_box .guidance_a a {
	width: 400px;
	background: #ffffff;
	padding: 10px 30px 10px 25px;
	border: 2px solid #F9B8D6;
	border-radius: 20px;
	text-align: center;
	transition: 0.5s;
	display: grid;
	position: relative;
}

.guidance_a a::before {
	content: '';
	width: 18px;
	height: 16px;
	background: url(../img/guidance_menu.png) center center / contain no-repeat;
	position: absolute;
	top: 30px;
	right: 20px;
	transition: 0.5s;
}

.guidance_a a:hover:before {
	right: 15px;
}

.page_box .guidance_a a:hover {
	background-color: #FFF2F8;
}

/* --------　「退園」　-------- */

.guidance_box.out {
	background: #F8FDFF;
}


.guidance_box.out .guidance_h3 {
	background: #DEEFFF;
}

/* --------　「里庄町」　-------- */

.guidance_box.satosho {
	background: #F6FFEA;
	margin-bottom: 20px;
}

.guidance_box.satosho .guidance_h3 {
	background: #E2FAB8;
}

.guidance_add .guidance_dl {
	display: flex;
	flex-wrap: wrap;
	text-align: left;
	gap: 10px 40px;
	width: 340px;
}

.guidance_dl .dd_tel {
	padding-right: 60px;
}

/*********** ごあいさつ レスポンシブ ***********/

@media (max-width: 991px) {

	.greeting_back_cloud::before {
		width: 700px;
		height: 440px;
		top: -100px;
	}

	.greeting_back_cloud::after {
		width: 700px;
		height: 425px;
		bottom: -130px;
	}

	.greeting_p {
		padding-bottom: 0;
	}

	.greeting_p p {
		font-size: 112.5%;
		letter-spacing: 0.05em;
	}
}

@media (max-width: 767px) {

	.greeting_p p br {
		display: none;
	}
}

@media (max-width: 699px) {

	.greeting_back_cloud::before {
		width: 400px;
		height: 250px;
		top: -60px;
	}

	.greeting_back_cloud::after {
		width: 400px;
		height: 250px;
	}
}


@media (max-width: 575px) {

	.greeting_p {
		text-align: left;
	}

	.greeting_p p {
		font-size: 100%;
	}
}

@media (max-width: 400px) {

	.greeting_back_cloud::before {
		width: 250px;
		height: 155px;
		top: -40px;
	}

	.greeting_back_cloud::after {
		width: 250px;
		height: 160px;
		bottom: -115px;
	}
}

/*********** 保育目標 レスポンシブ ***********/

@media (max-width:1199px) {

	.sl {
		display: block;
	}

	.sl_n {
		display: none;
	}

	.objective_area .page_box::before {
		right: 5px;
	}

	.objective_area .page_box::after {
		left: 0;
	}
}

@media (max-width:991px) {

	.objective_box {
		gap: 20px;
	}

	.objective_box div {
		width: 100%;
	}

	.objective_box img {
		width: 170px;
	}

	.objective_down {
		padding-top: 50px;
	}

	.objective_box br {
		display: none;
	}

	.objective_area .page_box::before {
		width: 100px;
		height: 110px;
	}

	.objective_area .page_box::after {
		width: 60px;
		height: 90px;
		bottom: 0px;
	}
}

@media (max-width: 767px) {

	.objective_area {
		margin-top: 100px;
	}

	.objective_box {
		display: block;
	}

	.objective_down {
		padding-top: 0;
	}

	.objective_box div {
		padding-bottom: 30px;
	}

	.objective_box br {
		display: block;
	}

	.sl_n {
		display: block;
	}

	.objective_area .page_box::after {
		left: -20px;
		bottom: -30px;
	}

	.objective_area .page_box::before {
		right: -30px;
		bottom: -25px;
	}

	.slogan_box dl dd {
		font-size: 100%;
	}
}

@media (max-width: 575px) {

	.objective_area .page_box::before {
		width: 80px;
		height: 90px;
		right: 10px;
		bottom: -15px;
	}

	.objective_area .page_box::after {
		left: 0px;
		bottom: -10px;
		width: 50px;
		height: 80px;
	}
}

@media (max-width: 500px) {

	.objective_area .page_box::before {
		width: 60px;
		height: 70px;
	}

	.objective_area .page_box::after {
		bottom: -15px;
		width: 40px;
		height: 65px;
	}
}

@media (max-width: 461px) {

	.slogan_box {
		padding-top: 40px;
		text-align: left;
	}

	.slogan_box dl dd {
		text-align: left;
	}

}

@media (max-width: 425px) {

	.objective_area .about_h2 span {
		padding-bottom: 20px;
	}

	.objective_box {
		padding-top: 20px;
	}

	.slogan_box dl dt {
		font-size: 112.5%;
	}

	.slogan_box dl dt {
		padding: 5px 30px;
	}

	.slogan_box dl dt:nth-of-type(3) {
		padding: 5px 20px;
	}
}

@media (max-width: 383px) {

	.sl {
		display: none;
	}
}

/*********** はだし保育 レスポンシブ ***********/

@media (max-width: 1290px) {
	.hadashi_img::after {
		bottom: 70px;
		right: -30px;
	}
}

@media (max-width: 1199px) {
	.hadashi_img::after {
		width: 210px;
		height: 280px;
		bottom: -70px;
		right: 10px;
		transform: rotate(15deg);
		z-index: 1;
		opacity: 0.5;
	}
}

@media (max-width: 991px) {

	.hadashi_p {
		left: calc(50% - 315px);
	}

	.hadashi_p p {
		font-size: 100%;
	}

	.hadashi_img img {
		width: 300px;
	}

	.hadashi_img::after {
		width: 160px;
		height: 210px;
		bottom: -30px;
		right: -10px;
		transform: rotate(0deg);
	}
}

@media (max-width: 767px) {

	.ha {
		display: block;
	}

	.ha_p {
		display: none;
	}

	.hadashi_p {
		left: calc(50% - 202px);
	}

	.h_img img {
		padding-top: 30px;
	}

	.hadashi_merit h3 {
		font-size: 125%;
	}

	.hadashi_merit h3::before {
		top: 9px;
	}

	.hadashi_merit {
		padding: 70px 0 0;
	}

	.hadashi_merit dl dt {
		font-size: 112.5%;
		padding: 20px 0 5px 35px;
	}

	.hadashi_merit dl dt::before {
		top: 24px;
	}

	.hadashi_merit dl dd {
		font-size: 100%;
	}

	.hadashi_img {
		gap: 20px;
		margin-top: 30px;
	}

	.hadashi_img img {
		width: 240px;
	}

	.hadashi_img::after {
		right: -40px;
	}
}

@media (max-width: 600px) {

	.hadashi_img::after {
		width: 120px;
		height: 150px;
		bottom: -60px;
		right: 10px;
		transform: rotate(30deg);
	}
}

@media (max-width: 575px) {

	.hadashi_img::after {
		width: 100px;
		height: 130px;
		right: 40px;
		bottom: -50px;
	}
}

@media (max-width: 523px) {

	.hadashi_img img {
		width: 200px;
	}
}

@media (max-width: 485px) {
	.ol {
		display: block;
	}
}


@media (max-width: 461px) {

	.hadashi_p p {
		text-align: left;
		padding-bottom: 10px;
	}
}

@media (max-width: 443px) {

	.hadashi_img img {
		width: 170px;
	}
}

@media (max-width: 430px) {

	.ha {
		display: none;
	}
}

@media (max-width: 425px) {

	.greeting_area .about_h2 span,
	.hadashi_area .about_h2 span {
		padding-bottom: 40px;
	}

	.hadashi_p {
		left: calc(50% - 200px);
		padding-left: 10px;
		padding-top: 15px;
	}

	.hadashi_merit h3 {
		font-size: 112.5%;
	}

	.outline_area .about_h2 span {
		padding-bottom: 0px;
	}

	.guidance_area .about_h2.guidance span {
		padding-bottom: 30px;
	}
}

@media (max-width: 400px) {

	.hadashi_p {
		padding-left: 20px;
	}
}

@media (max-width: 375px) {

	.hadashi_p {
		padding-left: 30px;
	}

	.hadashi_img img {
		width: 70%;
	}
}

@media (max-width: 350px) {

	.hadashi_p {
		padding-left: 40px;
	}
}

@media (max-width: 337px) {

	.hadashi_merit {
		padding: 140px 0 0;
	}

	.hadashi_p {
		padding-left: 50px;
	}
}

/*********** 園の概要 レスポンシブ ***********/

@media (max-width: 767px) {

	.outline_list .dd_car img {
		width: 100%;
	}
}

/*********** 入退園案内 レスポンシブ ***********/

@media (max-width: 1199px) {

	.guidance_img {
		width: 40%;
	}
}

@media (max-width: 991px) {

	.guidance_box.in .guidance_imgbox .guidance_img img {
		padding-top: 0;
		padding-bottom: 20px;
	}

	.guidance_img {
		margin: 0 auto;
	}

	.guidance_p,
	.guidance_out_p,
	.guidance_add {
		width: 100%;
		text-align: center;
	}

	.guidance_out_p {
		padding-top: 20px;
	}

	.page_box .guidance_a {
		display: flex;
		justify-content: center;
	}

	.guidance_add {
		display: flex;
		justify-content: center;
		padding-top: 20px;
	}

	.guidance_dl dd {
		line-height: 1.5;
		margin-bottom: 0;
	}
}

@media (max-width: 767px) {

	.page_box .guidance_a a {
		width: 100%;
	}

	.guidance_img {
		width: 100%;
	}

	.guidance_img img {
		width: 200px;
	}

	.page_box .guidance_a a {
		padding: 10px 25px 10px 15px;
	}
}

@media (max-width: 575px) {

	.page_box .guidance_a {
		width: 100%;
	}

	.guidance_h3 {
		margin-bottom: 30px;
		font-size: 125%;
	}
}

@media (max-width: 461px) {

	.guidance_p br,
	.guidance_out_p br {
		display: none;
	}

	.guidance_p p {
		text-align: left;
	}

	.guidance_out_p {
		text-align: left;
	}

	.guidance_add .guidance_dl {
		display: block;
	}

	.guidance_dl dt {
		padding-top: 10px;
	}

	.guidance_dl dd {
		padding-left: 10px;
	}
}

@media (max-width: 425px) {

	.guidance_box {
		margin-bottom: 20px;
	}
}

@media (max-width: 375px) {

	.guidance_a a::before {
		right: 13px;
		top: 46px;
	}

	.guidance_a a:hover:before {
		right: 8px;
	}
}