@charset "utf-8";
/* ===================================================================
CSS information

  file name  : sp.css
  style info : スマートフォン用
=================================================================== */
body {
    overflow-y: clip;
}

.inner {
    width: 96%;
    min-width: auto;
    max-width: none;
}
footer .flex {
    display: block;
}
footer .flex a.flex {
    display: flex;
}
footer .flex div {
    text-align: center;
        margin-top: 10px;
}
.banner_footer {
    width: 100%;
    max-width: 100%;
}

footer .flex div a img {
    margin: auto;
}

footer .flex .banner_footer a img {
        margin: auto;
        display: block;
        float: none;
        margin-top: 20px;
        margin-bottom: 20px;
}

a.gmap {
    margin: auto;
    margin-top: 10px;
}

html.fixed,
html.fixed body {
  overflow: hidden;
}

footer .inner .flex div div:nth-child(1) li a {
    font-size: 14px;
}

footer .flex div.flex {
    flex-wrap: wrap;
    display: flex;
}

footer .flex div.flex div:nth-child(1) div,footer .flex div.flex div:nth-child(2) div,footer .flex div.flex div:nth-child(3) div,footer .flex div.flex div:nth-child(4) div{
    width:auto;
}
footer .flex div.flex div:nth-child(1){ width: 130px;}
footer .flex div.flex div:nth-child(1),footer .flex div.flex div:nth-child(2),footer .flex div.flex div:nth-child(3),footer .flex div.flex div:nth-child(4) {
    text-align: left;
}
footer .flex div.flex {
    display: flex;
    flex-wrap: wrap;
}
footer .inner .flex div div:nth-child(1) a img {
    margin-left: 0;
}


footer .flex div .flex div {
        width: max-content;
}
footer .flex .banner_footer div a {
    margin-left: 10px;
    font-size: 15px;
}
       



/* -----------------------------------------------------------
    top
----------------------------------------------------------- */


@media screen and (max-width: 1200px) {

.top__acquisition-plan-wrap {
    display: block;
}

section.top__acquisition-wrap .top__acquisition-plan__ttl {
    position: absolute;
    top: 0;
    right: 0;
}

.top__acquisition-plan-list-wrap {
    width: 100%;
}

section.top__acquisition-wrap .top__acquisition-plan__ttl.second {
  
}

.top__acquisition-plan-list-wrap .imgWrap {
    max-width: 300px;
    margin-left: auto;
    margin-right: auto;
}

}







@media screen and (max-width: 1000px) {

.top__acquisition-plan-list_co dd .moreLink {
    margin: auto;
}

.top__acquisition-plan-list-wrap li:last-child {
    max-width: 100%;
    width: 100%;
    margin: auto;
    margin-top: 50px;
}
.top__acquisition-plan__ttl {
            font-size: 23px;
            height: 245px;
            margin-left: 2%;
            padding: 38px 10px;
            width: max-content;
            width: 42px;
            left: 0;
            right: 0;
            text-align: center;
            writing-mode: rl;
}
.top__staff-co-wrap .moreLink {
    width: 200px;
    margin-top: 35px;
}
.top__staff-wrap .top__staff-co-wrap .moreLink {
    width: 280px;
    font-size: 16px;
}
.top__staff-slider-wrap .staff_slide-wrap {
    width: 330px;
}
section.top__aboutContents-wrap { margin-top: 70px; margin-bottom: 70px; }
section.top__introduction-wrap { padding-bottom: 70px; }
section.top__about-wrap ul { margin-bottom: 0; }

section.top__aboutContents-wrap .inner div a {
    margin-left: auto;
    margin-top: 15px;
}
body {
    font-size: 15px;
}
section.top__introduction-wrap h2.flex {
    font-size: 30px;
}
.mv-wrap .news {
    bottom: 8%;
}
section.top__about-wrap ul li p.title {
    left: 15px;
    font-size: 20px;
    height: 190px;
}
}

section.top__introduction-wrap h2.flex:before {
  content: url(../img/top/hata1.png);
  vertical-align: middle;
  padding-right: 5px;
  width: 150px;
  overflow: hidden;
}

section.top__introduction-wrap h2.flex:after {
  content: url(../img/top/hata2.png);
  vertical-align: middle;
  padding-left: 5px;
  width: 150px;
  overflow: hidden;
}


