 /*                      culture                    */
 .culture {
  background-color: #F1EEEE;
 }
.culture .page_top_ttl >div {
 width: min(23.3rem, calc(233vw / 12.8));
}
.culture_contents {
 padding-bottom:  min(11.5rem, calc(115vw / 12.8));
}
.culture_item {
 width: min(88.8rem, calc(888vw / 12.8));
 margin: 0 auto min(11.5rem, calc(115vw / 12.8));
 position: relative;
}
.culture_item:last-of-type {
 margin-bottom:0;
}
.culture_img {
 overflow: hidden;
}
.culture_img img{
 transition: .4s;
}
.culture_item p {
 width: min(29.5rem, calc(295vw / 12.8));
 background-color: #B5002B;
 position: absolute;
 bottom:  max(-3.3rem, calc(-33vw / 12.8));
 right: 0;
 box-sizing: border-box;
 border:  min(.4rem, calc(4vw / 12.8)) solid #B5002B;
}
.culture_item p span {
 width:  min(26.6rem, calc(266vw / 12.8));
 margin-left: auto;
 display: block;
 background-color: #fff;
 font-size: 1.7rem;
 letter-spacing: 0.045em;
 font-weight: 600;
 color: #B5002B;
 padding:  min(1.1rem, calc(11vw / 12.8)) 0;
 transition: .4s;
}
.culture_item p::before {
 content: '';
 width: min(.8rem, calc(6vw / 12.8));
 height: min(.8rem, calc(6vw / 12.8));
 border-top: min(.3rem, calc(3vw / 12.8)) solid #B5002B;
 border-right: min(.3rem, calc(3vw / 12.8)) solid #B5002B;
 position: absolute;
 top: 50%;
 transform: translateY(-50%) rotate(45deg);
 right: min(3.2rem, calc(32vw / 12.8));
 transition: .4s;
}


@media (hover: hover)  and (pointer: fine){
 .culture_item a:where(:any-link, :enabled, summary):hover  p span{
  background-color: #B5002B;
  color: #fff;
 }
 .culture_item a:where(:any-link, :enabled, summary):hover  p::before{
  border-color: #fff;
 }
 .culture_item a:where(:any-link, :enabled, summary):hover  .culture_img img{
  transform: scale(1.1);
 }
}


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

.culture .page_top_ttl >div {
 width:7.5rem;
 font-size: 0;
 margin-right: 0.5rem;
}
.culture_contents {
 padding-bottom: 9rem;
}
.culture_item {
 width:32.5rem;
 margin: 0 auto 5rem;
}
.culture_item:last-of-type {
 margin-bottom: 0;
}

.culture_item p {
 width: 18rem;
 bottom: -2.2rem;
 border:  .2rem solid #B5002B;
}
.culture_item p span {
 font-size: 1.2rem;
 width: 16.5rem;
 padding: .8rem 0;
}
.culture_item p::before {
 width:.6rem;
  height:.6rem;
  border-top:.2rem solid #B5002B;
  border-right:.2rem solid #B5002B;
  right:1.4rem;
}

}


 /*                      education                    */
 .education_contents,
 .welfare_contents {
  background: #fff;
 }
.education_top,
.welfare_top {
 width: min(108rem, calc(1080vw / 12.8));
 margin: 0 auto;
 text-align: justify;
 padding:  min(5rem, calc(50vw / 12.8)) 0  min(8rem, calc(80vw / 12.8));
}
.education_top_ttl,
.welfare_top_ttl {
 font-size: 2.8rem;
 font-weight: 600;
 color: #b5002b;
 letter-spacing: 0.06em;
 margin-bottom: min(1.6rem, calc(16vw / 12.8));
}

.education_top_txt,
.welfare_top_txt {
font-size: 1.8rem;
font-weight: 500;
letter-spacing: 0.08em;
line-height: 2
}
.education_img {
 width: min(114rem, calc(1140vw / 12.8));
 margin: 0 auto;
}


.education_item {
 width: min(89rem, calc(890vw / 12.8));
 margin: min(6rem, calc(60vw / 12.8)) auto 0;
}
.education_item dl {
 margin-bottom: min(5.6rem, calc(56vw / 12.8));
}
.education_item dl:last-of-type {
 margin-bottom: 0;
}
.education_item dt {
 display: flex;
 align-items: center;
 line-height: 1.6;
 font-size: 2.8rem;
    font-weight: 600;
    color: #b5002b;
    letter-spacing: 0.06em;
    margin-bottom: min(1.6rem, calc(16vw / 12.8));
}
.education_item dt::before {
 content: '';
 display: block;
 width:  min(0.8rem, calc(8vw / 12.8));
 height:  min(4rem, calc(40vw / 12.8));
 background-color: #F2D8C9;
 margin-right: min(1.6rem, calc(16vw / 12.8));
}
.education_item dd {
 text-align: justify;
 margin-top: min(0.8rem, calc(8vw / 12.8));
font-size: 1.8rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    line-height: 2;
}




