@import url('https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic&display=swap');
body p,
body a,
body li,
body dt,
body dd,
body time,
body h1,
body h2,
body h3,
body h4,
body h5,
body h6,
body th,
body td,
body span,
body label,
body input {
    font-family: "Zen Maru Gothic", serif;
    font-weight: 400;
    font-style: normal;
    color: #524642;
    font-size: 1.8rem;
}

.sp450-show {
    display: none;
}

.page-nav>div {
    border: none;
    flex: 1;
    margin: 10px;
    background: #fff;
}

.page-nav>div.list-link {
    border: none;
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center;
}

.page-nav div span {
    color: #333;
}

.list-link-sp {
    display: none;
}

.g-menu-icon-img-wrap {
    display: none;
}

.menu-image-title {
    font-size: 1.7rem;
}

.side-box li ul li {
    border: none;
    margin-left: 4rem;
}

li.cat-catnews>a::before {
    font-family: "Font Awesome 6 Free";
    content: "\f023";
    /* Unicode for lock icon */
    font-weight: 900;
    margin-right: 0.5em;
}

.show-sp {
    display: none;
}


/*--------------------------------------------------
 * PCスライドメニュー
 * ------------------------------------------------*/

.open-btn-wrap {
    -webkit-transform: translateY(-130px);
    transform: translateY(-130px);
    position: fixed;
    top: 50px;
    right: 50px;
    z-index: 50;
    -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    transition: -webkit-transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    transition: transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    transition: transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55), -webkit-transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    transition: transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55), -webkit-transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    transition: transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55), -webkit-transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
}

.open-btn-wrap.active {
    -webkit-transform: translateY(0);
    transform: translateY(0);
}

.openbtn {
    position: relative;
    background: #7ED8C2;
    cursor: pointer;
    width: 80px;
    height: 80px;
    border-radius: 999px;
    border: 2px solid #fff;
}

.openbtn span {
    display: inline-block;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    position: absolute;
    left: 20px;
    height: 3px;
    border-radius: 2px;
    background: #fff;
    width: 45%;
}

.openbtn span:nth-of-type(1) {
    top: 27px;
}

.openbtn span:nth-of-type(2) {
    top: 36px;
}

.openbtn span:nth-of-type(3) {
    top: 45px;
}

.openbtn.active span:nth-of-type(1) {
    top: 29px;
    left: 19px;
    -webkit-transform: translateY(6px) rotate(-45deg);
    transform: translateY(6px) rotate(-45deg);
    width: 50%;
}

.openbtn.active span:nth-of-type(2) {
    opacity: 0;
}

.openbtn.active span:nth-of-type(3) {
    top: 41px;
    left: 19px;
    -webkit-transform: translateY(-6px) rotate(45deg);
    transform: translateY(-6px) rotate(45deg);
    width: 50%;
}

.pc-side-menu {
    position: fixed;
    height: 100%;
    width: 800px;
    z-index: 10;
    background-color: rgba(255, 255, 255, 0.95);
    right: 0;
    top: 0;
    padding: 150px 50px 100px;
    -webkit-transform: translateX(800px);
    transform: translateX(800px);
    -webkit-transition-duration: 0.5s;
    transition-duration: 0.5s;
    -webkit-transition-timing-function: ease-out;
    transition-timing-function: ease-out;
    overflow-y: auto;
    z-index: 20;
    box-shadow: 0px 4px 10px -2px rgba(0, 0, 0, 0.1);
}

.pc-side-menu .mobile-sns-icon-title p {
    color: #524642;
    !important
}

.pc-side-menu .mobile-sns-icon-title p span {
    color: #524642;
    !important
}

.pc-side-menu.active {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    background-image: url(/wp-content/uploads/2025/02/takahagi.png);
    background-size: 70%;
    background-repeat: no-repeat;
    background-position: center bottom 10px;
    animation: none;
    transform: none;
    transition: unset;
}

.pc-side-list {
    margin-bottom: 40px;
}

.pc-side-list li a {
    display: block;
    padding-bottom: 10px;
    border-bottom: 1px solid #524642;
    margin-bottom: 20px;
    letter-spacing: 0.1em;
    font-size: 2rem;
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    color: #524642;
}

.pc-side-list li a:hover {
    opacity: 0.7;
}

.pc-side-list .g-sub-nav .g-sub-nav-list.flex a {
    display: flex;
    align-items: center;
    font-size: 1.8rem;
    border: solid 2px #7ED8C2;
    background-color: #7ED8C2;
    color: #fff;
    width: 100%;
    text-align: center;
    justify-content: center;
}

.g-sub-nav .g-sub-nav-list li {
    display: flex;
}

