@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700;900&family=Roboto:wght@500&display=swap');
@media screen and (min-width: 768px) {
  .l-breadcrumbs {
    margin-bottom: 80px;
  }
}
@media screen and (max-width: 767px) {
  .l-breadcrumbs {
    margin-top: 10px;
  }
}
.opencampus-main-visual {
  position: relative;
  width: 100%;
  height: auto;
}
.opencampus-main-visual__image {
  display: block;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
}
.opencampus-main-visual__list {
  position: absolute;
  top: max(389.1654465593px, 32.4304538799vw);
  left: max(144.9487554905px, 12.0790629575vw);
  display: grid;
  grid-template-columns: repeat(3, max(139.6778916545px, 11.6398243045vw));
  grid-template-rows: max(137.9209370425px, 11.4934114202vw);
  gap: max(17.5695461201px, 1.4641288433vw);
}
@media screen and (max-width: 767px) {
  .opencampus-main-visual__list {
    position: static;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    grid-template-columns: repeat(3, 30.9333333333vw);
    grid-template-rows: 30.4vw;
    gap: 1.6vw;
    margin: 2.6666666667vw auto 30px;
  display: none;
  }
}
.opencampus-main-visual__item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background: url(/assets/img/opencampus/mv-2.jpg) no-repeat center/cover;
}
.opencampus-main-visual__item-number {
  position: absolute;
  top: max(4.39238653px, 0.3660322108vw);
  left: max(13.17715959px, 1.0980966325vw);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: max(28.9897510981px, 2.4158125915vw);
  height: max(28.9897510981px, 2.4158125915vw);
  border-radius: 9999px;
  background: #ffb64a;
  font-size: max(17.5695461201px, 1.4641288433vw);
  font-family: "din-2014", "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, sans-serif;
}
@media screen and (max-width: 767px) {
  .opencampus-main-visual__item-number {
    top: 0;
    left: 2.6666666667vw;
    width: 6.4vw;
    height: 6.4vw;
    font-size: 4.2666666667vw;
  }
}
.opencampus-main-visual__item-text {
  font-size: max(14.055636896px, 1.1713030747vw);
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .opencampus-main-visual__item-text {
    font-weight: bold;
    font-size: 3.4666666667vw;
  }
}
.news {
  position: relative;
}
@media screen and (max-width: 767px) {
  .news {
    padding-right: 15px;
    padding-left: 15px;
  }
}
.news:after {
  position: absolute;
  bottom: -57px;
  left: calc(50% + 30px);
  z-index: -2;
  content: url(/assets/img/opencampus/news-bg.svg);
}
@media screen and (max-width: 767px) {
  .news:after {
    bottom: -27px;
    left: calc(50% - 157px);
    content: url(/assets/img/opencampus/sp/news-bg.svg);
  }
}
@media screen and (min-width: 768px) {
  .news__content {
    display: grid;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 40px auto 0;
  }
}
@media screen and (max-width: 767px) {
  .news__content {
    margin: 30px auto 0;
  }
}
@media screen and (max-width: 767px) {
  .news__slider {
    grid-template-columns: 330px;
  }
}
.news__list {
  margin: 50px auto 0;
}
@media screen and (max-width: 767px) {
  .news__list {
    margin: 30px auto 0;
  }
}
.infomation {
  position: relative;
  margin: 160px auto 0;
  padding: 57px 0;
  border-radius: 20px;
  background: #fff8f8;
}
@media screen and (max-width: 767px) {
  .infomation {
    margin: 80px auto 0;
    padding: 40px 33px 70px;
    background: #fff8f8 url(/assets/img/opencampus/sp/infomation-bg.png) no-repeat top/100% auto;
  }
}
@media screen and (max-width: 767px) {
.infomation {
display: none;
}
}
.infomation:before {
  position: absolute;
  top: -12px;
  left: 20px;
  content: url(/assets/img/opencampus/infomation-1.png);
}
@media screen and (max-width: 767px) {
  .infomation:before {
    top: unset;
    bottom: 0;
    left: -15px;
    content: url(/assets/img/opencampus/sp/infomation-1.png);
    -webkit-transform: scale(0.5) translate(-50%, 50%);
    transform: scale(0.5) translate(-50%, 50%);
  }
}
.infomation:after {
  position: absolute;
  top: -8px;
  right: 20px;
  content: url(/assets/img/opencampus/infomation-2.png);
}
@media screen and (max-width: 767px) {
  .infomation:after {
    top: unset;
    right: -20px;
    bottom: 0;
    content: url(/assets/img/opencampus/sp/infomation-2.png);
    -webkit-transform: scale(0.5) translate(50%, 50%);
    transform: scale(0.5) translate(50%, 50%);
  }
}
.infomation__content {
  margin: 0 auto;
  width: 680px;
}
@media screen and (max-width: 767px) {
  .infomation__content {
    width: 100%;
    text-align: center;
  }
}
.infomation__content > .infomation__title,
.infomation__content > p {
  position: relative;
  z-index: 1;
}
.infomation__title {
  margin: 0 0 40px;
}
@media screen and (max-width: 767px) {
  .infomation__title {
    margin: 0 0 20px -20px;
    width: calc(100% + 40px);
    font-size: 20px;
    line-height: 30px;
  }
}
.infomation__title:after {
  height: 10px;
  border-radius: 9999px;
  background-image: url(/assets/img/opencampus/title-bg.jpg);
}
@media screen and (max-width: 767px) {
  .infomation__title:after {
    width: 80px;
    height: 4px;
  }
}
.schedule {
  margin: 135px auto 0;
}
@media screen and (max-width: 767px) {
  .schedule {
    margin: 60px auto 0;
    padding: 0;
  }
}
.schedule__content {
  position: relative;
  margin: 40px auto 0;
}
.schedule__content:before {
  position: absolute;
  top: 35px;
  left: 80px;
  z-index: -1;
  width: max(1153px, 50vw + 470px);
  height: calc(100% + 45px);
  background: #f4fbff;
  content: "";
}
@media screen and (max-width: 767px) {
  .schedule__content:before {
    left: 100px;
    width: calc(50vw + 90px);
    height: calc(100% + 25px);
  }
}
.schedule__links {
  margin: 40px auto 50px;
}
@media screen and (max-width: 767px) {
  .schedule__links {
    margin: 30px auto 40px;
  }
}
@media screen and (max-width: 767px) {
  .schedule__title {
    margin: 0 15px 25px;
    font-size: 26px;
  }
}
.schedule__list-wrapper {
  overflow: scroll;
}
@media screen and (min-width: 768px) {
  .schedule__list-wrapper {
    margin-left: min(-133px, -50vw + 550px);
    padding-left: max(133px, 50vw - 550px);
    width: max(1233px, 100vw);
  }
}
@media screen and (max-width: 767px) {
  .schedule__list-wrapper {
    padding: 0 15px;
  }
}
.schedule__list {
  margin: 0;
  padding: 0;
  background: none;
}
  .schedule__list .c-list-post-12 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 0;
  }
