@charset "utf-8";
/* CSS Document */
.default_txt2{
  font-size: clamp(14px, 1vw, 15px);
}
.section05{
  position: relative;
  background:
    linear-gradient(rgba(255,255,255,.88),rgba(255,255,255,.88)),
    url("https://risora.jp/system_panel/uploads/images/bg1.jpg") center center / cover no-repeat;
}


.newstop_h {
  background: #fff;
}
.newstop_h .titlebox {
  text-align: center;
}
.newstop_h .titlebox .entitle3 {
  line-height: 1.2;
  font-weight: 400;
  letter-spacing: .04em;
}
.newstop_h .titlebox h2 {
  color: #333;
  line-height: 1.4;
  letter-spacing: .12em;
  font-weight: 400;
}
.newstop_h .contents .webgene-blog {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  gap: clamp(30px, 3vw, 40px);
}
.newstop_h .contents .webgene-blog .webgene-item {
  width: calc((100% - (clamp(30px, 3vw, 40px) * 3)) / 4);
}
.newstop_h .contents .webgene-blog .webgene-item a {
  display: block;
  color: #333;
  text-decoration: none;
  transition: .3s ease;
}
.newstop_h .contents .webgene-blog .webgene-item .imgbox {
  width: 100%;
  aspect-ratio: 1.45 / 1;
  overflow: hidden;
  border-radius: 14px;
  margin-bottom: clamp(12px, 1.4vw, 16px);
}
.newstop_h .contents .webgene-blog .webgene-item .imgbox img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity .3s ease;
}
.newstop_h .contents .webgene-blog .webgene-item a:hover .imgbox img {
  opacity: .85;
}
.newstop_h .contents .webgene-blog .webgene-item .txtbox {
  margin-bottom: clamp(10px, 1.2vw, 14px);
}
.newstop_h .contents .webgene-blog .webgene-item h2 {
  color: #333;
  line-height: 1.8;
  letter-spacing: .08em;
  font-weight: 400;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.newstop_h .contents .webgene-blog .webgene-item .catebox {
  align-items: center;
  gap: 12px;
}
.newstop_h .contents .webgene-blog .webgene-item .date {
  color: #666;
  line-height: 1.4;
  letter-spacing: .04em;
  font-weight: 400;
}
.newstop_h .contents .webgene-blog .webgene-item .catename {
  color: #fff;
  line-height: 1;
  letter-spacing: .08em;
  font-weight: 400;
  background: #8cc63f;
  border-radius: 999px;
  padding: 6px 14px;
  white-space: nowrap;
}
@media screen and (max-width: 1080px) {
  .newstop_h .contents .webgene-blog {
    gap: 36px 30px;
  }
  .newstop_h .contents .webgene-blog .webgene-item {
    width: calc(50% - 15px);
  }
}
@media screen and (max-width: 576px) {
  .newstop_h .contents .webgene-blog {
    width: 100%;
    gap: 32px;
  }
  .newstop_h .contents .webgene-blog .webgene-item {
    width: 100%;
  }
  .newstop_h .contents .webgene-blog .webgene-item .imgbox {
    border-radius: 10px;
  }
  .newstop_h .contents .webgene-blog .webgene-item .catebox {
    gap: 10px;
  }
}

.section03{
  position: relative;
  background:
    linear-gradient(
      to bottom,
      rgba(232,231,226,.95) 0px,
      rgba(232,231,226,.88) 220px,
      rgba(232,231,226,.0) 400px
    ),
    url("https://risora.jp/system_panel/uploads/images/bgtop.jpg") center top / cover no-repeat;
}
.features_c .titlebox h2{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(10px,1.4vw,18px);
  color: #333;
  line-height: 1.5;
  letter-spacing: .12em;
  font-weight: 400;
}

.features_c .titlebox h2 img{
  width: clamp(28px,3vw,42px);
  height: auto;
}

.features_c .titlebox p{
  line-height: 1.2;
  letter-spacing: .18em;
  font-weight: 400;
}

.features_c .features_wrap{
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: clamp(24px,2.4vw,34px);
}

.features_c .feature_item{
  background: rgba(255,255,255,.92);
  border: 1px solid #9f9a93;
  padding: clamp(24px,3vw,38px) clamp(20px,2.6vw,34px) clamp(30px,3vw,42px);
  text-align: center;
  min-height: 100%;
}

.features_c .feature_item .point{
  margin-bottom: clamp(14px,1.6vw,20px);
}

.features_c .feature_item .point img{
  display: block;
  width: clamp(42px,4vw,56px);
  height: auto;
  margin: 0 auto 4px;
}

.features_c .feature_item .point p{
  color: #4a443f;
  line-height: 1;
  letter-spacing: .04em;
}

.features_c .feature_item .imgbox{
  width: clamp(120px,12vw,170px);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto clamp(20px,2vw,28px);
}

.features_c .feature_item .imgbox img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.features_c .feature_item h3{
  line-height: 1.6;
  letter-spacing: .12em;
  font-weight: 400;
  margin-bottom: clamp(10px,1.2vw,16px);
}

.features_c .feature_item > p{
  color: #333;
  line-height: 2;
  letter-spacing: .08em;
  text-align: left;
}

.features_c .mini_btn{
  margin-top: 14px;
}

.features_c .mini_btn a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #8cc63f;
  border-radius: 999px;
  padding: 7px 20px;
  text-decoration: none;
  transition: .3s ease;
}