.g-sub-nav .g-sub-nav-list li:nth-child(1) a:before {
    content: "";
    margin-right: 10px;
    display: inline-block;
    width: 30px;
    height: 30px;
    background-image: url(/wp-content/uploads/2025/02/icon_mail.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

.g-sub-nav .g-sub-nav-list li:nth-child(2) a:before {
    content: "";
    margin-right: 10px;
    display: inline-block;
    width: 30px;
    height: 30px;
    background-image: url(/wp-content/uploads/2025/02/icon_tel.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

.pc-side-menu.active .g-sub-nav .g-sub-nav-list li {
    display: flex;
    width: 50% !important;
    margin-top: 50px;
}

.pc-side-menu.active .g-sub-nav .g-sub-nav-list.flex a {
    width: 100%;
    border: none;
    background: #524642;
    justify-content: center;
    padding: 10px;
    border-radius: 5px;
    border: 2px solid #fff;
}

body {
    background-image: url(/wp-content/uploads/2025/02/bg_pattern02.png);
    background-size: cover;
}


/*--------------------------
 * header
 * -------------------------*/

.header-inner.flex {
    max-width: 100%;
}

.logo {
    position: absolute;
    z-index: 1;
    width: 500px;
    margin-bottom: 0;
    top: 0;
    background: #fff;
    border-radius: 0 0 20px 0;
    padding: 10px;
    left: 0;
}

.g-sub-nav .g-sub-nav-list.flex {
    margin-bottom: 0;
    flex-wrap: nowrap;
}

.g-menu-wrap {
    width: calc(100% - 400px);
    margin-left: auto;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.g-menu-a-list>li {
    border: none;
}

.g-menu-a-list>li {
    width: auto;
}

.g-sub-nav {
    position: static;
}

.g-sub-nav .g-sub-nav-list.flex a {
    display: flex;
    align-items: center;
    font-size: 1.8rem;
    border: solid 2px #7ED8C2;
    background-color: #7ED8C2;
    color: #fff;
    white-space: nowrap;
}

.g-sub-nav .g-sub-nav-list.flex a:hover {
    color: #fff;
    background-color: var(--main);
    opacity: 0.8;
}

.menu-image-title {
    margin: 0;
    color: #524642;
}

.footer-menu-title {
    display: none;
}

.sp600 {
    display: none;
}


/*--------------------------
 * 見出し
 * -------------------------*/

h3 {
    font-size: 4em;
    text-align: center;
    margin-bottom: 30px;
}

h3.bln01 {
    display: inline-block;
    position: relative;
    font-size: 3.5em;
    text-align: center;
    margin-bottom: 30px;
}

.center {
    text-align: center;
}

h3.bln01::before,
h3.bln01::after {
    display: block;
    content: "";
    position: absolute;
    width: 1px;
    height: 3rem;
    background: #524642;
    border-radius: 10px;
}

h3.bln01::before {
    transform: rotate(-30deg);
    left: -20px;
    bottom: 0;
}

h3.bln01::after {
    transform: rotate(30deg);
    right: -20px;
    bottom: 0;
}

h3.v01 {
    background: url(/wp-content/uploads/2025/02/line02.png);
    background-repeat: repeat-x;
    background-position: center bottom;
    padding: 20px;
    background-size: 30%;
    font-size: 3em;
}

h4.v_2 {
    border-bottom: 3px dotted #ffedb3;
    padding-bottom: 10px;
}

h4.v_2:before {
    content: "";
    display: inline-block;
    background-color: #ffedb3;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    position: relative;
    margin-right: 10px;
}

.title01::before {
    display: none;
}

.title01 span {
    display: block;
    font-size: 1.8rem;
    font-weight: bold;
    color: #524642;
    line-height: 1;
}

.title01 {
    position: relative;
    /*  background-image: url(/wp-content/uploads/2025/02/bg_title.png);*/
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    padding: 6vw;
    padding: 70px 0;
    color: #524642;
    font-size: 4rem;
}

.title01:before {
    position: absolute;
    content: "";
    display: block;
    background-image: url(/wp-content/uploads/2025/02/takahagi6_g.png);
    width: 80px;
    height: 80px;
    background-position: center bottom;
    background-size: contain;
    background-repeat: no-repeat;
    background-color: transparent;
    top: -30px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    z-index: 1;
    margin: 0;
}

.title02 {
    background: url(/wp-content/uploads/2025/02/bg_c01.png);
    border-radius: 20px;
}

.box_club .box50 {
    background: rgba(255, 165, 0, 0.1);
    border-radius: 10px;
    padding: 40px 20px;
}

.mb100 {
    margin-bottom: 100px;
}

h4.top_title {
    position: relative;
    font-size: 3em;
    font-weight: bold;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    border-bottom: 1px dotted;
    margin-top: 0;
    margin-bottom: 10px;
    padding-bottom: 10px;
}

.top_title span {
    font-size: 0.8em;
    display: block;
    width: auto;
    line-height: 1;
}

h4.top_title:before {
    content: "";
    background-image: url(/wp-content/uploads/2025/02/icon_key-1.png);
    background-size: contain;
    width: 35px;
    height: 35px;
    display: inline-block;
    background-repeat: no-repeat;
    background-position: center left;
    margin-right: 10px;
}

h2.l_tit {
    font-size: 3em;
    text-align: center;
    margin-bottom: 30px;
    background: url(/wp-content/uploads/2025/02/line01.png);
    background-size: 250px;
    background-repeat: no-repeat;
    background-position: center bottom;
    padding-bottom: 40px;
}

.layout01 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.box50 {
    width: 48%;
}


/*--modal-----------------------------*/

.modal {
    display: none;
    position: fixed;
    z-index: 500;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.5);
}

.modal-box {
    background-color: #fff;
    margin: 10% auto;
    max-width: 1000px;
    width: 90vw;
    border-radius: 10px;
    animation-name: modalopen;
    animation-duration: 1s;
    position: relative;
    padding: 50px;
}

.modal-box img {
    max-width: 500px;
    width: 100%;
    margin: 0 auto;
}

.modalClose {
    position: absolute;
    top: 0;
    right: 0;
    width: 30px;
    height: 30px;
    margin: 10px;
}

span.mkGR2 {
    background: linear-gradient(rgba(255, 255, 255, 0) 40%, #E5FFE5 70%);
}

.modal-box a:link {
    color: #ff9f1c;
}

.about1 h5::before {
    content: "";
    display: inline-block;
    background-color: #E5FFE5;
    border-radius: 50%;
    width: 15px;
    height: 15px;
    position: relative;
    margin-right: 10px;
}

.lifeArea2 h4,
h3.prehoiku,
.h3_titlebox {
    padding: 1rem;
    margin-bottom: 2rem;
    border-radius: 5px;
    background: #fac172;
    color: #fff;
    font-size: 20px;
    text-align: left;
}

.info_font {
    color: #fff;
}

.modal-box h5 {
    font-weight: bold;
    border-bottom: 1px #ccc solid;
    margin-bottom: 10px;
    padding-bottom: 10px;
}

.en_logo_area {
    border: 1px solid #ccc;
    text-align: center;
    padding: 20px;
}

.en_logo_area img {
    max-width: 300px;
    margin: 0 auto;
}


/*slider*/

.slider .ab01 {
    position: absolute;
    width: 20vw;
    height: 30vw;
    bottom: -5vw;
    left: 3vw;
    z-index: 1;
}

.slider_inner {
    width: 90%;
    margin-left: auto;
    border-radius: 50px 0 0 50px;
    overflow: hidden;
    box-shadow: 0px 4px 10px -2px rgba(0, 0, 0, 0.1);
}

#footer .o-hover img {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    background: #fff;
    padding: 20px;
    border-radius: 20px;
}


/*--------------------------
 * 新着情報
 * -------------------------*/

#greeting {
    position: relative;
}

#greeting .box_greeting {
    position: relative;
}

#greeting .box_greeting .title01 {}

.news-list01 {
    margin-bottom: 25px;
    background: rgba(255, 255, 255, .4);
    padding: 50px;
    border-radius: 10px;
    box-shadow: 0px 4px 10px -2px rgba(0, 0, 0, 0.1);
}

.news-list01 li .news-cat a {
    background-color: transparent;
    border: 1px solid #524642;
    color: #524642;
}

.news-list01 li .news-cat a:hover {
    color: #524642;
    opacity: 0.8;
}

.single-info-wrap {
    margin-bottom: 100px;
    background: #fff;
    padding: 50px;
    border-radius: 20px;
}

.btn01 {
    border: 1px solid var(--main);
    background-color: transparent;
    color: #7ED8C2;
}

.btn01 .btn-arrow {
    fill: #7ED8C2;
}

.sec02 {
    position: relative;
    padding-top: 10vw;
    padding-bottom: 10vw;
}

.sec02 .ab01 {
    position: absolute;
    width: 16vw;
    height: 35vw;
    top: 0;
    right: 3vw;
    z-index: 1;
}

.sec02 .title01 {
    width: 50vw;
    height: 25vw;
    position: relative;
    background: url(/wp-content/uploads/2025/02/bg_pt01-1.jpg);
    background-size: auto;
    background-size: 100%;
    border-radius: 0 20px 20px 0;
    padding: 5vw;
    color: #524642;
}

.sec02 .title01 span {
    color: #524642;
}

.sec02 .title01:before {
    background: none;
}

.sec02 .title01:after {
    content: "";
    background-image: url(/wp-content/uploads/2025/02/bg_title03.png);
    display: block;
    width: 20vw;
    height: 20vw;
    position: absolute;
    top: -10vw;
    background-size: 100%;
    left: -10vw;
    z-index: 1;
}

.sec02 .layout01 {
    margin-top: -14vw;
    /*position: absolute;
  top: 25vw;
  left: 10vw;
  z-index: 999;
	*/
}

.sub-header {
    position: relative;
    width: 90%;
    margin: 0 auto;
    border-radius: 20px;
}

.sub-header:after {
    content: "";
    background-image: url(/wp-content/uploads/2025/02/takahagi_illust10.png);
    background-repeat: no-repeat;
    display: block;
    width: 30vw;
    height: 20vw;
    position: absolute;
    bottom: 0;
    background-size: contain;
    background-position: bottom center;
    right: -5%;
    z-index: 10;
    bottom: -40px;
}

.sub-header-txt {
    padding: 10px 25px;
    color: #524642;
}

.sec02 .box50 {
    width: 48%;
    box-shadow: 0px 4px 10px -2px rgba(0, 0, 0, 0.1);
    background: rgba(255, 255, 255, 0.9);
    padding: 50px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border: none;
    border-radius: 10px;
}

.sec02 .layout01 .youchien img {
    width: 100%;
    height: 10vw;
    display: block;
    margin: 0 auto;
    margin-top: 0px;
    overflow: hidden;
    border-radius: 10px;
    margin-top: 20px;
}

.sec02 .layout01 .bus img {
    width: 250px;
    display: block;
    margin: 20px auto;
}

#sb_instagram .sbi_follow_btn a,
#sb_instagram .sbi_follow_btn a,
#sb_instagram #sbi_load .sbi_load_btn {
    transition: all 0.1s ease-in;
    background: url(/wp-content/uploads/2025/02/bg_c01.png);
}

.sbi_follow_btn a {
    background: url(/wp-content/uploads/2025/02/bg_c01.png) !important;
}

#sb_instagram .sbi_caption {
    font-size: 14px;
}