@media screen and (max-width: 767px) {
  .schedule__list .c-list-post-12 {
    gap: 20px;
  }
}
.schedule__list .c-list-post-12__item {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 340px;
}
@media screen and (max-width: 767px) {
  .schedule__list .c-list-post-12__item {
    width: 90%;
  }
}
@media screen and (min-width: 768px) {
  .schedule__list .c-list-post-12__item:nth-child(n+2) {
    margin-left: 40px;
  }
}
.embed {
  margin: 150px auto 0;
}
@media screen and (max-width: 767px) {
  .embed {
    margin: 40px auto 0;
  }
}
.embed__list {
  display: grid;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  grid-template-columns: repeat(3, 340px);
  gap: 40px;
  margin: 0px auto 0;
}
@media screen and (max-width: 767px) {
  .embed__list {
    grid-template-columns: 1fr;
    gap: 20px;
    justify-items: center;
  }
}
@media screen and (min-width: 768px) {
  .embed__item:hover .embed__link {
    -webkit-box-shadow: 5px 5px 0 0 #eaf7ff;
    box-shadow: 5px 5px 0 0 #eaf7ff;
    -webkit-transform: translate(5px, 5px);
    transform: translate(5px, 5px);
  }
}
.embed__item:nth-child(1) .embed__link {
  background: #65b0de;
}
.embed__item:nth-child(1) .embed__link:before {
  content: url(/assets/img/opencampus/embed-link-1.svg);
}
.embed__item:nth-child(2) .embed__link {
  background: #caacd5;
}
.embed__item:nth-child(2) .embed__link:before {
  content: url(/assets/img/opencampus/embed-link-2.svg);
}
.embed__item:nth-child(3) .embed__link {
  background: #ff9ab9;
}
.embed__item:nth-child(3) .embed__link:before {
  content: url(/assets/img/opencampus/embed-link-3.svg);
}
.embed__link {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 340px;
  height: 160px;
  border-radius: 10px;
  -webkit-box-shadow: 10px 10px 0 0 #eaf7ff;
  box-shadow: 10px 10px 0 0 #eaf7ff;
  font-size: 26px;
  line-height: 36px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (max-width: 767px) {
  .embed__link {
    border-radius: 6px;
    -webkit-box-shadow: 5px 5px 0 0 #eaf7ff;
    box-shadow: 5px 5px 0 0 #eaf7ff;
  }
}
.embed__link:after {
  position: absolute;
  top: calc(50% - 15px);
  right: 15px;
  content: url(/assets/img/common/i-arrow-10.svg);
}

.program {
  margin: 80px auto 0;
}
@media screen and (max-width: 767px) {
  .program {
    margin: 60px auto 0;
  }
}

.program__content {
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .program__content {
    margin: 30px auto 0;
  }
}
.voice {
  margin: 80px auto 0;
  padding: 80px 0;
  background: #f4fbff;
}
@media screen and (max-width: 767px) {
  .voice {
    margin: 60px auto 0;
    padding: 60px 0;
  }
}
.voice__content {
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .voice__content {
    margin: 30px auto 0;
  }
}
.faq {
  margin: 80px auto 0;
}
@media screen and (max-width: 767px) {
  .faq {
    margin: 60px auto 0;
  }
}
.faq__content {
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .faq__content {
    margin: 30px auto 0;
  }
}
.access {
  margin: 80px auto 0;
  padding: 80px 0;
  background: -webkit-gradient(linear, left top, left bottom, from(#f4fbff), to(#f4fbff)) no-repeat right/max(1153px, 50vw + 470px);
  background: linear-gradient(#f4fbff, #f4fbff) no-repeat right/max(1153px, 50vw + 470px);
}
@media screen and (max-width: 767px) {
  .access {
    margin: 60px auto 0;
    padding: 60px 0;
    background-position: right;
    background-size: calc(50vw + 90px) 100%;
  }
}
.access__content {
  display: grid;
  grid-template-columns: 500px 560px;
  gap: 40px;
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .access__content {
    grid-template-columns: 1fr;
    gap: 30px;
    margin: 30px auto 0;
  }
}
@media screen and (max-width: 767px) {
  .access__content iframe {
    width: 100%;
    height: 61.0666666667vw;
  }
}

.opencampus {
  margin: 80px auto 0;
}
@media screen and (max-width: 767px) {
  .opencampus {
    margin: 60px auto 0;
  }
}

.opencampus__content {
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .opencampus__content {
    margin: 30px auto 0;
  }
}
.opencampus__content-button {
  display: block;
}
@media screen and (max-width: 767px) {
  .opencampus__slider {
    grid-template-columns: 330px;
  }
}
.l-cta {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .l-cta {
    margin-top: 60px;
  }
}
/*追加*/
.c-title-1 {
font-size: 30px;
}
.embed {
margin: 60px auto 0;
}
.embed__content{
margin-top: 20px;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
}
.embed__link {
height: 120px;
font-size: 20px;
line-height: 25px;
}
@media screen and (max-width: 767px) {
.c-title-1 {
font-size: 20px;
}
.l-breadcrumbs {
margin: 15px;
}
.c-title-1:after {
margin: 10px auto 0;
width: 70px;
}
.embed {
margin: 15px 15px 0;
padding: 0 0 30px;
}
.l-breadcrumbs {
margin: 15px 15px 30px 15px;
}
}
.c-button-3, .c-button-4 {
height: 60px;
}
.opencampus__button-list{
display: grid;
-webkit-box-pack: center;
ms-flex-pack: center;
justify-content: center;
grid-template-columns: repeat(2, 400px);
gap: 25px;
}
.opencampus__button{
margin: 0;
}
@media screen and (max-width: 767px){
.opencampus__button {
margin: 30px auto 0;
}
.opencampus__button-list {
grid-template-columns: auto;
gap: 0px;
margin-top: -40px;
}
.opencampus__button {
margin: 20px auto 0;
}
}
/*オープンキャンパス開催日*/
.schedule {
padding: 70px 0 0;
background: #f5f5f5;
}
.oc_schedule__item {
padding: 15px 5px;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
background: #fff;
border: solid 1px #ccc;
display: block;
border-radius: 10px;
box-shadow: 4px 4px 2px 1px rgba(29, 32, 138, .3);
transition: .3s all;
}
.oc_schedule__item .date {
font-weight: bold;
font-size: 2.8rem;
}
.oc_schedule__item .day_of_week {
display: -webkit-inline-box;
display: -ms-inline-flexbox;
display: inline-flex;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
margin-left: 5px;
width: 28px;
height: 28px;
background: #000;
color: #fff;
font-weight: bold;
font-size: 1.5rem;
}
.oc_schedule__item .day_of_week._sat {
background: #5ba6d5;
}
.oc_schedule__item .day_of_week._sun {
background: #fd7575;
}
#schedule_slider {
display: grid;
grid-template-columns: repeat(5, 1fr);
gap: 15px;
text-align: center;
margin: 0 auto;
flex-wrap: wrap;
width: 1200px;
}
.slick-initialized .slick-slide {
transition: .3s ease;
}
@media only screen and (max-width: 768px) {
#schedule_slider {
grid-template-columns: repeat(3, 1fr);
width: 100%;
}
.oc_schedule {
display: -webkit-box;
display: -ms-flexbox;
display: flex;
flex-wrap: wrap;
}
.oc_schedule__item .date {
font-weight: bold;
font-size: 2.2rem;
}
.oc_schedule__item .day_of_week {
width: 20px;
height: 20px;
}
}
/*個別相談*/
#schedule_slider-kobetsu{
text-align: center;
margin: 0 auto;
flex-wrap: wrap;
width: 800px;
}
#schedule_slider-kobetsu a{
color: #fff;
}
.oc_schedule__item-kobetsu .title {
font-weight: bold;
font-size: 1.8rem;
}
.oc_schedule__item-kobetsu{
width: 100%;
background: #5ba6d5;
padding: 15px 5px;
align-items: center;
border: solid 1px #ccc;
display: block;
border-radius: 10px;
box-shadow: 4px 4px 2px 1px rgba(29, 32, 138, .3);
transition: .3s all;
}
@media only screen and (max-width: 768px) {
#schedule_slider-kobetsu{
width: 100%;
}
}
/*分野から選ぶ*/
.flxbox {
width: 1200px;
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 15px;
margin: 0 auto;
}
.flxbox  a{
display: block;
}
@media only screen and (max-width: 768px) {
.flxbox {
width: 100%;
margin: 0 auto;
grid-template-columns: repeat(2, 1fr);
}
}