section.top__aboutContents-wrap .inner div {
    display: block;
}
section.top__aboutContents-wrap .inner div p {
    width: 100%;
}
section.top__aboutContents-wrap .inner {
    position: relative; /* 追加 */
}
.mv-wrap .news {
    right: 1%;
}

.right_banner a {
    padding-top: 10px;
    padding-bottom: 10px;
}

.right_banner a img {
    height: 129px;
}

.right_banner {
    width: 55px;
}
p.line {
    font-size: 16px;
}

section.top__introduction-wrap ul li a img.obtn {
    width: 25px;
    bottom: 10px;
}

p.line:before,p.line:after {
    top: 20px;
}

section.top__about-wrap img.panda {
    width: 270px;
}

section.top__introduction-wrap .inner {
    padding: 10px;
    padding-bottom: 120px;
    overflow-y: hidden;
    padding-top: 60px;
}

section.top__about-wrap img.animal_img {
    width: 150px;
    right: 40px;
}
section.top__introduction-wrap .inner img.hay {
    width: 135px;
    bottom: 10px;
    right: 37%;
    left: auto;
    display: block;
    margin: auto;
}
section.top__introduction-wrap ul li {
    width: 46%;
}
section.top__introduction-wrap img.tree01 {
        width: 50px;
        z-index: 9;
}
section.top__introduction-wrap img.balloon {
    width: 128px;
    left: 0;
    top: -60px;
}
section.top__introduction-wrap img.tree03 {
    top: -73px;
    width: 87px;
    right: 10px;
        z-index: 9;
}


/* -----------------------------------------------------------
    toggle-panel
----------------------------------------------------------- */

