@charset "utf-8";
/*------------------------------------------------------*/
.cmshtml #page-top {
  display: block;
  position: fixed;
  bottom: 60px;
  right: 60px;
  z-index: 33;
  cursor: pointer;
  width: 40px;
  height: 40px;
}
.cmshtml #page-top:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  margin: -5px 0 0 -10px;
  border-top: 2px solid #282828;
  border-right: 2px solid #282828;
  transform: rotate(-45deg);
  transition: all 0.6s ease;
}
.cmshtml #page-top:hover:before {
  top: 0;
}
@media screen and (max-width: 1000px) {
  .cmshtml #page-top {
    bottom: 20px;
    right: 20px;
  }
}
/*------------------------------------------------------*/
.cmshtml .load-fade {
  opacity: 0;
  transition: all 2s;
  overflow: hidden;
}
.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 .subpage .contact_tit.sec_tit {
    color: #fff!important;
}
.cmshtml .subpage .slide_mask_wh:after {
    display: none;
}

/*------------------------------*/
.cmshtml .timeline {
  margin-bottom: 60px;
  position: relative;
}
.cmshtml .timeline_box {
  align-items: flex-start;
  position: relative;
}
.cmshtml .timeline_box:not(:last-child) {
  padding-bottom: 40px!important;
}
.cmshtml .timeline_box:not(:last-child):before {
  background-color: #707070;
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  margin: auto;
  position: absolute;
  left: 70px;
  top: 0;
  z-index: -1;
}
.cmshtml .timeline_box > div:first-child {
  width: 145px;
}
.cmshtml .timeline_box > div:nth-child(2) {
  width: calc(100% - 145px);
}
.cmshtml .time_l {
  background: #fff;
  color: #23A943;
  font-size: 28px;
  font-weight: 600;
  text-align: center;
  padding: 15px 0!important;
  position: relative;
}
.cmshtml .timeline_r {
  background: #F9F7EE;
  padding: 20px 25px!important;
  position: relative;
}
.cmshtml .timeline_tit {
  font-weight: 600;
  color: #2B2B2B;
}
.cmshtml .timeline_txt {
  color: #2B2B2B;
}
@media screen and (max-width: 680px) {
  .cmshtml .timeline_box {
    display: block;
  }
  .cmshtml .timeline_box:not(:last-child) {
    padding-bottom: 20px!important;
  }
  .cmshtml .timeline_box:not(:last-child):before {
    left: 18px;
  }
  .cmshtml .time_l {
    font-size: 20px;
    text-align: left;
    padding-top: 0!important;
    padding-bottom: 5px!important;
  }
  .cmshtml .timeline_box > div:nth-child(1), .cmshtml .timeline_box > div:nth-child(2) {
    width: 100%;
  }
  .cmshtml .timeline_r {
    padding: 10px!important;
    max-width: calc(100% - 55px);
    margin-left: auto;
  }
  .cmshtml .timeline_tit {
    font-size: 15px;
  }
  .cmshtml .timeline_txt {
    font-size: 14px;
  }
}
/*------------------------------*/
.cmshtml .prof {
  position: relative;
}
.cmshtml .prof_img {
  width: 55%;
  position: relative;
  z-index: 1;
}
.cmshtml .prof_textbox {
  width: 45%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-top: min(8vw, 150px);
  position: relative;
  z-index: 10;
  transform: translateX(-70px);
}
.cmshtml .prof_voice {
  background: #fff;
  font-size: 18px;
  font-weight: 600;
  padding: 15px 10%!important;
  margin-bottom: 30px;
  position: relative;
}
.cmshtml .prof_voice:before, .cmshtml .prof_voice:after {
  content: "";
  display: block;
  width: 32px;
  height: 35px;
  margin: auto;
  position: absolute;
  z-index: 10;
  pointer-events: none;
}
.cmshtml .prof_voice:before {
  border-top: 10px solid #23A943;
  border-left: 10px solid #23A943;
  top: -3px;
  left: -5px;
}
.cmshtml .prof_voice:after {
  border-bottom: 10px solid #2B2B2B;
  border-right: 10px solid #2B2B2B;
  bottom: -3px;
  right: -5px;
}
.cmshtml .prof_plate {
  background: #23A943;
  padding: 20px 14% 30px!important;
  position: relative;
}
.cmshtml .prof_name_box {
  border-bottom: 1px solid #fff;
  padding-right: 45px!important;
  align-items: center;
}
.cmshtml .prof_name, .cmshtml .prof_name_ruby, .cmshtml .prof_year, .cmshtml .prof_department, .cmshtml .prof_link, .cmshtml .prof_name a, .cmshtml .prof_name_ruby a, .cmshtml .prof_year a, .cmshtml .prof_department a, .cmshtml .prof_link a {
  color: #fff;
}
.cmshtml .prof_name {
  color: #fff;
  font-size: 30px;
  font-weight: 600;
  padding-right: 20px!important;
}
.cmshtml .prof_name_ruby {
  font-size: 14px;
}
.cmshtml .prof_about {
  padding: 10px 5px 0px!important;
  margin-bottom: 20px;
  position: relative;
}
.cmshtml .prof_year {
  position: relative;
}
.cmshtml .prof_department {
  padding-left: 20px!important;
  margin-left: 20px;
  position: relative;
}
.cmshtml .prof_department:before {
  background-color: #fff;
  content: "";
  display: block;
  width: 2px;
  height: 80%;
  margin: auto;
  position: absolute;
  left: 0;
  top: 0;
  z-index: auto;
  transition: all 0.3s;
  transform: rotate(25deg);
}
.cmshtml .prof_link {
  font-size: 10px;
  font-weight: 600;
  text-align: center;
}
.cmshtml .prof_link a {
  border: 1px solid #fff;
  display: inline-block;
  text-decoration: none;
  padding: 10px 50px!important;
  max-width: 250px;
  width: 100%;
  transition: all 0.3s;
}
.cmshtml .prof_link a:hover {
  background: #fff;
  color: #333;
}
.cmshtml .prof_re {
  position: relative;
}
.cmshtml .prof_re .prof_textbox {
  align-items: flex-end;
  transform: translateX(70px);
}
.cmshtml .prof_re .prof_voice:before {
  border: none;
  border-bottom: 10px solid #2B2B2B;
  border-left: 10px solid #2B2B2B;
  top: auto;
  right: auto;
  bottom: -3px;
  left: -5px;
}
.cmshtml .prof_re .prof_voice:after {
  border: none;
  border-top: 10px solid #23A943;
  border-right: 10px solid #23A943;
  bottom: auto;
  left: auto;
  top: -3px;
  right: -5px;
}
@media screen and (max-width: 1200px) {
  .cmshtml .prof_img, .cmshtml .prof_textbox {
    width: 50%;
  }
  .cmshtml .prof_voice {
    font-size: 16px;
    padding: 15px 40px!important;
  }
  .cmshtml .prof_plate {
    padding: 20px 20px!important;
  }
  .cmshtml .prof_textbox {
    display: block;
    margin-top: 60px;
    transform: translateX(-30px);
  }
  .cmshtml .prof_re .prof_textbox {
    transform: translateX(30px);
  }
  .cmshtml .prof_name_box {
    padding: 0 5px 5px!important;
  }
  .cmshtml .prof_name {
    font-size: 22px;
  }
  .cmshtml .prof_voice:before {
    border-top: 5px solid #23A943;
    border-left: 5px solid #23A943;
    top: -3px;
    left: -3px;
  }
  .cmshtml .prof_voice:after {
    border-bottom: 5px solid #2B2B2B;
    border-right: 5px solid #2B2B2B;
    bottom: -3px;
    right: -3px;
  }
  .cmshtml .prof_year, .cmshtml .prof_department {
    font-size: 14px;
  }
  .cmshtml .prof_department {
    padding-left: 15px!important;
    margin-left: 15px;
  }
  .cmshtml .prof_link a {
    padding: 10px 50px!important;
    max-width: 200px;
  }
  .cmshtml .prof_re .prof_voice:before {
    border: none;
    border-bottom: 5px solid #2B2B2B;
    border-left: 5px solid #2B2B2B;
    bottom: -3px;
    left: -3px;
  }
  .cmshtml .prof_re .prof_voice:after {
    border: none;
    border-top: 5px solid #23A943;
    border-right: 5px solid #23A943;
    top: -3px;
    right: -3px;
  }
}
@media screen and (max-width: 680px) {
  .cmshtml .prof_img, .cmshtml .prof_textbox {
    width: 100%;
  }
  .cmshtml .prof_textbox {
    margin: 0;
    transform: none !important;
  }
  .cmshtml .prof_voice {
    text-align: center;
    padding: 15px 40px!important;
    margin: 15px auto;
  }
  .cmshtml .prof_voice:before {
    top: 0;
    left: 0;
  }
  .cmshtml .prof_voice:after {
    bottom: 0;
    right: 0;
  }
  .cmshtml .prof_re {
    flex-direction: column-reverse;
  }
  .cmshtml .prof_re .prof_voice:before {
    bottom: 0;
    left: 0;
  }
  .cmshtml .prof_re .prof_voice:after {
    top: 0;
    right: 0;
  }
}
@media screen and (max-width: 450px) {
  .cmshtml .prof_voice {
    font-size: 14px;
    padding: 20px 15px!important;
    margin: 15px auto;
  }
  .cmshtml .prof_voice:before, .cmshtml .prof_voice:after {
    width: 20px;
    height: 30px;
  }
  .cmshtml .prof_name_box {
    justify-content: center;
  }
  .cmshtml .prof_name {
    font-size: 18px;
  }
  .cmshtml .prof_name_ruby {
    font-size: 12px;
  }
  .cmshtml .prof_about {
    justify-content: center;
  }
  .cmshtml .prof_year {
    font-size: 12px;
  }
  .cmshtml .prof_department {
    padding-left: 15px!important;
    margin-left: 15px;
    font-size: 12px;
  }
}
#editView .cmshtml .prof_img, #editView .cmshtml .prof_textbox {
  width: 100%;
}
#editView .cmshtml .prof_textbox {
  display: block;
  margin-top: 0;
  transform: none !important;
}
#editView .cmshtml .prof_voice:before, #editView .cmshtml .prof_voice:after {
  display: none;
}
#editView .cmshtml .prof > div:has(.prof_img) {
  width: 55%;
}
#editView .cmshtml .prof > div:has(.prof_textbox) {
  width: 45%;
}
/*------------------------------*/