@charset "UTF-8";
/*g-mixin*/
/*20250616 OC詳細ページモデルコース追加*/
.course_item.modelcourse {
  text-align: center;
}
.course_item.modelcourse .copy {
  margin: 30px 0 36px;
}
@media screen and (max-width: 768px) {
  .course_item.modelcourse .copy {
    margin: 19px 0 19px;
  }
}

.inner.modelcourse__wrap {
  max-width: 1600px;
  background-color: #F4F4F4;
  padding: 36px 20px 56px;
  margin-bottom: 40px;
}
.inner.modelcourse__wrap .c-select {
  max-width: 1400px;
  margin: 0 auto;
  text-align: center;
}
.inner.modelcourse__wrap .c-select > div {
  position: relative;
  margin: 0 0 93px;
}
.inner.modelcourse__wrap .c-select > div::after {
  position: absolute;
  content: "";
  background-image: url("../imgs/event/opencampus/n_modelcourse_border.svg");
  background-size: contain;
  display: inline-block;
  left: 0;
  bottom: -68px;
  width: 100%;
  height: 20px;
  background-repeat: no-repeat;
}
.inner.modelcourse__wrap .c-select > div:last-child::after {
  display: none;
}
.inner.modelcourse__wrap .c-select > div > p {
  margin-bottom: 15px;
}
.inner.modelcourse__wrap .c-select > div .c-select__btn {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.inner.modelcourse__wrap .c-select > div .c-select__btn label {
  max-width: 690px;
  width: 100%;
  text-align: center;
  border-radius: 56px;
  border: 1px solid #000;
  font-size: 20px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 14px 0;
  box-shadow: 2px 3px 0px 1px #000;
  background-color: #fff;
  cursor: pointer;
  transition: 0.3s;
}
.inner.modelcourse__wrap .c-select > div .c-select__btn label .btn__radio {
  margin: 0;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  background-color: #CACACA;
  border: none;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  position: absolute;
  left: 5%;
}
.inner.modelcourse__wrap .c-select > div .c-select__btn label .btn__radio:checked {
  background-color: #0789AD;
}
.inner.modelcourse__wrap .c-select > div .c-select__btn label:hover {
  background-color: #97DBEE;
}
.inner.modelcourse__wrap .c-select > div .c-select__btn label:has(.btn__radio:checked) {
  background-color: #97DBEE;
}
.inner.modelcourse__wrap .c-select > div .c-select__btn label:has(.btn__radio:checked)::before {
  opacity: 1;
}
.inner.modelcourse__wrap .c-select > div .c-select__btn label::before {
  position: absolute;
  content: "";
  z-index: 1;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  width: 18px;
  height: 9px;
  transform: rotate(-45deg);
  left: calc(5% + 11px);
  top: 40%;
  opacity: 0;
}
.inner.modelcourse__wrap .c-select > div .c-select__btn.row2 label {
  min-width: 400px;
  width: calc(50% - 16px);
}
.inner.modelcourse__wrap .c-select > div .c-select__btn.row3 label {
  min-width: 350px;
  width: calc(33.3333333333% - 16px);
}
.inner.modelcourse__wrap .c-select > div .c-select__btn.row4 label {
  min-width: 325px;
  width: calc(25% - 16px);
}
.inner.modelcourse__wrap .c-select > div.department {
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  .inner.modelcourse__wrap {
    padding: 20px 12px 40px;
    margin-bottom: 24px;
  }
  .inner.modelcourse__wrap .c-select > div {
    margin-bottom: 54px;
  }
  .inner.modelcourse__wrap .c-select > div::after {
    background-image: url("../imgs/event/opencampus/n_modelcourse_border_sp.svg");
    bottom: -56px;
    background-size: 100%;
  }
  .inner.modelcourse__wrap .c-select > div > p {
    margin-bottom: 6px;
    font-size: 18px;
  }
  .inner.modelcourse__wrap .c-select > div .c-select__btn {
    gap: 13px;
  }
  .inner.modelcourse__wrap .c-select > div .c-select__btn label {
    font-size: 14px;
    padding: 6px 0;
  }
  .inner.modelcourse__wrap .c-select > div .c-select__btn label .btn__radio {
    width: 24px;
    height: 24px;
  }
  .inner.modelcourse__wrap .c-select > div .c-select__btn label::before {
    width: 12px;
    height: 7px;
    left: calc(5% + 6px);
  }
  .inner.modelcourse__wrap .c-select > div .c-select__btn.row2 label {
    min-width: 130px;
    width: calc(50% - 13px);
  }
  .inner.modelcourse__wrap .c-select > div .c-select__btn.row3 label {
    min-width: 0;
    width: 100%;
  }
  .inner.modelcourse__wrap .c-select > div .c-select__btn.row4 label {
    min-width: 0;
    width: 100%;
  }
}

.modelcourse__result {
  display: flex;
  justify-content: center;
}
.modelcourse__result button {
  font-family: YuMincho, "Yu Mincho", serif, "Noto Serif JP";
  max-width: 690px;
  width: 100%;
  text-align: center;
  border-radius: 56px;
  border: 1px solid #000;
  font-size: 20px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px 0;
  box-shadow: 2px 3px 0px 1px #000;
  background-color: #fff;
  color: #000;
  cursor: pointer;
  transition: 0.3s;
}
.modelcourse__result button .arrow {
  width: 67px;
  height: 1px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 50px;
  background-color: #707070;
  transition: 0.5s;
}
.modelcourse__result button .arrow::after {
  content: "";
  width: 20px;
  height: 1px;
  background-color: #707070;
  position: absolute;
  right: -4px;
  bottom: 7px;
  transform: rotate(45deg);
}
.modelcourse__result:hover button .arrow {
  right: 25px;
}
@media screen and (max-width: 768px) {
  .modelcourse__result button {
    padding: 11px 0;
    font-size: 18px;
  }
  .modelcourse__result button .arrow {
    width: 15%;
    right: 20px;
    top: 60%;
  }
}

.modal__modelcourse {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.8);
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 50;
  visibility: hidden;
  opacity: 0;
}
.modal__modelcourse__wrap {
  display: flex;
  gap: 35px;
  align-items: start;
  transform: translateX(60px);
}
.modal__modelcourse .img__area {
  max-width: 486px;
  max-height: 830px;
  width: 100%;
  height: 92vh;
  overflow-x: hidden;
  overflow-y: scroll;
  padding-right: 22px;
}
.modal__modelcourse .img__area img {
  width: 100%;
  height: auto;
}
.modal__modelcourse .img__area::-webkit-scrollbar {
  width: 8px;
}
.modal__modelcourse .img__area::-webkit-scrollbar-track {
  background-color: #fff;
  border-radius: 4px;
}
.modal__modelcourse .img__area::-webkit-scrollbar-thumb {
  background-color: #9FE8FD;
  border-radius: 4px;
}
.modal__modelcourse .img__area.hide-scrollbar::-webkit-scrollbar {
  display: none;
}
.modal__modelcourse .btn__area button.close {
  position: relative;
  width: 96px;
  height: 96px;
  border-radius: 100%;
  background-color: transparent;
  border: 1px solid #fff;
}
.modal__modelcourse .btn__area button.close span {
  display: block;
  width: 40px;
  height: 40px;
  position: absolute;
  top: calc(50% - 20px);
  left: calc(50% - 20px);
}
.modal__modelcourse .btn__area button.close span::before {
  content: "";
  transform: translateX(1px) rotate(45deg);
  width: 2px;
  height: 40px;
  display: inline-block;
  background-color: #fff;
}
.modal__modelcourse .btn__area button.close span::after {
  content: "";
  transform: translateX(-1px) rotate(-45deg);
  width: 2px;
  height: 40px;
  display: inline-block;
  background-color: #fff;
}
.modal__modelcourse.active {
  visibility: visible;
  opacity: 1;
}
@media screen and (max-width: 768px) {
  .modal__modelcourse__wrap {
    flex-flow: column-reverse;
    gap: 9px;
    align-items: end;
    transform: translateX(0) translateY(-6px);
    width: calc(100% - 48px);
    height: calc(100% - 36px);
  }
  .modal__modelcourse .img__area {
    max-width: 100%;
    padding-right: 5px;
    height: 100%;
  }
  .modal__modelcourse .img__area::-webkit-scrollbar {
    width: 5px;
  }
  .modal__modelcourse .img__area::-webkit-scrollbar-track {
    border-radius: 2.5px;
  }
  .modal__modelcourse .img__area::-webkit-scrollbar-thumb {
    border-radius: 2.5px;
  }
  .modal__modelcourse .img__area.hide-scrollbar::-webkit-scrollbar {
    display: none;
  }
  .modal__modelcourse .btn__area button.close {
    width: 42px;
    height: 42px;
  }
  .modal__modelcourse .btn__area button.close span {
    width: 16px;
    height: 16px;
    top: calc(50% - 8px);
    left: calc(50% - 8px);
  }
  .modal__modelcourse .btn__area button.close span::before {
    height: 16px;
  }
  .modal__modelcourse .btn__area button.close span::after {
    height: 16px;
  }
}