/* -----------------------------------------------------------
    meanmenu
----------------------------------------------------------- */
header#header {
    background: #fff;
    z-index: 999;
    width: 100%;
    top: 0;
}
#h_top{
	padding: 5px 0 0;
}
.h_logo{
	width: 115px;
	position: relative;
	z-index: 9999;
	margin-left: 15px;
}
a.meanmenu-reveal{
	display:none;
}
.fixed {
	position: fixed;
	width: 100%;
	height: 100%;
	z-index: 1;
}
#header .mask {
	top: 60px;
	left: 0;
	z-index: 1;
	position: absolute;
	width: 100%;
	height: 100vh;
	opacity: 1;
	display: none;
}
.mean-container .mean-bar {
	width: 100%;
	background: none;
	z-index: 98;
	top: 0;
	left: 0;
}
.meanmenu-reveal-btn {
  position: absolute;
  display: block;
  z-index: 9;
  box-sizing: border-box;
  width: 60px;
  height: 60px;
  right: 0;
  top: 0;
}
.meanmenu-reveal {
  width: 26px;
  height: 20px;
  margin: 13px 17px 27px 17px;
  display: block !important;
  position: relative;
}
.meanmenu-reveal:after {
	content: "MENU";
	position: absolute;
	bottom: -20px;
	color: #fe9166;
	font-size: 10px;
	width: 60px;
	left: -17px;
	text-align: center;
	display: block;
	font-family:serif;
}
.meanmenu-reveal.meanclose:after {
	content: "CLOSE";
}
.meanmenu-reveal span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  margin: 0 auto;
}
.meanmenu-reveal span:nth-of-type(1) {
  top: 0;
  background: #fe9166;
}
.meanmenu-reveal span:nth-of-type(2) {
  top: 8px;
  background: #fe9166;
}
.meanmenu-reveal span:nth-of-type(3) {
  top: 16px;
  background: #fe9166;
}
.meanmenu-reveal  span:nth-of-type(1) {
  -webkit-animation: menu-ber01 .75s forwards;
  animation: menu-ber01 .75s forwards;
}
.meanmenu-reveal  span:nth-of-type(2) {
  transition: all .25s .25s;
  opacity: 1;
}
.meanmenu-reveal  span:nth-of-type(3) {
  -webkit-animation: menu-ber02 .75s forwards;
  animation: menu-ber02 .75s forwards;
}
.meanclose span:nth-of-type(1) {
  -webkit-animation: active-menu-ber01 .75s forwards;
  animation: active-menu-ber01 .75s forwards;
  top: -2px;
}
.meanclose span:nth-of-type(2) {
  opacity: 0;
}
.meanclose span:nth-of-type(3) {
  -webkit-animation: active-menu-ber03 .75s forwards;
  animation: active-menu-ber03 .75s forwards;
}
@-webkit-keyframes menu-ber01 {
  0% {
    -webkit-transform: translateY(8px) rotate(45deg);
  }
  50% {
    -webkit-transform: translateY(8px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(0);
  }
}
@keyframes menu-ber01 {
  0% {
    transform: translateY(8px) rotate(45deg);
  }
  50% {
    transform: translateY(8px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
@-webkit-keyframes menu-ber02 {
  0% {
    -webkit-transform: translateY(-8px) rotate(-45deg);
  }
  50% {
    -webkit-transform: translateY(-8px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(0);
  }
}
@keyframes menu-ber02 {
  0% {
    transform: translateY(-8px) rotate(-45deg);
  }
  50% {
    transform: translateY(-8px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
@-webkit-keyframes active-menu-ber01 {
  0% {
    -webkit-transform: translateY(0) rotate(0);
  }
  50% {
    -webkit-transform: translateY(10px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(10px) rotate(45deg);
  }
}
@keyframes active-menu-ber01 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(10px) rotate(0);
  }
  100% {
    transform: translateY(10px) rotate(45deg);
  }
}
@-webkit-keyframes active-menu-ber03 {
  0% {
    -webkit-transform: translateY(0) rotate(0);
  }
  50% {
    -webkit-transform: translateY(-8px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(-8px) rotate(-45deg);
  }
}
@keyframes active-menu-ber03 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(-8px) rotate(0);
  }
  100% {
    transform: translateY(-8px) rotate(-45deg);
  }
}
header h1, header p.logo{
	width: auto;
	position: absolute;
	left: 0;
	z-index: 100;
}
.mean-container .mean-nav{
	margin-top: 50px;
	max-height: 100vh;
	overflow-y:auto;
}
.mean-container .mean-nav > ul{
	padding: 0;
	margin: 0;
	width: 100%;
	list-style-type: none;
	-webkit-overflow-scrolling:touch;
	position: relative;
	z-index: 99;
	max-height: 100vh;
	max-height: calc(100vh - 60px);
	background: #fe9166;
}
.mean-container .mean-nav ul ul{
	padding-bottom:0;
	margin-bottom:0;
}
.mean-container .mean-nav ul li{
	position:relative;
	width:100%;
	box-sizing: border-box;
	border-bottom: 1px solid #FFF;
	background: #fe9166;
}
.mean-container .mean-nav ul li ul li{
        background: #ffdd8d;
}
.mean-container .mean-nav ul li a,.mean-container .mean-nav ul li span.pre{
	display:block;
	width:100%;
	padding:1em;
	text-decoration:none;
	color: #000;
	box-sizing: border-box;
}
.mean-container .mean-nav ul li a,.mean-container .mean-nav ul li span{
	font-size: 14px;
}
.mean-container .mean-nav ul li a{
	padding: 10px;
        color: #fff;
        display: inline-block;
        padding-left: 20px;
}
.mean-container .mean-nav ul li li a{
	width:100%;
	padding:1em 10%;
	text-shadow:none !important;
	visibility:visible;
	padding-left: 4%;
	font-size: 13px;
        padding-left: 34px;
}
.mean-container .mean-nav ul li.mean-last a{
	border-bottom:none;
	margin-bottom:0;
}
.mean-container .mean-nav ul li li li a{
	width:70%;
	padding:1em 15%;
}
.mean-container .mean-nav ul li li li li a{
	width:60%;
	padding:1em 20%;
}
.mean-container .mean-nav ul li li li li li a{
	width:50%;
	padding:1em 25%;
}
.mean-container .mean-nav ul li a:hover{
	background:#252525;
	background:rgba(255,255,255,0.1);
}
.mean-container .mean-nav ul li a.mean-expand{
	width: 100%;
	height: 39px;
	position:absolute;
	right:0;
	top: 0px;
	padding: 0.2em;
	font-size: 20px;
	color: #FFF;
	line-height: 30px;
	text-align: right;
	margin: 0;
	padding-top: 0.5%;
	padding-right: 3%;
}
.mean-container .mean-nav ul li a.mean-expand:hover {
  /* background:#43AEE2; */
  color: #fff;
}
.mean-container .mean-nav ul li a img {
    float: left;
    margin-right: 10px;
    height: 20px;
}

.mean-container .mean-nav ul li.saiyo {
    background: #39b9ad;
}
.mean-container .mean-nav ul li.h_comm {
    background: #fc7d74;
}
.mean-container .mean-push {
  float:left;
  width:100%;
  padding:0;
  margin:0;
  clear:both;
}
.mean-nav .wrapper{
  width:100%;
  padding:0;
  margin:0;
}
.mean-container .mean-bar, .mean-container .mean-bar *{
  -webkit-box-sizing:content-box;
  -moz-box-sizing:content-box;
  box-sizing:content-box;
}
.mean-remove{
  display:none !important;
}
.mean-container .mean-nav ul.sub-menu{
	background: #EEE;
}
.mean-container .mean-nav ul.sub-menu a{
	color: #333;
}
/*.mean-container .mean-nav ul li:nth-of-type(6) a{
	width: auto;
}*/
	#gNav{
		display: block;
	}

@media all and (-ms-high-contrast: none){
	ul.flex li, .flex > div, .intro figure{
		display: inline-block !important;
		vertical-align: top;
	}
	

}


.headerMenu {
	margin: 0 auto;
	display: flex;
}
@media all and (-ms-high-contrast: none){
	.headerMenu{
		width: 158%;
		display: inline-block;
	}
}
.headerMenu .nav {
    -webkit-justify-content: flex-start;
    -moz-justify-content: flex-start;
    justify-content: flex-start;
}
.headerMenu .nav > li{
	width: 167px;
	height: 87px;
	line-height: 87px;
}
.headerMenu .nav > li:nth-child(2){
	width: 238px;
}
.headerMenu .nav > li:nth-child(3){
	width: 212px;
}
.headerMenu .nav > li {
	float: none !important;
}
.headerMenu ul.menu_buttan:nth-child(1) > li{
	padding-left: 0;
	padding-right: 0;
}
.headerMenu .nav > li > a {
	position: relative;
	top: 10px;
}
.headerMenu .nav > li.contact > a{
	position: static;
}
.headerMenu .nav li a{
	line-height: 1.3;
}
.headerMenu .nav > li::before{
	position: relative;
	top: 10px;
}
.headerMenu .nav > li:nth-child(1):hover::after,
.headerMenu .nav > li:nth-child(2):hover::after,
.headerMenu .nav > li:nth-child(4):hover::after{
	content: '▲';
	display: block;
	font-size: 20px;
	color: #fe9166;
	position: absolute;
	top: 30px;
	left: 45%;
}
/*.headerMenu .nav > li:nth-child(1)::before{
	content: url(../img/common/icon01.png);
}*/
.headerMenu .nav li a span span{
	display: block;
}
.headerMenu .nav > li:hover > a {/*layer-1*/

	display: inline-block;
}
.headerMenu .nav > li > ul {
	width: 230px;
	display: none;
	position: relative;
	top: -8px;
	left: 0;
	background: #fe9166;
}
.headerMenu .nav > li:nth-child(2) > ul{
	position: relative;
	left: 10%;
}
.headerMenu .nav li ul li{

}
.headerMenu .nav li ul li a{
	display: block;
	padding: 10px;
    padding-left: 20px;
	color: #FFF;
        padding-right: 5px;
}
.headerMenu .nav li ul li a:hover{
	color: #333;
	opacity: 1;
}
.headerMenu .nav li ul li a::before{
    content: url(../img/common/arrow_wht.png);
    padding-right: 10px;
    display: inline-block;
}
.headerMenu .nav li ul li a:hover::before{
    content: url(../img/common/arrow.png);
}
.nav > li li:hover > a {/*layer-2*/
  background: #F8F0E0;
	color: #333;
}
.menuAdjust > a{
    line-height: 1.5 !important;
    text-indent: -0.75em;
    padding-left: 3em !important;
}
ul.tezyun img {
    height: 170px;
    margin: auto;
}
p.form_link a {
    display: inline-block;
    color: #f39992;
    text-decoration: revert;
    margin-left: 5px;
    margin-right: 5px;
}
p.form_link { margin-top: 15px; }
.page-id-1590 .childcare .lifeBox#afternoonnap { margin-top: 0; }

#overview.layout01>div.under {
    margin-top: 15px;
}
#overview.layout01>div.under .left, #overview.layout01>div.under .right {
    margin: auto;
}

#panel-btn {
  display: block;
  width: 30px;
  height: 30px;
  position: absolute;
  right: 2vw;
  cursor: pointer;
  z-index: 1000;
  transform: translateX(0);
  transition: transform .5s;
}

#panel-btn-icon {
  background-color: #151515;
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  width: 30px;
  height: 2px;
  transition: .2s;
}

#panel-btn-icon:before,
#panel-btn-icon:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  width: 30px;
  height: 2px;
  margin-left: 0;
  transition: .3s;
}