.cf-tel-number {
    color: #fff;
}

.btn01 .btn-arrow {
    fill: #524642;
}

.btn01 {
    border: 1px solid #524642;
    background-color: transparent;
    color: #524642;
}


/*--------------------------
 * 各種資料ダウンロード
 * -------------------------*/

.box_pdf {
    margin-left: 5vw;
    width: 60vw;
}

.list_pdf {
    display: flex;
    flex-wrap: wrap;
}

.list_pdf li {
    width: 50%;
}

.list_pdf li a {
    font-size: 1.5em;
    border: 1px solid;
    display: block;
    margin: 25px 15px;
    padding: 40px 80px 40px 40px;
    background: #fff;
    border: none;
    border-radius: 10px;
    background-image: url(/wp-content/uploads/2025/02/icon_pdf.png);
    background-size: 40px;
    background-repeat: no-repeat;
    background-position: center right 30px;
    box-shadow: 0px 4px 10px -2px rgba(0, 0, 0, 0.1);
}


/*--------------------------
 * footer
 * -------------------------*/

.contact-band {
    padding: 0;
    background-color: #fffdf5;
    background-image: url(/wp-content/uploads/2025/08/toitoi002.jpg);
    background-size: 100%;
    background-position: center;
}

.contact-band-inner {
    padding: 50px 15px;
    background: rgba(192, 109, 64, 0.3);
    color: #fff;
}