/* =======================================
	oc-section
======================================= */
.c-pet {background: linear-gradient(90deg, #F77A45 0%, #FFB64A 100%);}
.c-nurse {background: linear-gradient(90deg, #FE80A7 0%, #FF6F4F 100%);}
.c-planning {background: linear-gradient(90deg, #44A3DD 0%, #5A75D4 100%);}
.c-it {background: linear-gradient(90deg, #00BD75 0%, #00BD9B 100%);}
.c-fashion {background: linear-gradient(90deg, #5F3EE2 0%, #A75AD4 100%);}
.c-flower {background: linear-gradient(90deg, #9BCA44 0%, #6BD296 100%);}
.c-global {background: linear-gradient(90deg, #F95456 0%, #F36338 100%);}

.for-sp {
  display: none;
}
@media only screen and (max-width: 767px) {
  .for-sp {
    display: block;
  }
  .for-pc {
    display: none;
  }
}

.oc-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    aspect-ratio: 1;
    background-color: #D1D1D1;
    border-radius: 50%;
    flex: none;
    transition: background-color 0.3s;
}

.oc-icon--check {
    mask-image: url(/assets/img/opencampus/icon-check.svg);
    mask-repeat: no-repeat;
    mask-size: contain;
    width: 12px;
    aspect-ratio: 1;
    background-color: #939393;
    transition: background-color 0.3s;
}

.oc-section {
  margin: 80px auto 0;
}

.oc-section .c-title-1::after {
  margin: 16px auto 0;
  width: 164px;
  height: 18px;
  background: url(/assets/img/opencampus/ornament.png) no-repeat center / cover;
}

@media only screen and (max-width: 767px) {
  .oc-section {
    margin-top: 48px;
    padding: 0 0 30px;
  }

  .oc-section .c-title-1::after {
    margin-top: 12px;
    width: 124px;
    height: 12px;
  }
}


/* =======================================
	oc-filter
======================================= */
.oc-filter {
  margin-top: 129px;
  background-color: #FFE7E5;
}

.oc-filter-inner {
  position: relative;
  max-width: 1130px;
  margin: 0 auto;
  padding: 0 15px;
}

.oc-filter-tab {
  position: absolute;
  top: -65px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.oc-filter-tab__button {
  padding: 16px 23px;
  border-radius: 8px 8px 0 0;
  background: #E3E3E3;
  color: #7E7E7E;
  text-align: center;
  font-size: 2.2em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  transition: color 0.3s, background-color 0.3s;
}
.oc-filter-tab__button.is-active {
  color: #FFFFFF;
  background: linear-gradient(90deg, #FF6360 0%, #FFA13D 100%);
}
@media (hover: hover) {
  .oc-filter-tab__button:not(.is-active):hover {
    background-color: #C7C7C7;
    color: #3C3C3C;
  }
}

.oc-filter-head {
  display: flex;
  align-items: center;
  gap: 10px;
}

.oc-filter-head__img {
  width: fit-content;
}

.oc-filter-head__img img {
  width: 49px;
}

.oc-filter-head__title {
  font-size: 2em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
}

@media only screen and (max-width: 767px) {
  .oc-filter {
    margin-top: 104px;
  }

  .oc-filter-tab {
    width: 92.5%;
    gap: 12px;
    top: -64px;
  }

  .oc-filter-tab__button {
    padding: 8px 15px;
    font-size: 1.6em;
  }
}

@media only screen and (max-width: 354px) {
  .oc-filter-tab {
    top: -88px;
  }
}


/* =======================================
	oc-filter--oc
======================================= */
.oc-filter--oc {
  padding: 48px 0 64px;
  display: grid;
  gap: 32px;
}

.oc-filter--oc.is-hidden,
.oc-filter--cons.is-hidden {
    visibility: hidden;
    opacity: 0;
    height: 0;
    padding: 0;
    overflow: hidden;
}


.oc-filter-section {
  padding: 32px 40px;
  border-radius: 12px;
  background-color: #FFFFFF;
  display: grid;
  gap: 24px;
}

.oc-filter-date__list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(0, 160px));
  gap: 12px;
}

.oc-filter-date__button {
  padding: 12px 20px;
  border-radius: 4px;
  border: 2px solid transparent;
  transition: border 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  outline: 1px solid #CACACA;
  transition: border 0.3s;
}
@media (hover: hover) {
    .oc-filter-date__button:hover {
        border: 2px solid #FFA688;
        outline: 1px solid transparent;
    }
}

.oc-filter-date__button.is-active {
  border: 2px solid #FFA688;
  outline: 1px solid transparent;
}
.oc-filter-date__button.is-active .oc-icon--color {
  background-image: url(/assets/img/opencampus/checkbox-active.svg);
}
.oc-filter-date__button.is-active .oc-filter-date__item--date,
.oc-filter-date__button.is-active .oc-filter-date__item--week {
  color: #FF6D3D;
}

.oc-filter-date__item .oc-icon--color {
  background-image: url(/assets/img/opencampus/checkbox.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 24px;
  aspect-ratio: 1;
  transition: background 0.3s;
}

.oc-filter-date__item--content {
  display: flex;
  align-items: baseline;
  gap: 2px;
}


.oc-filter-date__item{
	display:none;
}
.oc-filter-date__item.on{
	display:block;
}


.oc-filter-date__item--date {
  font-family: "Roboto", sans-serif;
  font-weight: 500;
  font-size: 20px;
  line-height: 1;
  letter-spacing: -0.04em;
}

.oc-filter-date__item--date span {
  font-size: 30px;
}

.oc-filter-date__item--week {
  font-size: 1.3em;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.05em;
}

.oc-filter-genre__list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(302px, 1fr));
    column-gap: 24px;
    row-gap: 22px;
}

.oc-filter-genre__button {
    position: relative;
    display: flex;
    align-items: center;
    padding: 16px 106px 16px 16px;
    border-radius: 6px;
    height: 82px;
    transition: border 0.3s;
}

.oc-filter-genre__button .oc-icon {
  background-color: #FFFFFF;
}

.oc-filter-genre__button .oc-icon--check {
  background-color: #939393;
}

.oc-filter-genre__button::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url(/assets/img/opencampus/pattern.png) repeat;
  background-size: 15%;
  opacity: 0.1;
  mix-blend-mode: soft-light;
}

.oc-filter-genre__button.is-active {
  border: 2px solid #2F2F2F;
}
.oc-filter-genre__button.is-active .oc-icon {
  background-color: #2F2F2F;
}
.oc-filter-genre__button.is-active .oc-icon--check {
  background-color: #FFFFFF;
}
@media (hover: hover) {
    .oc-filter-genre__button:hover {
        border: 2px solid #2F2F2F;
    }
}

.oc-filter-genre__content {
  display: flex;
  align-items: center;
  gap: 10px;
}

.oc-filter-genre__item--txt {
  position: relative;
  z-index: 1;
  color: #FFFFFF;
  font-size: 2em;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
}
.c-pet .oc-filter-genre__item--txt { 
  text-shadow:
  0 0 1px #F77A45,
  0 0 1px #F77A45,
  0 0 1px #F77A45,
  0 0 1px #F77A45,
  0px 0px 12px rgba(255, 114, 55, 0.5);
}
.c-nurse .oc-filter-genre__item--txt { 
  text-shadow:
  0 0 1px #FF6E8C,
  0 0 1px #FF6E8C,
  0 0 1px #FF6E8C,
  0 0 1px #FF6E8C,
  0px 0px 12px rgba(255, 50, 73, 0.5);
}
.c-planning .oc-filter-genre__item--txt { 
  text-shadow:
  0 0 1px #1889CF,
  0 0 1px #1889CF,
  0 0 1px #1889CF,
  0 0 1px #1889CF,
  0px 0px 12px rgba(0, 123, 200, 0.5);
}
.c-it .oc-filter-genre__item--txt { 
  text-shadow:
  0 0 1px #00A273,
  0 0 1px #00A273,
  0 0 1px #00A273,
  0 0 1px #00A273,
  0px 0px 12px rgba(1, 156, 110, 0.5);
}
.c-fashion .oc-filter-genre__item--txt { 
  text-shadow:
  0 0 1px #7447DE,
  0 0 1px #7447DE,
  0 0 1px #7447DE,
  0 0 1px #7447DE,
  0px 0px 12px rgba(98, 33, 232, 0.5);
}
.c-flower .oc-filter-genre__item--txt { 
  text-shadow:
  0 0 1px #61BF22,
  0 0 1px #61BF22,
  0 0 1px #61BF22,
  0 0 1px #61BF22,
  0px 0px 12px rgba(75, 154, 21, 0.5);
}
.c-global .oc-filter-genre__item--txt { 
  text-shadow:
  0 0 1px #F65C47,
  0 0 1px #F65C47,
  0 0 1px #F65C47,
  0 0 1px #F65C47,
  0px 0px 12px rgba(246, 92, 71, 0.5);
}

.oc-filter-genre__item--img {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 103px;
    border-radius: 0 0 6px 0;
}

.oc-filter-reset {
  display: flex;
  justify-content: center;
  gap: 24px;
}

.oc-filter-reset__button {
  position: relative;
  width: 100%;
  max-width: 394px;
  padding: 16px 24px;
  border-radius: 4px;
  background-color: #FFFFFF;
  border: 1px solid #FD7575;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  transition: background-color 0.3s;
}
@media (hover: hover) {
    .oc-filter-reset__button:hover {
      background-color: #FD7575;
    }

    .oc-filter-reset__button:hover .oc-filter-reset__txt p {
      color: #FFFFFF;
    }

    .oc-filter-reset__button:hover .oc-filter-reset__icon {
      background-color: #FFFFFF;
    }

    .oc-filter-reset__button:hover .oc-icon--arrow {
      background-color: #FFFFFF;
    }

    .oc-filter-reset__button:hover .oc-icon--arrow::after {
      background-color: #FD7575;
    }
}

.oc-filter-reset__icon {
  display: block;
  width: 20px;
  aspect-ratio: 1;
  mask-repeat: no-repeat;
  mask-size: contain;
  background-color: #FD7575;
  transition: background-color 0.3s;
}

.oc-filter-reset__icon--date {
  mask-image: url(/assets/img/opencampus/icon-calendar.svg);
}

.oc-filter-reset__icon--genre {
  mask-image: url(/assets/img/opencampus/icon-category.svg);
}

.oc-filter-reset__txt p {
  font-size: 1.6em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  transition: color 0.3s;
}

.oc-filter-reset__button .oc-icon--arrow {
  flex: none;
  width: 20px;
  aspect-ratio: 1;
  border-radius: 50%;
  background-color: #FD7575;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  right: 24px;
  top: 50%;
  transform: translateY(-50%);
  transition: background-color 0.3s;
}

.oc-filter-reset__button .oc-icon--arrow.for-sp {
  display: none;
} 

.oc-filter-reset__button .oc-icon--arrow::after {
  content: '';
  display: block;
  width: 7.5px;
  aspect-ratio: 6 / 7.5;
  mask-image: url(/assets/img/opencampus/icon-arrow1.svg);
  mask-repeat: no-repeat;
  mask-size: contain;
  background-color: #FFFFFF;
  transition: background-color 0.3s;
}

@media only screen and (max-width: 767px) {
  .oc-filter--oc {
    padding: 32px 0 64px;
  }

  .oc-filter-section {
    padding: 20px;
    border-radius: 8px;
    gap: 20px;
  }

  .oc-filter-date__list {
    grid-template-columns: repeat(2,1fr);
    gap: 12px;
  }

  .oc-filter-date__button {
    width: 100%;
    padding: 8px;
  }

  .oc-filter-date__item--date {
    font-size: 16px;
  }

  .oc-filter-date__item--date span {
    font-size: 22px;
  }

  .oc-filter-date__item--week {
    font-size: 1em;
  }

  .oc-filter-genre__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }

  .oc-filter-genre__button {
    padding: 22px 8px;
    border-radius: 4px;
    height: 66px;
  }

  .oc-filter-genre__button:last-of-type {
    padding-right: 25px;
  }

  .oc-filter-genre__button .oc-icon {
    position: absolute;
    top: -8px;
    left: -8px;
  }

  .oc-filter-genre__item--txt {
    font-size: 1.5em;
  }

  .oc-filter-genre__item--img {
    width: 79px;
    border-radius: 0 0 4px 0;
  }

  .oc-filter-reset {
    margin-top: 16px;
    gap: 12px;
  }

  .oc-filter-reset__button {
    width: 100%;
    padding: 16px;
    flex-direction: column;
  }

  .oc-filter-reset__txt {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
  }

  .oc-filter-reset__button .oc-icon--arrow {
    width: 16px;
    position: static;
    transform: none;
  }

  .oc-filter-reset__button .oc-icon--arrow.for-sp {
    display: flex;
  } 

  .oc-filter-reset__button .oc-icon--arrow.for-pc {
    display: none;
  } 

  .oc-filter-reset__button .oc-icon--arrow::after {
    width: 6px;
  }
}


/* =======================================
	oc-filter--cons
======================================= */
.oc-filter--cons {
  padding: 48px 0 64px;
}

.oc-filter-cons__body {
  padding: 32px 24px;
  border-radius: 12px;
  background-color: #FFFFFF;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
}

.oc-filter-cons__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 32px;
}

.oc-filter-cons__item {
  display: flex;
  align-items: center;
  gap: 8px;
  transition: opacity 0.3s;
}
.oc-filter-cons__item.is-active .oc-icon {
  background-color: #FD7575;
}
.oc-filter-cons__item.is-active .oc-icon--check {
  background-color: #FFFFFF;
}
@media (hover: hover) {
  .oc-filter-cons__item:hover {
    opacity: 0.7;
  }
}

.oc-filter-cons__item p {
  font-size: 1.6em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
}

.oc-filter-cons__button {
  width: fit-content;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 23px 24px;
  border-radius: 4px;
  background-color: #FD7575;
  box-shadow: 0px 4px 0px 0px #C36060;
  transition: box-shadow 0.3s, transform 0.3s;
  cursor:pointer;
}
@media (hover: hover) {
  .oc-filter-cons__button:hover {
    box-shadow: none;
    transform: translateY(4px);
  }
}

.oc-filter-cons__button p {
  color: #FFFFFF;
  font-size: 2em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
}

@media only screen and (max-width: 767px) {
  .oc-filter--cons {
    padding: 32px 0 48px;
  }

  .oc-filter-cons__body {
    flex-direction: column;
    align-items: start;
  }

  .oc-filter-cons__list {
    flex-direction: column;
    align-items: start;
  }

  .oc-filter-cons__button {
    width: 100%;
    padding: 16px;
  }

  .oc-filter-cons__button p {
    font-size: 1.6em;
  }
}


/* =======================================
	oc-card
======================================= */
.oc-card {
  margin: 64px auto 0;
  padding: 0 15px;
  max-width: 1130px;
}
.oc-card.is-hidden{
	display:none;
}


.oc-card-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
}

.oc-card-link { 
  display: grid;
  gap: 24px;
  padding: 24px 24px 32px;
  border-radius: 8px;
  border: 2px solid #E3E3E3;
  transition: border 0.3s;
}

.oc-card-item.kobetsu-off,
.oc-card-item.kobetsu-off2,
.oc-card-item.date-off,
.oc-card-item.cat-off,
.oc-card-item.event-off{
	display:none;
}



@media (hover: hover) {
  .oc-card-link:hover { 
    border: 2px solid #5D5D5D;
  }

  .oc-card-link:hover .oc-card-item__img img {
    transform: scale(1.05);
  }

  .oc-card-link:hover .oc-card-item__button {
    box-shadow: none;
    transform: translateY(4px);
  }
}

.oc-card-item__inner {
  display: grid;
  gap: 20px;
}

.oc-card-item__img {
  width: fit-content;
  border-radius: 8px;
  overflow: hidden;
}

.oc-card-item__img img {
  width: 100%;
  transition: transform 0.3s;
}

.oc-card-item__body {
  display: grid;
  gap: 20px;
}

.oc-card-item__content {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.oc-card-item__content h3 {
  font-weight: 700;
  font-size: 2.4em;
  line-height: 1.5;
  letter-spacing: 0;
}

.oc-card-item__content p {
  font-size: 1.6em;
  line-height: 1.6;
  letter-spacing: 0;
}

.oc-card-item__daytime {
  margin-top: 4px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 16px;
  border-radius: 4px;
  background-color: #EDEDED;
}

.oc-card-item__daytime--item {
  position: relative;
  display: flex;
  align-items: baseline;
  gap: 12px;
}

.oc-card-item__daytime--item:first-of-type {
  padding-bottom: 14px;
}

.oc-card-item__daytime--item:first-of-type::before {
  content: "";
  height: 1px;
  width: 100%;
  margin: auto;
  position: absolute;
  left: 0;
  bottom: 0;
  background-image: radial-gradient(circle, #C2C2C2 1px, transparent 1.5px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
}

.oc-card-item__daytime--title {
  flex: none;
  padding: 4px 12px;
  background-color: #FFFFFF;
  width: 84px;
  font-size: 1.5em;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0;
  text-align: center;
}

.oc-card-item__date,
.oc-card-item__time {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  font-size: 1.8em;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0;
}

.oc-card-item__categories {
  display: flex;
    flex-wrap:wrap;
  
  align-items: baseline;
  gap: 12px;
}

.oc-card-item__category {
  padding: 6px 10px;
  border-radius: 99px;
  color: #FFFFFF;
  font-size: 1.4em;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.03em;
}

.oc-card-item__button {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 16px;
  border-radius: 4px;
  background-color: #FD7575;
  box-shadow: 0px 4px 0px 0px #C36060;
  transition: box-shadow 0.3s, transform 0.3s;
  
  height:62px;
}

.oc-card-item__button p {
  color: #FFFFFF;
  font-size: 2em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
}

@media only screen and (max-width: 767px) {
  .oc-card-list {
    grid-template-columns: 1fr;
  }

  .oc-card-link { 
    padding: 20px 20px 32px;
  }

  .oc-card-item__inner {
    gap: 24px;
  }

  .oc-card-item__content h3 {
    font-size: 1.8em;   
  }

  .oc-card-item__content p {
    font-size: 1.4em;
  }

  .oc-card-item__daytime {
    margin-top: 0;
  }

  .oc-card-item__daytime--item {
    gap: 8px;
  }

  .oc-card-item__daytime--title {
    font-size: 1.3em;
    width: 76px;
  }

  .oc-card-item__date,
  .oc-card-item__time {
    font-size: 1.5em;
    gap: 16px;
  }

  .oc-card-item__category {
    font-size: 1.2em;
  }

  .oc-card-item__button p {
    font-size: 1.6em;
  }
}


/* =======================================
	oc-entry
======================================= */
.oc-entry {
  position: relative;
  padding: 64px 15px 120px;
  background-color: #FDF3D7;
  overflow: hidden;
}

.oc-entry::before,
.oc-entry::after {
  position: absolute;
  content: "";
  background-image: url(/assets/img/opencampus/blur.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 1918px;
  aspect-ratio: 959 / 639;
}

.oc-entry::before {
  top: -500px;
  right: -800px;
}

.oc-entry::after {
  bottom: -500px;
  left: -800px;
  transform: rotate(180deg);
}

/* oc-entry__head */
.oc-entry__head {
  position: relative;
  z-index: 1;
}

.oc-entry__head h1 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.oc-entry__head--ja {
  font-size: 4em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
}

.oc-entry__head--en {
  font-size: 2.4em;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  background: linear-gradient(90deg, #FF6360 0%, #FFA13D 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

@media only screen and (max-width: 767px) {
  .oc-entry::before {
    width: 714px;
    top: -200px;
    right: -300px;
  }

  .oc-entry::after {
    width: 714px;
    bottom: -200px;
    left: -300px;
  }

  .oc-entry__head h1 {
    gap: 4px;
  }

  .oc-entry__head--ja {
    font-size: 2.5em;
  }

  .oc-entry__head--en {
    font-size: 1.8em;
  }
}


/* l-breadcrumbs */
.oc-entry .l-breadcrumbs {
  position: relative;
  z-index: 2;
  margin: 24px auto 0;
  padding: 0;
  border-bottom: 0;
}

@media only screen and (max-width: 767px) {
  .oc-entry .l-breadcrumbs {
    margin-top: 48px;
  }
}


/* oc-entry__main */
.oc-entry__main {
  position: relative;
  z-index: 1;
  margin: 24px auto 0; 
  max-width: 1100px;
  padding: 40px;
  border-radius: 8px;
  background-color: #FFFFFF;
}

.oc-entry__main::before,
.oc-entry__main::after {
  position: absolute;
  content: "";
  background-image: url(/assets/img/opencampus/ornament_2.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 274px;
  aspect-ratio: 274 / 205;
}

.oc-entry__main::before {
  top: -64px;
  right: -64px;
}

.oc-entry__main::after {
  bottom: -64px;
  left: -64px;
}

.oc-entry__header {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 32px;
}

.oc-entry-header__title {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.oc-entry-header__title h1 {
  font-size: 2.8em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
}

.oc-entry-header__categories {
  display: flex;
  align-items: baseline;
  gap: 12px;
}

.oc-entry-header__category {
  padding: 6px 10px;
  border-radius: 99px;
  color: #FFFFFF;
  font-size: 1.4em;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.03em;
}

.oc-entry-header__content {
  display: grid;
  grid-template-columns: 564fr 432fr;
  gap: 24px;
}

.oc-entry-header__img {
  border-radius: 8px;
  overflow: hidden;
}

.oc-entry-header__img img {
  width: 100%;
  height: auto;
}

.oc-entry-header__daytime {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.oc-entry-header__daytime--item {
  position: relative;
  display: flex;
  align-items: baseline;
  gap: 12px;
}

.oc-entry-header__daytime--item:first-of-type {
  padding-bottom: 14px;
}

.oc-entry-header__daytime--item:first-of-type::before {
  content: "";
  height: 1px;
  width: 100%;
  margin: auto;
  position: absolute;
  left: 0;
  bottom: 0;
  background-image: radial-gradient(circle, #C2C2C2 1px, transparent 1.5px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
}

.oc-entry-header__daytime--title {
  flex: none;
  padding: 4px;
  width: 117px;
  text-align: center;
  font-size: 1.5em;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0;
  background-color: #FFD0D0;
}

.oc-entry-header__date,
.oc-entry-header__time {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.oc-entry-header__date li,
.oc-entry-header__time li {
  font-size: 1.8em;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0;
}

.oc-entry__body {
  position: relative;
  z-index: 1;
  margin-top: 56px;
}

@media only screen and (max-width: 767px) {
  .oc-entry__main {
    margin-top: 16px;
    padding: 20px;
  }

  .oc-entry__main::before {
    width: 188px;
    top: -54px;
    right: -15px;
  }

  .oc-entry__main::after {
    width: 188px;
    bottom: -54px;
    left: -15px;
  }

  .oc-entry-header__title h1 {
    font-size: 2.2em;
  }

  .oc-entry-header__category {
    font-size: 1.2em;
  }

  .oc-entry-header__content {
    grid-template-columns: 1fr;
  }

  .oc-entry-header__img {
    border-radius: 4px;
  }

  .oc-entry-header__daytime--title {
    font-size: 1.5em;
    width: 87px;
  }

  .oc-entry-header__daytime--item {
    padding-bottom: 14px;
  }

  .oc-entry-header__daytime--item::before {
    content: "";
    height: 1px;
    width: 100%;
    margin: auto;
    position: absolute;
    left: 0;
    bottom: 0;
    background-image: radial-gradient(circle, #C2C2C2 1px, transparent 1.5px);
    background-size: 6px 2px;
    background-repeat: repeat-x;
  }

  .oc-entry-header__date li,
  .oc-entry-header__time li {
    font-size: 1.5em;
  }
}


/* =======================================
	c-entry
======================================= */
.c-entry {
  word-break: break-all;
}

.c-entry h2 {
  position: relative;
  margin-bottom: 16px;
  padding: 10px 16px;
  border-radius: 4px;
  background-color: #FFD86A;
  font-size: 2.4em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
}

.c-entry h2::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url(/assets/img/opencampus/pattern.png) repeat;
  background-size: 5%;
  opacity: 0.2;
  mix-blend-mode: soft-light;
}

.c-entry h3 {
  position: relative;
  margin-bottom: 12px;
  padding-bottom: 12px;
  font-size: 2em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
}

.c-entry h3::before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #FF9860 0%, #FFE23D 100%);
}

.c-entry h4 {
  margin-bottom: 8px;
  font-size: 1.8em;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0;
}

.c-entry p {
  margin-bottom: 16px;
  font-size: 1.5em;
  line-height: 1.8;
  letter-spacing: 0;
}

.c-entry p strong {
  font-weight: 700;
}

.c-entry img {
  border-radius: 8px;
  max-width: 720px;
  width: 100%;
  height: auto;
}

.c-entry .img {
  margin: 0 auto;
  margin-bottom: 40px;
  max-width: 720px;
}

.c-entry .imgs {
  margin-bottom: 40px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.c-entry .cols {
  margin-bottom: 40px;
  display: grid;
  grid-template-columns: 560fr 436fr;
  gap: 24px;
}

@media only screen and (max-width: 767px) {
  .c-entry h2 {
    padding: 8px 12px;
    font-size: 2em;
  }

  .c-entry h2::before {
    background-size: 12%;
  }

  .c-entry h3 {
    font-size: 1.9em;
  }

  .c-entry h4 {
    font-size: 1.6em;
  }

  .c-entry img  {
    border-radius: 4px;
  }

  .c-entry .imgs {
    grid-template-columns: 1fr;
  }

  .c-entry .cols {
    grid-template-columns: 1fr;
  }
}


/* =======================================
	oc-entry__flow
======================================= */
.oc-entry__flow {
  position: relative;
  z-index: 1;
  margin-top: 40px;
  padding: 32px;
  display: grid;
  gap: 24px;
  border-radius: 8px;
  border: 2px solid #E3E3E3;
}

.oc-entry-flow__inner {
  overflow: hidden;
}

.oc-entry-flow__title {
  display: flex;
  align-items: center;
  gap: 12px;
}

.oc-entry-flow__title img {
  width: 49px;
  height: auto;
}

.oc-entry-flow__title h2 {
  font-size: 2.4em;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0;
}

.oc-entry-flow__list {
  display: flex;
  justify-content: center;
  gap: 24px;
}

.oc-entry-flow__item {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.oc-entry-flow__item:not(:last-of-type)::before {
  position: absolute;
  content: "";
  background-image: url(/assets/img/opencampus/icon-arrow-yellow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 8px;
  aspect-ratio: 8 / 10;
  top: 74px;
  right: -16px;
}

/* カスタムスクロールバー */
.oc-entry-flow__scrollbar {
  display: none;
}

.oc-entry-flow__scrollbar__thumb {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  height: 10px;
  background: #AAAAAA;
  border-radius: 999px;
  transition: left 0.1s;
}

.oc-entry-flow__img {
    position: relative;
    border: 2px solid #FFCF4A;
    border-radius: 4px;
    overflow: hidden;
}

.oc-entry-flow__time {
    position: absolute;
    z-index: 1;
    padding: 6px 8px;
    background-color: #FFCF4A;
    border-radius: 0 0 4px 0;
    font-family: "Roboto", sans-serif;
    font-weight: 700;
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0.05em;
}

.oc-entry-flow__txt {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0;
}

@media only screen and (max-width: 767px) {
  .oc-entry__flow {
    padding: 32px 20px;
    gap: 20px;
    border-radius: 4px;
  }

  .oc-entry-flow__title img {
    width: 41px;
  }

  .oc-entry-flow__title h2 {
    font-size: 1.8em;
  }

  .oc-entry-flow__list {
    justify-content: flex-start;
    overflow-x: scroll;
    flex-wrap: nowrap;
    scrollbar-width: none;
    padding-bottom: 10px;
  }

  .oc-entry-flow__item { 
      width: 230px;
      flex: none;
  }

  .oc-entry-flow__list::-webkit-scrollbar {
      display: none;
  }

  .oc-entry-flow__scrollbar {
      display: block;
      position: relative;
      width: 100%;
      height: 10px;
      background: #EAEAEA;
      border-radius: 999px;
      margin-top: 10px;
  }
}


/* =======================================
	oc-entry__button
======================================= */
.oc-entry__button {
  position: relative;
  z-index: 1;
  margin-top: 40px;
  padding: 32px 64px;
  border-radius: 8px;
  background: linear-gradient(90deg, #FD7575 0%, #FFBF48 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
}

.oc-entry__button::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 8px;
    background: linear-gradient(90deg, #FFA13D 0%, #FF6360 100%);
    opacity: 0;
    transition: opacity 0.3s;
    z-index: -1;
}

.oc-entry__button::after {
  content: '';
  position: absolute;
  inset: 0;
  background: url(/assets/img/opencampus/pattern.png) repeat;
  background-size: 5%;
  opacity: 0.1;
  mix-blend-mode: soft-light;
}

@media (hover: hover) {
  .oc-entry__button:hover .oc-entry__link {
    transform: translateY(4px);
    box-shadow: none;
  }

  .oc-entry__button:hover::before {
    opacity: 1;
  }
}

.oc-entry__button h2 {
  flex: none;
  color: #FFFFFF;
  font-size: 2.8em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  text-align: center;
}

.oc-entry__link {
  width: 100%;
  padding: 16px;
  background-color: #FFFFFF;
  border-radius: 4px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  box-shadow: 4px 4px 0px 0px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s;
}

.oc-entry__link__txt {
  overflow: hidden;
}

.oc-entry__link p {
  display: inline-block;
  font-size: 2em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
  background: linear-gradient(90deg, #FF6360 0%, #FFA13D 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.oc-entry__link .oc-icon--arrow {
  flex: none;
  width: 24px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #FF6360 0%, #FFA13D 100%);
  display: flex;
  justify-content: center;
  align-items: center;
}

.oc-entry__link .oc-icon--arrow img {
  transform: rotate(90deg);
}

@media only screen and (max-width: 767px) {
  .oc-entry__button {
    padding: 24px 20px;
    border-radius: 4px;
    flex-direction: column;
    gap: 16px;
  }

  .oc-entry__button::after {
    background-size: 12%;
  }

  .oc-entry__button h2 {
    font-size: 2.2em;
  }

  .oc-entry__link .oc-icon--arrow {
    width: 22px;
  }

  .oc-entry__link p {
    font-size: 1.6em;
  }
}


/* =======================================
	oc-entry__fixed
======================================= */
.oc-entry__fixed {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 100;
  transition: opacity 0.3s, visibility 0.3s;
}

.oc-entry__fixed.is-hidden {
  opacity: 0;
  visibility: hidden;
}

.oc-entry__fixed--link {
  position: relative;
  margin: 0 auto;
  width: 100%;
  max-width: 282px;
  padding: 18px 24px;
  background: linear-gradient(90deg, #FF6360 0%, #FFA13D 100%);
  border-radius: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  box-shadow: 2px 2px 0px 0px rgba(0, 0, 0, 0.2);
  transition: transform 0.3s;
}

.oc-entry__fixed--link::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 8px;
    background: linear-gradient(90deg, #FFA13D 0%, #FF6360 100%);
    opacity: 0;
    transition: opacity 0.3s;
    z-index: -1;
}

.oc-entry__fixed--link::after {
  content: '';
  position: absolute;
  inset: 0;
  background: url(/assets/img/opencampus/pattern.png) repeat;
  background-size: 15%;
  opacity: 0.1;
  mix-blend-mode: soft-light;
}

@media (hover: hover) {
  .oc-entry__fixed--link:hover {
    transform: scale(1.03);
  }

  .oc-entry__fixed--link:hover::before {
    opacity: 1;
  }
}

.oc-entry__fixed--link p {
  position: relative;
  transition: transform 0.3s ease;
  color: #FFFFFF;
  font-size: 1.8em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
}

.oc-entry__fixed--link .oc-icon--arrow {
  flex: none;
  width: 24px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: #FFFFFF;
  display: flex;
  justify-content: center;
  align-items: center;
}

.oc-entry__fixed--link .oc-icon--arrow::after {
  content: "";
  width: 9px;
  aspect-ratio: 9 / 11;
  mask-image: url(/assets/img/opencampus/icon-arrow1.svg);
  mask-repeat: no-repeat;
  mask-size: contain;
  background-color: #FD7575;
  transform: rotate(90deg);
}

@media only screen and (max-width: 767px) {
  .oc-entry__fixed {
    width: calc(100% - 132px);
    bottom: 24px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
  }

  .oc-entry__fixed--link {
    max-width: 258px;
    padding: 18px 12px;
  }

  .oc-entry__fixed--link p {
    font-size: 1.6em;
  }

  .oc-entry__fixed--link .oc-icon--arrow {
    width: 22px;
  }

  .oc-entry__fixed--link .oc-icon--arrow::after {
    width: 8px;
  }
}