#panel-btn-icon:before {
  background-color: #151515;
  margin-top: -11px;
}

#panel-btn-icon:after {
  background-color: #151515;
  margin-top: 9px;
}

#panel-btn .close {
  background-color: transparent;
}

#panel-btn .close:before,
#panel-btn .close:after {
  background-color: #ffffff;
  margin-top: 0;
  width: 30px;
}

#panel-btn .close:before {
  transform: rotate(-45deg);
}

#panel-btn .close:after {
  transform: rotate(-135deg);
}

#panel-btn.active {
  transform: translateX(-350px);
}

.overlay {
  background-color: rgba(0, 0, 0, 0.7);
  content: "";
  display: block;
  height: 0;
  width: 0;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 999;
  opacity: 0;
  transition: opacity .5s;
}

.overlay.open {
  opacity: 1;
  height: 100vh;
  width: 100%;
}


/* -----------------------------------------------------------
    #g_nav
----------------------------------------------------------- */
#g_nav {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  color: #ffffff;
  background: rgba(0,0,0,.9);
  transition: all 0.2s ease-in-out 0s;
  visibility: hidden;
  opacity: 0;
  z-index: 999;
  padding: 15%;
}

.open #g_nav {
  transition: all 0.2s ease-in-out 0s;
  visibility: visible;
  opacity: 1;
}