.contact-band-title,
.cf-cb-txt {
    color: #524642;
    color: #fff;
}

.contact-band .btn01 {
    border: 1px solid #fff;
    background-color: transparent;
    color: #fff;
}

.contact-band .btn01 .btn-arrow {
    fill: #fff;
}

.footer {
    background-color: #fff9f3;
}

.footer-address p,
.footer-address a {
    color: #524642;
}

.footer-logo {
    padding-bottom: 40px;
    border-bottom: none;
}

.footer-menu a {
    color: #524642;
}

.footer-menu>li>a {
    border-bottom: 1px dashed #524642;
}

.sns-icon-title p {
    font-size: 2rem;
    font-weight: 700;
    color: #524642 !important;
}

.sns-sub-nav li a {
    color: #524642;
    font-size: 24px;
}

.sns-icon-wrap.flex .line {
    background-color: #524642 !important;
}

.fa-instagram::before {
    content: "\f16d";
    color: #524642;
}

.copyright p {
    color: #524642;
}

#page-top img {
    max-height: 130px;
    width: auto;
}


/*--------------------------
 * ボタン
 * -------------------------*/

.btn_more {
    display: block;
    text-align: right;
    margin-top: 50px;
    margin-bottom: 0;
}

.btn_more a {
    position: relative;
    display: inline-block;
    text-align: center;
    text-decoration: none;
    outline: 0;
    overflow: hidden;
    color: #fff;
    background: -moz-linear-gradient(45deg, #ff9a9e 0%, #f0b77f 99%, #fad0c4 100%);
    background: -webkit-linear-gradient(45deg, #ff9a9e 0%, #f0b77f 99%, #fad0c4 100%);
    background: linear-gradient(45deg, #ff9a9e 0%, #f0b77f 99%, #fad0c4 100%);
    box-shadow: 0 1px 1px 2px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    padding: .5em 1em;
}

.contact-band-tel-icon fill {
    color: #524642;
}

.list_about01 {
    margin: 100px 0;
}

.list_about01 li {
    position: relative;
    flex-wrap: wrap;
    flex-flow: column;
    font-size: 3em;
    text-align: center;
    width: 30%;
    margin-bottom: 50px;
    width: 450px;
    height: 450px;
    background-image: url(/wp-content/uploads/2025/02/frame01_03-1.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-weight: bold;
    line-height: 1.5;
}

.list_about01 li:nth-child(3n+1) {
    background-image: url(/wp-content/uploads/2025/02/frame01_01-1.png);
}

.list_about01 li:nth-child(3n+2) {
    background-image: url(/wp-content/uploads/2025/02/frame01_02-1.png);
}

.list_about01 li:nth-child(3n+3) {
    background-image: url(/wp-content/uploads/2025/02/frame01_03-1.png);
}

.no_list_about01 {
    font-family: "Helvetica Neue", Arial, "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "Hiragino Kaku Gothic ProN", sans-serif;
    color: #8b5c2d;
    position: absolute;
    top: -80px;
    font-size: 2em;
}

.modalOpen .img {
    width: 50%;
}

.btn10 {
    background: #fac172;
    padding: 5px 20px 10px;
    line-height: 1;
    border-radius: 20px;
    font-size: 16px;
}

.btn11 {
    text-align: center;
}

.btn11 a {
    background: #fac172;
    padding: 15px 20px 20px;
    line-height: 1;
    border-radius: 50px;
    margin-top: 30px;
    font-size: 20px;
    display: inline-block;
    text-align: center;
    margin: 0 auto;
}

.btn12 a {
    background: #7ED8C2;
    color: #fff;
    padding: 15px 20px 20px;
    line-height: 1;
    border-radius: 20px;
    margin-top: 30px;
    font-size: 16px;
    display: block;
    text-align: center;
    margin: 0 auto;
}

.btn12 a:link {
    color: #fff;
}

.modal .layout01 {
    justify-content: center;
}

.modal .layout01 .box50 {
    margin: 1%;
}

ul.list0 {
    margin-bottom: 30px;
}

ul.list01 li {
    font-size: 18px;
}

ul.list01 li:before {
    display: inline-block;
    margin-right: 10px;
    content: "";
    background-image: url(/wp-content/uploads/2025/02/icon_flower.png);
    width: 20px;
    height: 20px;
    background-repeat: no-repeat;
    background-size: contain;
}


/*--------------------------
 * 園について
 * -------------------------*/

main.about {
    background: url(/wp-content/uploads/2025/02/takahagi_illust8.png);
    background-size: 700px;
    background-repeat: no-repeat;
    background-position: bottom left;
    padding-bottom: 400px;
}


/*----------------------------------------
 * 課外教室
 * ---------------------------------------*/

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

.list_kagai li {
    width: 21%;
    margin: 0 1% 2%;
}

.single-post_kagai .list_kagai li {
    width: 31%;
}

.list_kagai li a {
    font-size: 20px;
    width: 100%;
    display: block;
    padding: 30px;
    text-align: center;
    font-size: 24px;
    background-color: #ffc3c3;
    box-shadow: 0 0 0 8px #ffc6c6;
    border: 2px dashed #ffffff;
    color: #000000;
}

.frame01 {
    background-image: url(/wp-content/uploads/2025/02/takahagi8.png);
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 150px;
}

.frame01_inner {
    padding: 30px;
    width: 1100px;
    margin: 0px 142px 50px auto;
    color: #565656;
    background: #fef9f3;
    box-shadow: 0px 0px 0px 10px #fef9f3;
    border: dashed 2px #ffc3c3;
    border-radius: 8px;
}

.frame01_inner p {
    font-size: 18px;
    margin: 0;
    padding: 0;
}

.single-post_kagai section {
    background-image: url(/wp-content/uploads/2025/02/bg_img01.png), url(/wp-content/uploads/2025/02/bg_img02.png);
    background-repeat: no-repeat;
    background-size: 100px, 200px;
    background-position: bottom 5vw left 5vw, top 5vw right 5vw;
}

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

.list_img {
    display: flex;
    margin-bottom: 30px;
    flex-wrap: wrap;
}

.list_img li {
    /*flex: 1;*/
    width: 30%;
    margin: 0 10px 10px;
}

.list_img.col4 li {
    flex: 1;
    margin: 0 10px 10px;
}

.txt {
    font-size: 16px;
}

.f24 {
    font-size: 20px;
    font-weight: bold;
    margin-right: 10px;
}

.list10 li {
    text-indent: -1.6em;
    padding-left: 2em;
    text-align: left;
    margin-bottom: 0;
    border-bottom: 1px dotted;
    margin-bottom: 10px;
    padding-bottom: 10px;
}

h4 {
    font-size: 2em;
    margin: 30px 0 10px;
}


/*--------------------------
 * table
 * -------------------------*/

.tablepress tbody td.column-1 {
    background-color: var(--main);
    border-right: 1px solid #ccc;
    color: #524642;
}

.com-box02-head {
    padding: 5px 15px;
    text-align: center;
    font-weight: bold;
    letter-spacing: 0.05em;
    font-size: 18px;
    color: #524642 !important;
    background-color: transparent !important;
    margin-bottom: 10px;
}

.com-list02-ttl {
    font-size: 2.2rem !important;
    font-weight: 700;
    color: #524642 !important;
    letter-spacing: .1em;
    border-bottom: 1px solid #524642 !important;
}


/*--------------------------
 * 予約
 * -------------------------*/

.reserve {
    background: url(/wp-content/uploads/2025/02/takahagi_illust5.png), url(/wp-content/uploads/2025/02/bg_pt01.jpg);
    background-size: 400px, cover;
    background-position: bottom left, center;
    background-repeat: no-repeat;
    padding-bottom: 20vw;
}

#booking-package_calendarPage .calendar {
    margin-bottom: 0 !important;
}

#booking-package_calendarPage .week_slot {
    border-color: #ddd;
    background: #fac172;
    color: #fff;
    font-weight: bold;
}

#booking-package_inputFormPanel .row {
    border-color: #ddd;
    display: flex;
}

#booking-package_inputFormPanel .name,
#booking-package_serviceDetails .name,
#booking-package_myBookingDetailsFroVisitor .name,
#booking-package_myBookingDetails_panel .name {
    display: inline-block;
    font-weight: normal;
    padding-bottom: 5px;
    width: 30% !important;
    color: #524642 !important;
    padding: 10px !important;
    margin-right: 10px !important;
}