.features_c .mini_btn a p{
  color: #fff;
  font-size: clamp(12px,1.1vw,14px);
  line-height: 1;
  letter-spacing: .08em;
}

.features_c .mini_btn a:hover{
  opacity: .85;
  transform: translateY(-2px);
}

@media screen and (max-width: 1080px){
  .features_c .features_wrap{
    grid-template-columns: repeat(2,1fr);
  }
}

@media screen and (max-width: 576px){
  .features_c .features_wrap{
    grid-template-columns: 1fr;
  }

  .features_c .titlebox h2{

  }

  .features_c .feature_item{
    padding: 28px 20px 34px;
  }
}
.section04.hygiene_d{
  position: relative;
  overflow: hidden;
  background: #fff;
}

.section04.hygiene_d::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 34%;
  height: 100%;
  background:
    radial-gradient(circle at 18% 8%, rgba(140,198,63,.16) 0, rgba(140,198,63,0) 28%),
    linear-gradient(to right, rgba(232,231,226,.5), rgba(255,255,255,0));
  pointer-events: none;
}

.section04.hygiene_d::after{
  content: "";
  position: absolute;
  left: clamp(28px,4vw,64px);
  top: clamp(28px,4vw,64px);
  width: clamp(180px,20vw,310px);
  height: clamp(160px,18vw,260px);
  border-left: 1px solid rgba(80,80,80,.22);
  border-top: 1px solid rgba(80,80,80,.22);
  pointer-events: none;
}

.hygiene_d .hygiene_inner{
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 54% 46%;
  align-items: stretch;
  min-height: clamp(420px,44vw,560px);
}

.hygiene_d .txtbox{
  position: relative;
  z-index: 2;
  padding: clamp(70px,8vw,120px) ;
 
}



.hygiene_d .titlebox{
  position: relative;
  padding-bottom: clamp(14px,1.6vw,20px);
}

.hygiene_d .titlebox::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: clamp(220px,28vw,420px);
  height: 1px;
  background: linear-gradient(to right, #8cc63f 0%, rgba(140,198,63,.45) 78%, transparent 100%);
}

.hygiene_d .titlebox h2{
  line-height: 1.6;
  letter-spacing: .14em;
  font-weight: 400;
}

.hygiene_d .txtbox > p{
  position: relative;
  z-index: 4;
  color: #333;
  line-height: 2.25;
  letter-spacing: .08em;
  font-weight: 400;
}

.hygiene_d .icon_wrap{
  position: relative;
  z-index: 4;
  gap: clamp(22px,3vw,42px);
  margin-top: clamp(34px,4vw,54px);

  justify-content: flex-start;
}

.hygiene_d .icon_item{
  width: clamp(72px,7vw,96px);
  aspect-ratio: 1 / 1;
  border: 1px solid rgba(140,198,63,.8);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.58);
}

.hygiene_d .icon_item img{
  width: 60px;
  height: auto;
  object-fit: contain;
  display: block;
}

.hygiene_d .imgbox{
  position: relative;
  overflow: hidden;
  min-height: 100%;
}

.hygiene_d .imgbox::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(255,255,255,1) 0%, rgba(255,255,255,.34) 22%, rgba(255,255,255,0) 45%),
    radial-gradient(ellipse at left center, rgba(255,255,255,.7) 0, rgba(255,255,255,0) 48%);
  z-index: 1;
  pointer-events: none;
}

.hygiene_d .imgbox::after{
  content: "";
  position: absolute;
  left: -120px;
  top: -8%;
  width: 240px;
  height: 116%;
  border-right: 1px solid rgba(140,198,63,.45);
  border-radius: 50%;
  z-index: 2;
  pointer-events: none;
}

.hygiene_d .imgbox img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

@media screen and (max-width: 1080px){
  .hygiene_d .hygiene_inner{
    grid-template-columns: 58% 42%;
  }

  .hygiene_d .txtbox{
    padding: 48px 40px;
  }

  .hygiene_d .txtbox > p br{
    display: none;
  }
      .section04.hygiene_d::after{
    display: none;
  }
}

@media screen and (max-width: 768px){
    
  .hygiene_d .hygiene_inner{
    display: flex;
    flex-direction: column-reverse;
    min-height: 0;
  }

  .hygiene_d .txtbox{
    padding: 34px 20px 0;
    background: rgba(255,255,255,.9);
  }

  .hygiene_d .txtbox::after{
    display: none;
  }

  .hygiene_d .imgbox{
    aspect-ratio: 4 / 3;
  }

  .hygiene_d .imgbox::after{
    display: none;
  }

  .hygiene_d .icon_wrap{
    justify-content: center;
  }
}

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


  .hygiene_d .hygiene_inner::before{
    width: 45%;
    left: -12%;
    top: -6%;
  }

  .hygiene_d .titlebox h2{
    font-size: 20px;
  }

  .hygiene_d .icon_wrap{
    gap: 14px;
  }

  .hygiene_d .icon_item{
    width: 68px;
  }
}
.course_e{
}
.course_e .titlebox{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(10px,1.8vw,22px);
    
}