#g_nav a:link,
#g_nav a:visited,
#g_nav a:hover,
#g_nav a:active {
  color: #ffffff;
}

@media screen and (max-width: 810px) {

section.top__introduction-wrap {
    padding-top: 50px;
}
section.top__introduction-wrap img.balloon {
    top: 0px;
}
section.top__introduction-wrap img.tree01 {
    top: 0;
}
section.top__introduction-wrap img.tree03 {
    top: 0;
}


.mv-slider .slick-img img.pcNone {
    display: none;
}

.mv-slider .slick-img img.spNone {
    display: block;
}

.banner_footer ul {
    justify-content: center;
}

.banner_footer ul li a {
    margin: 20px;
}

.top__acquisition-wrap .halfway-wrap img.triple_baby {
    width: 170px;
    bottom: -37px;
}

footer small {
    text-align: center;
    font-size: 12px;
}
.spNone{
	display: block;
}
.pcNone{
	display: none;

}
.mv-wrap .news{
	display:none;
}

.news.spNone {
            width: max-content;
            z-index: 9;
            background: #fff;
            border-radius: 25px;
            max-width: 90%;
            right: 10%;
            padding: 20px 25px;
            margin: auto;
}
.news.spNone div span {
    border: 1px solid #F08A00;
    display: block;
    text-align: center;
    border-radius: 20px;
    color: #F08A00;
    font-size: 12px;
    margin-top: 5px;
    width: 100px;
    margin-left: 10px;
margin-top: 0;
}
.news.spNone div a {
    font-size: 16px;
}
.news.spNone div {
    display: flex;
}



section.news_bak.spNone {
    background: #f1f2cd;
    padding-bottom: 50px;
}
.news.spNone div, .news.spNone a {
    font-size: 14px;
}

section.top__about-wrap ul li p.title {
    padding: 19px 7px;
    font-size: 20px;
    max-height: max-content;
}
.top__acquisition-plan-wrap img.baby {
    right: -45px;
    width: 158px;
    top: -76px;
}
.right_banner{display:none}

section.top__about-wrap img.animal_img {
    width: 150px;
    right: 40px;
}
.top__staff-wrap img.ehon {
    width: 200px;
}


footer .inner .flex div div ol li {
    width: max-content;
    margin-left: 30px;
}
footer .inner div .flex div:nth-child(1) {
    width: max-content;
    text-align: left;
}
footer .flex div .flex {
    width: max-content;
    margin: auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 376px;
    margin-top: 30px;
}

footer .flex div .flex div {
    width: 49%;
}

footer .inner .flex div div:nth-child(1) li a {
    font-size: 14px;
}

footer .flex div.flex {
    flex-wrap: wrap;
    display: flex;
}
footer .flex div.flex div:nth-child(1),footer .flex div.flex div:nth-child(2),footer .flex div.flex div:nth-child(3),footer .flex div.flex div:nth-child(4) {
    width: 49%;
    text-align: left;
}
footer .flex div.flex {
    display: flex;
    flex-wrap: wrap;
}
footer .inner .flex div div:nth-child(1) a img {
    margin-left: 0;
}

section.top__aboutContents-wrap a .a_title {
    width: 300px;
}
}