#booking-package_inputFormPanel .form_text {
    width: 100%;
    padding: 10px;
}

#booking-package_inputFormPanel .bottomBarPanel {
    text-align: center;
}

#booking-package_inputFormPanel .required {
    padding: 5px 10px;
    color: #f3f3f3;
    background-color: transparent;
    font-size: 1.2rem;
    font-weight: 700;
    margin-left: 0;
}

.bookingDate,
.bookingTime,
.bookingSubtitle {
    font-size: 20px;
}

.book_now_button {
    background-color: #fac172;
    color: #fff;
    padding: 20px;
    max-width: 300px;
    margin: 0 auto;
    text-align: center;
    font-weight: bold;
    border-radius: 10px;
}


/*--------------------------
 * お問い合わせ
 * -------------------------*/

.contact-form01 tbody {
    border: none;
}

.contact-form01 th {
    font-size: 1.6rem;
    width: 30%;
    vertical-align: middle;
    padding: 10px 15px;
    background-color: transparent;
    border-bottom: 1px solid #d1dee8;
    color: #524642;
    font-weight: 700;
}

.contact-form01 td.layout01 {
    flex-wrap: nowrap;
    align-items: center;
}

.contact-form01 td.layout01 p {
    margin: 0 10px;
}

iframe {
    width: 100%;
}