@media screen and (max-width: 767px) {
 .education_inner {
  overflow: hidden;
  padding-bottom: 7rem;
 }
.education_top,
.welfare_top {
        width: 100%;
        padding: 2.4rem 2.8rem 2.4rem;
        box-sizing: border-box;
}
.education_top_ttl,
.welfare_top_ttl {
   font-size: 1.6rem;
        margin-bottom: 1rem;
}

.education_top_txt,
.welfare_top_txt {
 font-size: 1.4rem;
        letter-spacing: 0.06em;
        text-align: justify;
}
.education_img {
 width: 100%;
 margin-left:0;
 overflow-x: scroll;
 position: relative;
}
.education_img .scrollhint {
 background: url(../images/culture/education/scrollhint.webp) no-repeat;
 background-size: cover;
 width: 4rem;
 height: 3.5rem;
 position: absolute;
 top: 1.5rem;
 left: 1rem;
 z-index: 10;
}

.education_img img {
 width: 80rem !important;
}


.education_item {
         width: 100%;
        padding: 4rem 2.8rem 0;
	margin: 0 auto;
	box-sizing: border-box;
}
.education_item dl {
 margin-bottom:2.8rem;
}
.education_item dt {
 font-size: 1.6rem;
}
.education_item dt::before {
 width: .4rem;
 height: 2rem;
 margin-right:1rem;
}
.education_item dd {
 font-size: 1.4rem;
 margin-top: 1rem;
}

 .education::-webkit-scrollbar {
  display: none;
 }
 .education .simplebar-track.simplebar-horizontal {
  height: 0.8rem;
  width: 32rem;
  margin: 0 auto;
  background-color: #EBEBEB;

 }
 .education .simplebar-scrollbar::before {
  background-color: #B5002B;
  width: 100%;
  height: 100%;
  border-radius: 1rem;
 }
 .education .simplebar-track.simplebar-horizontal .simplebar-scrollbar {
  height:  .8rem;
  top: 0;
  min-width: 0;
 }
 .education .simplebar-track {
  border: none;
  padding:  0;
  overflow: visible;
  box-sizing: border-box;
 }
 .education .simplebar-scrollbar.simplebar-visible::before {
  opacity: 1;
 }



}





 /*                      welfare                    */

 .welfare_item {
  width: min(108rem, calc(1080vw / 12.8));
  margin: 0 auto;
 }
 .welfare_item_ttl {
  text-align: left;
  font-size: 2.8rem;
    font-weight: 600;
    color: #b5002b;
    letter-spacing: 0.06em;
 }
 .welfare_list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: min(6.5rem, calc(65vw / 12.8));
 }
 .welfare_list:last-of-type {
  margin-bottom: 0;
 }
 .welfare_list li {
  width: min(53rem, calc(530vw / 12.8));
  background-color: #F1EEEE;
  box-shadow: 0  min(.3rem, calc(3vw / 12.8))  min(.6rem, calc(6vw / 12.8)) #00000026;
  display: flex;
  justify-content: space-between;
  box-sizing: border-box;
  align-items: center;
  padding: 0 min(4rem, calc(40vw / 12.8)) 0 min(3.2rem, calc(32vw / 12.8));
  margin-top: min(2.5rem, calc(25vw / 12.8));
  min-height:  min(20rem, calc(200vw / 12.8));
 }
 .welfare_list li .welfare_icon {
  width: min(10.5rem, calc(105vw / 12.8));
 }
 .welfare_list li p {
  width: min(33rem, calc(330vw / 12.8));
  font-size: 1.7rem;
  letter-spacing: 0.04em;
  font-weight: 500;
  line-height: 1.6;
  text-align: left;
 }
 .welfare_list li p  span {
  font-size: 2.2rem;
  font-weight: 600;
  color: #B5002B;
 display: block;
 margin-bottom: min(1.2rem, calc(12vw / 12.8));
 }


@media screen and (max-width: 767px) {
 .welfare_inner {
  padding-bottom: 7rem;
 }
 .welfare_item {
  width: 100%;
  padding: 0 2.8rem;
  box-sizing: border-box;
 }
 .welfare_item_ttl {
  font-size: 1.6rem;
 }
 .welfare_list {
  margin-bottom:3rem
 }
 .welfare_list li {
  width:100%;
  box-shadow: 0  .2rem .3rem #00000026;
  padding:0 1.6rem;
  margin-top:1.6rem;
  min-height: 12rem
 }
 .welfare_list li .welfare_icon {
  width: 6.4rem;
 }
 .welfare_list li p {
  width: 21rem;
  font-size: 1.2rem;
 }
 .welfare_list li p  span {
  font-size: 1.4rem;
 margin-bottom:.8rem;
 }
}