@media screen and (max-width: 520px) {
section.top__introduction-wrap img.tree01 {
    left: 45%;
    width: 10%;
}
footer .inner .flex div div:nth-child(1) a {
    width: 100%;
    justify-content: flex-start;
}
.top__acquisition-plan-list-wrap li:last-child a img {
    width: auto;
}
.top__acquisition-plan-list-wrap li:last-child img {
    width: 200px;
    height: auto;
}
section.top__about-wrap img.animal_img {
    top: -56px;
}
section.top__acquisition-wrap .top__acquisition-plan__ttl.second {
    max-height: 300px;
    padding-bottom: 30px;
}
    section.top__acquisition-wrap .top__acquisition-plan__ttl.second {
        right: 65px;
            margin-top: 70px;
    }
.top__acquisition-plan-list_co dl dt span {
    font-size: 23px;
}

.top__acquisition-plan-list_co dl dt small {
    font-size: 14px;
}
section.top__introduction-wrap h2.flex:before {
  width: 50px;
  overflow: hidden;
}
section.top__introduction-wrap h2.flex img {
    margin-left: 5px;
    margin-right: 5px;
}
section.top__introduction-wrap h2.flex:after {
  width: 50px;
  overflow: hidden;
}
section.top__introduction-wrap .inner img.hay {
    width: 40%;
    left: 30%;
}
.footer__pageTop {
    width: 60px;
    bottom: 10px !important;
    right: 10px;
}

section.top__introduction-wrap h2.flex span {
            font-size: 20px;
            width: 130px;
            text-align: center;
}
section.top__introduction-wrap h2.flex {
    font-size: 30px;
}
.slick-initialized .slick-slide {
    width: 270px;
}
section.top__aboutContents-wrap a .a_title {
    width: 220px;
z-index: 2;
}
        .top__acquisition-plan__ttl {
            margin-left: auto;
        }
.top__staff-slider-wrap {
    margin-left: 2%;
}


} 

@media screen and (max-width: 400px) {

header .logo {
    width: 280px;
}
} 


/* -----------------------------------------------------------
  志陽会について
----------------------------------------------------------- */
#about .philosophy_sec {
  container-name: philosophy_sec;
  container-type: inline-size;
}
@container philosophy_sec (width < 768px) {
  #about .philosophy_sec {
    .thumb {
      aspect-ratio: 1316 / 415;
      border-radius: 30px;
      margin: 0 0 45px;
    }
    .subttl {
      font-size: 2rem;
      margin: 0 0 30px;
    }
    .philosophy_items {
      display: grid;
      grid-template-columns: repeat(1,1fr);
      gap: 30px;
    }
  }
}
@container philosophy_sec (width < 620px) {
  #about .philosophy_sec {
    .thumb {
      aspect-ratio: 6 / 3;
      border-radius: 20px;
      margin: 0 0 25px;
    }
    .subttl {
      font-size: 1.8rem;
      margin: 0 0 20px;
    }
    .philosophy_items {
      gap: 20px;
      .item {
        padding: 40px 20px;
        border-radius: 15px;
      }
      .item .ttl {
        font-size: 2rem;
      }
      .item .icon {
        aspect-ratio: 154 / 108;
        width: 154px;
        margin: 0 auto 20px;
      }
      .item .txtbox {
        font-size: 1.4rem;
      }
    }
  }
}

#about .rightColumn {
  container-name: about_right_col;
  container-type: inline-size;
}
@container about_right_col (width < 768px) {
  #about .overview_sec {
    padding: 50px 10%;
    border: 2px dotted #F08A00;
    border-radius: 9.895vw;
  }
  #about .rightColumn > section + section {
    margin-top: 60px;
  }
}
@container about_right_col (width < 520px) {
  #about .overview_sec {
    padding: 60px 5% 30px;
    border-radius: 20px;
  }
}