/*--------------------------
 * tab
 * -------------------------*/

.tab-panel-a .tab.is-active,
.tab-panel-a .tab:hover {
    background-color: var(--main);
    color: #fff;
}

.tab-panel-a .tab-group {
    margin-bottom: 0;
}

.tab-panel-a .panel.is-show {
    background-color: var(--main);
    padding: 50px 30px;
}

.tab-panel-a .tab {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 50%;
    margin: 0;
    border-radius: 15px 15px 0 0;
    padding: 15px;
    font-weight: 700;
    color: var(--main);
    background-color: #dff7f7;
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    font-size: 24px;
}

.com-list02 {
    background-color: #fff;
    padding: 30px;
    border-radius: 10px;
}

.com-timeline01 {
    position: relative;
    background: #fff;
    padding: 30px 20px;
}


/*--------------------------
 * キッズクラブ
 * -------------------------*/

.club {
    position: relative;
}

.club .ab01 {
    position: absolute;
    width: 15vw;
    height: 20vw;
    top: 5vw;
    left: 3vw;
    z-index: 1;
}

.box_kids {
    border: 1px solid #524642;
    padding: 50px;
    border-radius: 10px;
}

.box_kids img {
    width: 50%;
    margin: 0 auto 30px;
}


/*--------------------------
 * 園の一日
 * -------------------------*/

.com-timeline01 .timeline {
    right: unset !important;
    left: 10px !important;
    margin: 150px auto !important;
}

.com-timeline01-head {
    color: #524642 !important;
}

.com-timeline01-time {
    color: #524642 !important;
    border-bottom: 1px solid #0067B5 !important;
}


/*--------------------------
 * 入園案内
 * -------------------------*/

.tbl01 {
    border: solid 2px orange;
}

.tbl01 th,
.tbl01 td,
.tbl02 th,
.tbl02 td,
.tbl03 th,
.tbl03 td {
    padding: 0.5em 2%;
    text-align: left;
}

.tbl01 th,
.tbl01 td {
    border: 1px solid orange;
}

.tbl02 th,
.tbl02 td {
    border: 1px solid #96CB51;
}

.tbl03 th,
.tbl03 td {
    border: 1px solid #F26284;
}

.tbl01 th {
    border: solid 1px orange;
    background: #ffb44e;
    color: #fff;
    width: 30%;
}

.tbl02 th {
    background: #EAF4DC;
    width: 30%;
}

.tbl03 th {
    background: #FDF5F7;
    width: 30%;
}

tr.tblw20>th {
    width: 22%;
    background-color: oldlace;
    border: solid 1px orange;
    color: orange;
}

.parallax {
    width: 100%;
    background-attachment: fixed;
    background-position: 50% 0;
    background-position: center;
    background-size: cover;
    height: 80vh;
}

.parallax.para01 {
    background-image: url(/wp-content/uploads/2025/03/.jpg);
    background-image: url(/wp-content/uploads/2025/03/bg_about.jpg);
}

.parallax.para02 {
    background-image: url(/wp-content/uploads/2025/03/image02.jpg);
}

.parallax.para03 {
    background-image: url(/wp-content/uploads/2025/03/image03.jpg);
}

.parallax.para04 {
    background-image: url(/wp-content/uploads/2025/03/image04.jpg);
}

.parallax.para05 {
    background-image: url(/wp-content/uploads/2025/03/image05.jpg);
}

.parallax.para06 {
    background-image: url(/wp-content/uploads/2025/03/image06.jpg);
}

.parallax.para07 {
    background-image: url(/wp-content/uploads/2025/03/image07.jpg);
}

.hoiku {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start
}

