@charset "utf-8";
/*------------------------------------------------------*/
.cmshtml #page-top {
  box-shadow: rgba(0, 0, 0, 0.2) 0 3px 6px;
  border-radius: 50%;
  background: #73D1B0;
  cursor: pointer;
  display: block;
  width: 57px;
  height: 57px;
  position: fixed;
  bottom: 87px;
  right: 87px;
  z-index: 33;
  transition: all 0.3s;
}
.cmshtml #page-top:before {
  background: #fff;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  content: "";
  display: block;
  width: 17px;
  height: 14px;
  margin: auto;
  position: absolute;
  top: 0%;
  bottom: 0;
  left: 0%;
  right: 0;
  transition: all 0.6s ease;
}
.cmshtml #page-top:hover {
  background: #48C096;
}
@media screen and (max-width: 1670px) {
  .cmshtml #page-top {
    bottom: 20px;
    right: 20px;
  }
}
@media screen and (max-width: 1000px) {
  .cmshtml #page-top {
    bottom: 20px;
    right: 20px;
    width: 40px;
    height: 40px;
  }
  .cmshtml #page-top:before {
    width: 13px;
    height: 10px;
  }
}
/*------------------------------------------------------*/
.cmshtml .load-fade {
  opacity: 0;
  transition: all 2s;
}
.cmshtml .load-fade.done {
  opacity: 1;
}
.cmshtml .to-lr {
  opacity: 0;
  transform: translateX(-40px);
  transition: all 1s;
}
.cmshtml .to-rl {
  opacity: 0;
  transform: translateX(40px);
  transition: all 1s;
}
.cmshtml .to-lr.scrollin, .cmshtml .to-rl.scrollin {
  opacity: 1;
  transform: translate(0);
}
/*------------------------------------------------------*/
.cmshtml .fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}
@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media screen and (max-width: 1000px) {
  .cmshtml .fadeUp {
    animation-name: fadeUpAnime_sp;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    opacity: 0;
  }
}
@keyframes fadeUpAnime_sp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.cmshtml .md_inwrap .fadeUp {
  animation-name: fadeUpAnime02;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
}
@keyframes fadeUpAnime02 {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/*------------------------------------------------------*/
.cmshtml .rehabili_img img {
  opacity: 0;
  transform: scale(0.8) translateY(20px);
}
.cmshtml .active_block .rehabili_img img {
  animation-name: zoom_in;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
}
.cmshtml .active_block .rehabili_img02 img {
  animation-delay: 1s;
}
.cmshtml .active_block .rehabili_img03 img {
  animation-delay: 0.5s;
}
@keyframes zoom_in {
  from {
    opacity: 0;
    transform: scale(0.8) translateY(20px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0px);
  }
}
/*------------------------------------------------------*/
.cmshtml .rehabili_img img {
  opacity: 0;
  transform: scale(0.8) translateY(20px);
}
.cmshtml .active_block .rehabili_img img {
  animation-name: zoom_in;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
}
.cmshtml .active_block .rehabili_img02 img {
  animation-delay: 1s;
}
.cmshtml .active_block .rehabili_img03 img {
  animation-delay: 0.5s;
}
@keyframes zoom_in {
  from {
    opacity: 0;
    transform: scale(0.8) translateY(20px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0px);
  }
}
/*------------------------------------------------------*/
.cmshtml .about_textbox {
  opacity: 0;
  transform: translateY(20px);
}
.cmshtml .active_block .about_textbox {
  animation-name: about_fade_up;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
}
@keyframes about_fade_up {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0px);
  }
}
.cmshtml .about_img img {
  opacity: 0;
  transform: scale(0.8) translateY(20px);
}
.cmshtml .active_block .about_img img {
  animation-name: zoom_in02;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
}
.cmshtml .active_block .about_img01 img {
  animation-delay: 1s;
}
.cmshtml .active_block .about_img02 img {
  animation-delay: 0.5s;
}
@keyframes zoom_in02 {
  from {
    opacity: 0;
    transform: scale(0.8) translateY(20px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0px);
  }
}
/*------------------------------------------------------*/
.cmshtml .f_access .f_map {
  transition-delay: 0.3s;
}
.cmshtml .f_contact .fade-up {
  transition-delay: 1s;
}
/*------------------------------------------------------*/
.cmshtml .scnews .rdnewArticle {
  padding: 0;
  border: none;
}
.cmshtml .scnews .rdnewArticle .rdnewArticle-item {
  padding: 0;
}
.cmshtml .scnews .rdnewArticle .rdnewArticle-contWrap {
  display: flex;
  padding: 7.5px 0;
}
.cmshtml .scnews .rdnewArticle .rdnewArticle-ContDate {
  font-size: 18px;
  max-width: 145px;
  min-width: 145px;
}
.cmshtml .scnews .rdnewArticle .rdnewArticle-ContTitle {
  font-size: 16px;
  margin-left: 40px;
}
.cmshtml .scnews .rdnewArticle .rdnewArticle-ContDate, .cmshtml .scnews .rdnewArticle .rdnewArticle-ContTitle, .cmshtml .scnews .rdnewArticle .rdnewArticle-ContDate a, .cmshtml .scnews .rdnewArticle .rdnewArticle-ContTitle a {
  color: #191919;
  transition: all 0.3s;
  text-decoration: none;
}
.cmshtml .scnews .rdnewArticle .rdnewArticle-item:has(a):hover .rdnewArticle-ContDate,
.cmshtml .scnews .rdnewArticle .rdnewArticle-item:has(a):hover .rdnewArticle-ContTitle,
.cmshtml .scnews .rdnewArticle .rdnewArticle-item:has(a):hover .rdnewArticle-ContDate a,
.cmshtml .scnews .rdnewArticle .rdnewArticle-item:has(a):hover .rdnewArticle-ContTitle a {
  color: #89D5BB;
}
.cmshtml .scnews .rdnewArticle .rdnewArticle-item {
    position: relative;
}
.cmshtml .scnews .rdnewArticle .rdnewArticle-item a:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    margin: auto;
    padding: 0;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    transition: all 0.3s;
}
.cmshtml .scnews .rdnewArticle .rdnewArticle-item+.rdnewArticle-item {
    border-top: none;
}
@media screen and (max-width: 1000px) {
  .cmshtml .scnews .rdnewArticle .rdnewArticle-contWrap {
    display: block;
    padding: 5px 0;
  }
  .cmshtml .scnews .rdnewArticle .rdnewArticle-ContDate {
    font-size: 14px;
    max-width: none;
    min-width: 1px;
  }
  .cmshtml .scnews .rdnewArticle .rdnewArticle-ContTitle {
    font-size: 14px;
    margin-top: 5px;
    margin-left: 0;
  }
}
/*------------------------------------------------------*/
.cmshtml .common_area {
  padding: 30px 0;
  position: relative;
}
.cmshtml .page_link {
  justify-content: flex-start;
}
.cmshtml .common_area > * {
  max-width: 1200px;
  width: 92%;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 20px;
}
@media screen and (max-width: 680px) {
  .cmshtml .common_area {
    padding: 30px 0 1px;
    background: #f2fbf8;
  }
  .cmshtml .common_area > *.rdblock {
    max-width: 96%;
    margin-left: auto !important;
  }
}
.cmshtml .p_link_area .p_link {
  margin-bottom: 10px;
}
.cmshtml .p_link_area .p_link_c {
  font-size: 14px;
    margin-left: 6px;
}
.cmshtml .p_link_area .p_link_c a {
  padding-left: 10px;
}
.cmshtml .p_link_area .p_link_c a:after {
  background: #969696;
  border-radius: 50%;
  clip-path: none;
  width: 3px;
  height: 3px;
}
#editView .cmshtml .p_link_area {
  min-width: 120px;
}
#editView .cmshtml .p_link_area:has(.p_link) {
  min-width: 1px;
}

/*------------------------------------------------------*/

.cmshtml .text_slide .rdslideItem {
    position: relative;
}
.cmshtml .text_slide .rdslideItem img {
    position: relative;
    z-index: 1;
}
.cmshtml .text_slide .rdslideItem .img_alt_txt {
    background: rgba(0, 0, 0, 0.5);
    font-size: 30px;
    color: #fff;
    font-weight: 500;
    width: 100%;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}

@media screen and (max-width: 768px) {
.cmshtml .text_slide .rdslideItem .img_alt_txt {
    font-size: 22px;
}
}