#about .overview_sec {
  container-name: overview_sec;
  container-type: inline-size;
}
@container overview_sec (width < 768px) {
  #about .overview_sec {
    .icon {
      top: -40px;
      width: 80px;
    }
    .overview_tbl .item {
      padding: 20px 0 15px;
      grid-template-columns: 1fr;
      grid-template-rows: auto;
    }
    
  }
}
@container overview_sec (width < 520px) {
  #about .overview_sec {
    .overview_tbl {
      grid-template-columns: 1fr;
      grid-template-rows: auto;
    }
    .overview_tbl .item {
      padding: 20px 0;
      grid-template-columns: 1fr;
    }
    .overview_tbl .item:first-child {
      grid-column: 1 / 5;
      grid-row: 1 / 2;
    }
    .overview_tbl .item:nth-child(2) {
      grid-column: 1 / 5;
      grid-row: 2 / 3;
    }
    .overview_tbl .item:nth-child(3) {
      grid-column: 1 / 5;
      grid-row: 3 / 4;
    }
    .overview_tbl .item:nth-child(4) {
      grid-column: 1 / 5;
      grid-row: 4 / 5;
      border-bottom: none;
    }
    .overview_tbl .item:nth-child(5) {
      grid-column: 1 / 5;
      grid-row: 5 / 6;
    }
    .overview_tbl .item:nth-child(6) {
      grid-column: 1 / 5;
      grid-row: 6 / 7;
      border-bottom: 1px solid #D2D2D2;
    }
  }
}

#about .information_sec {
  container-name: information_sec;
  container-type: inline-size;
}
@container information_sec (width < 520px) {
  #about .information_sec {
    .information_items {
      grid-template-columns: 1fr;
      gap: 20px;
    }
    .item {
      padding: 25px;
      border-radius: 10px;
    }
    .item .ttl {
      font-size: 1.8rem;
    }
  }
}

#about .history_sec {
  container-name: history_sec;
  container-type: inline-size;
}
@media screen and (max-width: 768px) {
  #about .history_sec {
    padding: 10px 20px;
    margin: 0 -5%;
  }
}
@container history_sec (width < 768px) {
  #about .history_sec {
    .contents {
      padding: 40px 20px;
      border-radius: 30px;
    }
    .history_items .item {
      grid-template-columns: 100px 1fr;
      padding: 0 0 20px;
    }
    .history_items .item .num {
      font-size: 1.6rem;
    }
    .history_items .item .txt {
      font-size: 1.4rem;
    }
    .history_items .item:not(:last-of-type):before {
      left: 75px;
    }
    .history_items .item:after {
      left: 71px;
    }
  }
}

#about .facilities_sec {
  container-name: facilities_sec;
  container-type: inline-size;
}
@media screen and (max-width: 768px) {
  #about .facilities_sec {
    padding: 40px 20px;
    margin-inline: -5%;
  }
}
@container facilities_sec (width < 768px) {
  #about .facilities_sec {
    padding: 150px 70px;
    border-radius: 20px 0 0 20px;
  }
}
@container facilities_sec (width < 520px) {
  #about .facilities_sec {
    margin-inline: -20px;
    padding: 40px 20px;
    border-radius: 10px 0 0 10px;
  }
}

/* -----------------------------------------------------------
  園のご紹介
----------------------------------------------------------- */
@media screen and (max-width: 768px) {
  #hoikuen-list .rightColumn {
    padding: 40px 20px 40px;
    container-name: hoikuen-item;
    container-type: inline-size;
  }
}

/* -----------------------------------------------------------
  個人情報保護方針
----------------------------------------------------------- */
#privacy {
  /* 個人情報保護方針ページのデザイン */
  .privacy-policy {
    max-width: 1200px;  /* 中央寄せのための最大幅 */
    margin: 0 auto;
    color: #240A00;
  }

  /* 説明テキスト */
  .privacy-policy__description {
    font-size: 1.4rem;
  }

  /* 見出し */
  .privacy-policy__heading {
    font-size: 1.6rem;
  }
}