.hoiku li {
    width: 45%;
    margin: 1%;
}

.bnr_genba {
    max-width: 700px;
    margin: 0 auto;
    width: 90%;
}

.m-txt {
    font-size: 1.1em;
    line-height: 1.3em;
    margin-top: 2vw;
    margin-bottom: 10px;
    font-weight: bold;
}

.d-txt {
    margin-bottom: 0;
    font-size: 18px;
    width: 80%;
}

.btn10 {
    position: relative;
    margin-top: 15px;
    padding: 7px 40px;
    color: #333;
}

.modalOpen .img {
    margin-bottom: 0;
}

.btn10:after {
    content: '';
    position: absolute;
    top: 50%;
    right: 25px;
    transform: rotate(45deg) translateY(-50%);
    width: 8px;
    height: 8px;
    border-width: 1px 1px 0 0;
    border-style: solid;
    border-color: #333;
    margin-left: 10px;
}

.btn10:hover {
    opacity: 0.8;
}

#club {
    background: url(/wp-content/uploads/2025/02/bg_title03.png), url(/wp-content/uploads/2025/02/bg_title03.png), url(/wp-content/uploads/2025/02/takahagi_illust7.png);
    background-size: 10vw, 20vw, 15vw;
    background-repeat: no-repeat;
    background-position: top left, top 10% right -10vw, bottom left;
}

#about {
    background: url(/wp-content/uploads/2025/03/frame03-01.png), url(/wp-content/uploads/2025/03/frame03-02.png), url(/wp-content/uploads/2025/02/takahagi_illust8.png);
    background-size: 20vw, 20vw, 30%;
    background-repeat: no-repeat;
    background-position: top left, top right, bottom left;
    padding-bottom: 15vw;
}

#life {
    background: url(/wp-content/uploads/2025/03/frame03-01.png), url(/wp-content/uploads/2025/03/frame03-02.png), url(/wp-content/uploads/2025/02/takahagi_illust8.png);
    background-size: 20vw, 20vw, 0;
    background-repeat: no-repeat;
    background-position: top left, top right, bottom left;
    padding-bottom: 0;
}

#guidance {
    background: url(/wp-content/uploads/2025/03/frame03-01.png), url(/wp-content/uploads/2025/03/frame03-02.png), url(/wp-content/uploads/2025/03/bg10.png), url(/wp-content/uploads/2025/02/takahagi_illust8.png);
    background-size: 20vw, 20vw, 10vw, 30%;
    background-repeat: no-repeat;
    background-position: top left, top right, top 60% right, bottom left;
    padding-bottom: 15vw;
}

#overview {
    background: url(/wp-content/uploads/2025/02/takahagi_illust6.png);
    background-size: 15vw;
    background-repeat: no-repeat;
    background-position: bottom right;
    padding-bottom: 15vw;
}

.box-hoiku {
    background: url(/wp-content/uploads/2025/02/bg_pt01-1.jpg);
    background-size: cover;
    padding: 100px 0;
    margin-top: 100px;
}

.box-hoiku p {
    font-size: 2.5rem;
    text-align: left;
    margin-top: 30px;
}


/*0331追加*/

.wp-block-image :where(figcaption) {
    font-family: "Zen Maru Gothic", serif;
    font-weight: 400;
    font-style: normal;
    color: #524642;
    font-size: 18px;
}

.wp-block-image>a,
.wp-block-image>figure>a {
    width: 100%;
}

.hoiku_box {
    width: 100%;
    margin: 0 auto 6rem;
    border-radius: 5px;
    background-color: #fdefdb;
    padding: 5rem;
}

.futoji {
    font-weight: bold;
}

.single-info-wrap main {
    width: calc(100% - 360px);
}

.sidebar {
    width: 300px;
}


/*20250411*/

body.afterschool .sub-header-title,
body.post-template-single-hoiku .sub-header-title,
body.category-hoiku .sub-header-title {
    -ms-flex-align: end;
    align-items: end;
}

body.afterschool .sub-header-txt,
body.post-template-single-hoiku .sub-header-txt,
body.category-hoiku .sub-header-txt {
    background-color: rgba(255, 255, 255, 0.95);
    padding: 15px 100px;
    border-radius: 20px 20px 0 0;
    margin: 0;
}

.sub-header-hoiku .sub-header-txt {
    background-color: rgba(255, 255, 255, 0.95);
    padding: 15px 100px;
    border-radius: 20px 20px 0 0;
    margin: 0;
}

.list_img .tit {
    text-align: center;
    font-weight: bold;
    margin-bottom: 5px;
}

.main-txt {
    text-align: center;
    margin-bottom: 100px;
    font-size: 20px;
}

.archive-hoiku li {
    width: 31%;
    margin-bottom: 25px;
    background: rgba(255, 255, 255, .4);
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0px 4px 10px -2px rgba(0, 0, 0, 0.1);
}

.archive-hoiku-title {
    background: url(/wp-content/uploads/2025/02/line02.png);
    background-repeat: repeat;
    background-size: 300px;
    background-repeat: repeat-x;
    background-position: center bottom;
    padding: 10px;
    margin-bottom: 10px;
}