.course_e .titlebox h2{
  color: #333;
  line-height: 1.6;
  letter-spacing: .12em;
  font-weight: 400;
    min-width: 300px;
}

.course_e .titlebox h2 span{
  color: #8cc63f;
  padding: 0 .15em;
}

.course_e .titlebox .title_deco img{
  display: block;
  width: clamp(70px,10vw,130px);
  height: auto;
}

.course_e .titlebox .title_deco.left{
  transform: scaleX(-1);
}
.course_e .course_wrap{
  justify-content: center;
  align-items: stretch;
}

.course_e .course_item{
  position: relative;
  width: calc(100% / 3);
  text-align: center;
  padding: clamp(10px,1.5vw,20px) clamp(28px,4vw,70px);
  border-left: 1px dotted rgba(140,198,63,.55);
}

.course_e .course_item:last-child{
  border-right: 1px dotted rgba(140,198,63,.55);
}

.course_e .course_item .icon{
  width: clamp(54px,6vw,82px);
  aspect-ratio: 1 / 1;
  margin: 0 auto clamp(18px,2vw,26px);
}

.course_e .course_item .icon img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.course_e .course_item h3{
  color: #333;
  line-height: 1.6;
  letter-spacing: .12em;
  font-weight: 400;
  margin-bottom: clamp(8px,1vw,14px);
}

.course_e .course_item > p{
  color: #333;
  line-height: 2;
  letter-spacing: .08em;
  font-weight: 400;
  text-align: left;
}

.course_e .course_item a{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  aspect-ratio: 1 / 1;
  border: 1px solid #8cc63f;
  border-radius: 50%;
  margin: clamp(14px,1.6vw,20px) auto 0;
  transition: .3s ease;
}

.course_e .course_item a::before{
  content: "";
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 7px solid #8cc63f;
  transform: translateY(1px);
}

.course_e .course_item:hover a{
  background: #8cc63f;
  transform: translateY(3px);
}

.course_e .course_item:hover a::before{
  border-top-color: #fff;
}

@media screen and (max-width: 768px){
  .course_e .titlebox h2{
    flex-wrap: wrap;
  }

  .course_e .course_wrap{
    flex-direction: column;
  }

  .course_e .course_item{
    width: 100%;
    border-left: none;
    border-top: 1px dotted rgba(140,198,63,.55);
    padding: 34px 20px;
      max-width: 350px;
          margin-right: auto;
     margin-left: auto;
  }

  .course_e .course_item:last-child{
    border-right: none;
    border-bottom: 1px dotted rgba(140,198,63,.55);
  }
}

.course_e .course_item .arrow{
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(24px,2.4vw,30px);
  aspect-ratio: 1 / 1;
  border: 1px solid #8cc63f;
  border-radius: 50%;
  margin: clamp(14px,1.6vw,20px) auto 0;
  transition: .3s ease;
}

.course_e .course_item .arrow img{
  display: block;
  width: 9px;
  height: auto;
  object-fit: contain;
  transition: .3s ease;
}

.course_e .course_item:hover .arrow{
  background: #8cc63f;
  transform: translateY(3px);
}

.course_e .course_item:hover .arrow img{
  filter: brightness(0) invert(1);
}


@media screen and (max-width: 768px){
  .course_e .course_menu_item.first{
    grid-template-columns: 1fr;
  }

  .course_e .course_menu_item .menu_head{
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }
}
.menu_box{
  padding-top: clamp(30px,12vw,80px);
}
.course_detail_wrap {

    margin-top: clamp(42px, 6vw, 80px);
}
.swiper_a {
  overflow: hidden;
  height: clamp(240px, 50vh, 400px);
}
.swiper_a img {
  display: block;
  height: clamp(240px, 50vh, 400px);
  width: auto;
}
.swiper_a .swiper-wrapper {
  transition-timing-function: linear !important;
}
.swiper_a .swiper-slide {
  opacity: 1 !important;
  width: auto;
}
.swiper_a .swiper-slide {
  opacity: 1 !important;
}
.swiper_a .swiper-slide {
  margin-right: 0 !important;
}
.swiper_a .swiper-wrapper {
  transition-timing-function: linear !important;
}

.swiper_a .swiper-slide {
  opacity: 1 !important;
  width: auto;
  margin-right: 10px !important;
  border-radius: 10px;
  overflow: hidden;
}
.swiper_a .swiper-slide img {
  height: clamp(220px, 28vw, 300px);
  width: auto;
  object-fit: cover;
  border: 2px solid #fff;
  border-radius: 10px;
}


/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px) {}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px) {}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px) {}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px) {}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px) {}