/* -----------------------------------------------------------
  よくあるご質問
----------------------------------------------------------- */
#faq {
  & .faq_wrap .faq_item + .faq_item {
    margin-top: 30px;
  }
  & .faq_wrap .faq_item__ttl {
    padding: 0 40px 20px 30px;
  }
  & .faq_wrap .faq_item__ttl .icon {
    width: 25px;
    bottom: auto;
    top: 0;
  }
  & .faq_wrap .faq_item__ttl .icon:before,
  & .faq_wrap .faq_item__ttl .icon:after {
    width: 12px;
  }
  & .faq_wrap .faq_item__content {
    padding: 20px 0 0 30px;
  }
  & .faq_wrap .faq_item__ttl:before,
  & .faq_wrap .faq_item__content:before {
    font-size: 2.5rem;
    left: 0px;
  }
  & .faq_wrap .faq_item__ttl:before {
    bottom: auto;
    top: -10px;
  }
  & .faq_wrap .faq_item__content:before {
    top: 15px;
  }
}



.top__acquisition-wrap .left, .top__acquisition-wrap .right {
    width: 100%;
}

.top__acquisition-wrap .container {
        display: block;
        max-width: 620px;
        margin-left: auto;
        margin-right: auto;
}





@media screen and (max-width: 1000px) {

.top__acquisition-wrap .left .flex {
    display: block;
}

.top__acquisition-wrap .highlight {
    font-size: 2rem;
}

.top__acquisition-wrap .section h3 p {
    font-size: 2.5rem;
    padding-left: 20px;
    padding-right: 20px;
    top: 20px;
    left: 40px;
}

.top__acquisition-wrap .section .number {
    font-size: 2rem;
}
.top__acquisition-wrap .left .flex img {
            display: none;
}
.top__acquisition-wrap .halfway-wrap .moreLink img {
    margin: 0;
            display: block;
}


}






@media screen and (max-width: 768px) {
section.top__introduction-wrap .inner {
    overflow: hidden;
}
section.top__about-wrap .top__about-ttl {
    font-size: 2rem;
    margin-bottom: 2rem;
}

section.top__about-wrap .top__about-txt {
    margin-top: 2rem;
}
section.top__about-wrap ul {
    display: block;
}

section.top__about-wrap ul li {
    width: 96%;
    margin-left: auto;
    margin-right: auto;
}
section.top__about-wrap ul li img {
    width: 50%;
    margin-left: auto;
    margin-right: auto;
}

section.top__about-wrap ul li p.title {
		margin-left: 20%;
            padding: 19px 0px;
            padding-left: 0;
            padding-right: 0;
            width: 40px;
            writing-mode: rl;
            text-align: center;
            letter-spacing: 0rem;
}
.top__acquisition-wrap .right img {
    width: 130px;
}
.top__acquisition-wrap .section {
	padding: 3px;
        padding-left: 0px;
        padding-right: 0px;
}
.top__acquisition-wrap .left .section {
    	padding-right: 25px;
}
.top__acquisition-wrap .small-note {
	top: -12px;
        right: auto;
       	left: 90px;
}

section.top__acquisition-wrap .top__acquisition-plan__ttl {
    	right: -50px;
}
.top__acquisition-wrap .section h3 {
    	margin-left: -15px;
}
.top__acquisition-wrap .section h3 p {
    	font-size: 2rem;
}
}


@media screen and (max-width: 600px) {
.banner_footer ul {
    display: block;
}
        footer .flex div.flex{
            display: flex;
            width: 210px;
        }

.banner_footer ul{width: 150px;}
        .banner_footer ul {
            text-align: left;
            margin-left: auto;
            margin-right: auto;
        }


.banner_footer ul li:before {
    content: "●";
    font-size: 6px;
    position: absolute;
    left: -13px;
    top: 10px;
}
.banner_footer ul li {
    position: relative;
}
footer .flex {
    display: block;
}

footer .flex div.flex div:nth-child(1), footer .flex div.flex div:nth-child(2), footer .flex div.flex div:nth-child(3), footer .flex div.flex div:nth-child(4) {
    width: 100%;
}
footer .flex div {
text-align: center;
}
.banner_footer ul li a {
    margin-inline: 0;
}

.banner_footer ul {
    text-align: left;
}
}

@media screen and (max-width: 480px) {

.top__acquisition-wrap .right .highlight br {
    display: none;
}
section.top__introduction-wrap ul li p.line {
    font-size: 14px;
}
section.top__introduction-wrap ul li p {
    font-size: 13px;
}
.top__acquisition-wrap .section h3 {
    margin-left: 0px;
}

}