.archive-hoiku-title a {
    display: block;
    padding-bottom: 20px;
    font-weight: 900;
    text-align: center;
}

.hoiku li {
    width: 45.5%;
    margin: 2%;
}

.hoikuArea {
    padding-top: 0;
}


/*
.sub-header-title{align-items: end;
}
*/

.sub-header-hoiku .sub-header-title {
    align-items: end!important;
}

.afterschool {
    align-items: end;
}

body.afterschool .sub-header-txt,
body.post-template-single-hoiku .sub-header-txt,
body.category-hoiku .sub-header-txt {}

.wp-block-image img {
    border-radius: 5px;
}

.wp-block-image :where(figcaption) {
    padding: 10px;
    line-height: 1.5;
}

.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column {
    margin: 10px;
}

.single-hoiku-wrap .single-info-article {
    margin-top: 30px;
}

.single-hoiku-wrap .news-list01 {
    background: transparent;
    padding: 50px;
    border-radius: 10px;
    box-shadow: none;
}

.single-hoiku-wrap .btn01 {
    padding-right: 50px;
    background-color: transparent;
    color: #524642;
    width: auto;
    max-width: max-content;
}


/*0425*/

.contact-band {
    background-size: cover;
}

.title01 span {
    display: none;
}

.footer-formtlink {
    display: flex;
    gap: 20px;
    max-width: 1600px;
    margin: 30px auto;
    width: 100%;
}

.contact-band .btn01 {
    max-width: unset;
    margin-bottom: 15px;
}

.contact-band .btn01 {
    max-width: unset;
}

.contact-band .btn01 {
    border: #7ED8C2;
    background-color: #7ED8C2;
    color: #fff;
    font-size: 20px;
    padding: 20px 0;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: space-around;
    border: 2px solid #7ED8C2;
    outline: 1px solid #fff;
    outline-offset: -6px;
}

.cf-cb-txt {
    text-align: center;
    font-size: 20px;
}

.footer-formtlink .br-sp {
    display: none;
}

.btn-arrow {
    width: 10px;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}

.cf-tel-number {
    font-size: 4rem;
}

.contact-band-tel-icon {
    width: 40px;
    height: 40px;
    margin-top: 5px;
}

.contact-band-inner {
    padding: 50px 15px;
    background: rgba(0, 0, 0, 0.1);
    color: #fff;
}


/*0728：modal内table幅調整*/

#about .tbl01 {
    width: 100%;
}

.en_logo_area01 {
    /* border: 1px solid #ccc; */
    text-align: center;
    /* padding: 20px; */
    /* border-radius: 30px; */
}

.en_logo_area01 img {
    max-width: 348px;
    margin: 0 auto;
    border-radius: 30px;
}


/*20250920:投稿記事内のボタン装飾*/

.wp-block-buttons .wp-block-button__link {
    width: 100%;
    background: #fac172;
    padding: 20px 30px;
    line-height: 1;
    border-radius: 50px;
    font-size: 18px;
    font-weight: 500;
    color: #333;
}


/*20250925:課外授業の一覧レイアウト調整*/

.list_kagai {
    justify-content: flex-start;
}
/*レイアウト再調整20251020*/
.list_kagai {
    justify-content: center;
}
.list_kagai li {
    width: 21%;
    margin: 0 2% 3%;
}

.single-post_kagai .list_kagai li {
    margin: 0 1% 2%;
}

h3.prehoiku {
    margin-top: 3rem;
}

.frame01_inner p {
    padding: 0 15px;
}

.single-post_kagai .list_kagai {
    margin-top: 50px;
}

.kagai-main-img {
    max-width: 900px;
    width: 90%;
    margin: 0 auto 50px;
}


/*20251003*/

#club .title01 span.sp450-none {
    display: inline-block;
}


/*20251006*/

.com-list02-list li {
    /*text-indent: -1em;
   padding-left: 1em;
	*/
}

.icon_f img {
    width: 20px;
}


/*「１日の流れ」タブ非表示*/

#life .panel-group .tab-A {
    display: none;
}

#life .panel-group .tab-B {
    display: block;
    background-color: var(--main);
    padding: 0 30px 30px;
    margin-top: 30px;
    border-radius: 10px;
}

#life .tab-group  {
    display: none;
}


@media screen and (max-width:820px) {
#life .panel-group .tab-B {
	padding: 0 0 15px;
}
}


.fiximg {
    position: relative;
    height: 80vh;
    /* クリップ用。iOS含め互換性のため両方書く */
    -webkit-clip-path: inset(0);
    clip-path: inset(0);
    /* 子のfixedを同じ“塊”に閉じ込める */
    isolation: isolate;
}
.fiximg img {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    object-fit: cover;
    /* レイヤー化でSafariの描画を安定化 */
    transform: translateZ(0);
}

.pcnone001 {
    display: none;
}

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

    .spnone001 {
        display: none;
    }

    .pcnone001 {
        display: block;
    }

    
}

@media (max-width: 768px) and (orientation: landscape) {
    .fiximg {
      height: 600px; /* 横持ち時はさらに低め */
    }

    .fiximg img {
    height: 1000px;
    }

    .fiximg img.fix-img-spvertical {
        transform: translateY(-600px);
    }
  }