@charset "UTF-8";
/*----------------------------------------------------
  変数
----------------------------------------------------*/
/*----------------------------------------------------
  全体
----------------------------------------------------*/
html {
  scroll-snap-type: y proximity;
  scroll-behavior: smooth;
}

body {
  color: #484848;
  font-size: 4vw;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  position: relative;
}
@media screen and (min-width: 992px) {
  body {
    font-size: 1.6rem;
  }
}

@media screen and (min-width: 992px) {
  .wrap {
    display: grid;
    align-items: start;
    grid-template-columns: 1fr 400px 1fr;
    grid-column-gap: 0px;
  }
}
@media screen and (min-width: 992px) {
  .wrap > div.left-wrap {
    min-height: 100vh;
    position: sticky;
    top: 0;
    z-index: 1;
    background: radial-gradient(at 60% 99%, hsl(227, 100%, 93%) 0px, transparent 50%), radial-gradient(at 80% 99%, hsl(197, 91%, 91%) 0px, transparent 50%), radial-gradient(at 98% 34%, hsl(195, 100%, 92%) 0px, transparent 50%), radial-gradient(at 56% 0%, hsl(227, 100%, 93%) 0px, transparent 50%), radial-gradient(at 0% 14%, hsl(194, 100%, 91%) 0px, transparent 50%), radial-gradient(at 0% 40%, hsl(210, 100%, 91%) 0px, transparent 50%), radial-gradient(at 0% 68%, hsl(227, 100%, 93%) 0px, transparent 50%);
    background-color: hsl(0, 0%, 100%);
  }
}
@media screen and (min-width: 992px) {
  .wrap > div.right-wrap {
    min-height: 100vh;
    position: sticky;
    top: 0;
    z-index: 1;
    background-color: hsl(0, 0%, 100%);
    background: radial-gradient(at 78% 98%, hsl(227, 100%, 93%) 0px, transparent 50%), radial-gradient(at 45% 100%, hsl(197, 91%, 91%) 0px, transparent 50%), radial-gradient(at 90% 1%, hsl(195, 100%, 92%) 0px, transparent 50%), radial-gradient(at 40% 10%, hsl(227, 100%, 93%) 0px, transparent 50%), radial-gradient(at 0% 31%, hsl(194, 100%, 91%) 0px, transparent 50%), radial-gradient(at 0% 61%, hsl(210, 100%, 91%) 0px, transparent 50%), radial-gradient(at 19% 96%, hsl(227, 100%, 93%) 0px, transparent 50%);
  }
}

.bg-loop {
  display: none;
}
@media screen and (min-width: 992px) {
  .bg-loop {
    display: flex;
    width: 100%;
    overflow: hidden;
    position: fixed;
    bottom: 0;
    z-index: 1;
  }
  .bg-loop .inner {
    display: flex;
    width: max-content;
    animation: text-loop 80s linear infinite;
  }
  .bg-loop .inner span {
    flex: 0 0 auto;
    color: #004098;
    opacity: 0.4;
    font-family: "Caveat", cursive;
    font-size: 15rem;
    font-weight: 400;
    line-height: 1;
    white-space: nowrap;
    padding-left: 0.5em;
    user-select: none;
  }
}

@keyframes text-loop {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
/*----------------------------------------------------
  左側
----------------------------------------------------*/
.left-wrap {
  display: none;
}
@media screen and (min-width: 992px) {
  .left-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
  }
}
.left-wrap .logo {
  position: absolute;
  top: 2rem;
  left: 2rem;
}
.left-wrap .logo img {
  display: inline-block;
  width: 220px;
  height: auto;
}
.left-wrap > div {
  width: 235px;
  max-width: 100%;
  position: relative;
  z-index: 1;
}
.left-wrap .ttl-contents {
  display: block;
  max-width: 100%;
  margin: 0 auto 5rem;
}
.left-wrap ul.contents-list {
  list-style: none;
  padding-left: 0;
  margin-bottom: 5rem;
}
.left-wrap ul.contents-list li {
  border-bottom: 1px solid #004098;
}
.left-wrap ul.contents-list li:first-child {
  border-top: 1px solid #004098;
}
.left-wrap ul.contents-list li a {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  color: #004098;
  text-decoration: none;
  padding: 1.6em 1em;
}
.left-wrap ul.contents-list li a:hover {
  color: #022b62;
}

/*----------------------------------------------------
  メイン
----------------------------------------------------*/
.main-wrap {
  position: relative;
  z-index: 50;
  overflow: hidden;
  background-color: #fff;
}
@media screen and (min-width: 992px) {
  .main-wrap > .inner {
    border-left: 2px solid #fff;
    border-right: 2px solid #fff;
  }
}
.main-wrap main {
  position: relative;
}
.main-wrap main::before {
  position: fixed;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
  content: "";
  background: radial-gradient(at 60% 99%, hsl(227, 100%, 93%) 0px, transparent 50%), radial-gradient(at 80% 99%, hsl(197, 91%, 91%) 0px, transparent 50%), radial-gradient(at 98% 34%, hsl(195, 100%, 92%) 0px, transparent 50%), radial-gradient(at 56% 0%, hsl(227, 100%, 93%) 0px, transparent 50%), radial-gradient(at 0% 14%, hsl(194, 100%, 91%) 0px, transparent 50%), radial-gradient(at 0% 40%, hsl(210, 100%, 91%) 0px, transparent 50%), radial-gradient(at 0% 68%, hsl(227, 100%, 93%) 0px, transparent 50%);
}
@media screen and (min-width: 992px) {
  .main-wrap main::before {
    width: 400px;
    left: 50%;
    transform: translateX(-50%);
  }
}

.mainimage-area {
  position: relative;
  margin: 0 -5.332vw;
}
@media screen and (min-width: 992px) {
  .mainimage-area {
    margin: 0 -2rem;
  }
}
.mainimage-area > img {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 auto;
}

.oc-title-area {
  padding-top: 38vw;
  position: relative;
}
@media screen and (min-width: 992px) {
  .oc-title-area {
    padding-top: 14rem;
  }
}
.oc-title-area .ttl-oc {
  position: absolute;
  top: -28vw;
  text-align: center;
}
@media screen and (min-width: 992px) {
  .oc-title-area .ttl-oc {
    top: -10.5rem;
  }
}
.oc-title-area .ttl-oc span {
  display: block;
  font-family: "Caveat", cursive;
  font-weight: 400;
  line-height: 1;
  color: #004098;
}
.oc-title-area .ttl-oc span.tomitan {
  font-size: 20.2vw;
}
@media screen and (min-width: 992px) {
  .oc-title-area .ttl-oc span.tomitan {
    font-size: 7.6rem;
  }
}
.oc-title-area .ttl-oc span.opencampus {
  font-size: 12.8vw;
}
@media screen and (min-width: 992px) {
  .oc-title-area .ttl-oc span.opencampus {
    font-size: 4.8rem;
  }
}
.oc-title-area .ttl-oc span.year {
  font-size: 30.1vw;
  margin-top: -0.1em;
  margin-left: -0.15em;
}
@media screen and (min-width: 992px) {
  .oc-title-area .ttl-oc span.year {
    font-size: 11.3rem;
  }
}

.contents-wrap {
  padding: 0 5.332vw;
}
@media screen and (min-width: 992px) {
  .contents-wrap {
    padding: 0 2rem;
  }
}
.contents-wrap .section-area {
  padding-top: 5vw;
  padding-bottom: 21.4vw;
}
@media screen and (min-width: 992px) {
  .contents-wrap .section-area {
    padding-top: 2rem;
    padding-bottom: 8rem;
  }
}

.section-title {
  text-align: center;
  margin-bottom: 8vw;
}
@media screen and (min-width: 992px) {
  .section-title {
    margin-bottom: 3rem;
  }
}
.section-title span {
  display: block;
  color: #004098;
}
.section-title .en {
  font-family: "Caveat", cursive;
  font-size: 11vw;
  font-weight: 400;
  line-height: 1;
}
@media screen and (min-width: 992px) {
  .section-title .en {
    font-size: 4.2rem;
  }
}
.section-title .jp {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
}

/*--------------- メイン ---------------*/
.section-area.catch-area {
  text-align: center;
}
.section-area.catch-area .catch-title {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 8vw;
  font-weight: 600;
  color: #004098;
  margin-bottom: 0.6em;
}
@media screen and (min-width: 992px) {
  .section-area.catch-area .catch-title {
    font-size: 3.2rem;
  }
}
.section-area.catch-area .catch-title + p {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  color: #004098;
  line-height: 2;
  display: inline-block;
  text-align: left;
}

/*--------------- 開催内容 ---------------*/
.event-block {
  display: flex;
  margin-bottom: 8vw;
}
@media screen and (min-width: 992px) {
  .event-block {
    margin-bottom: 3rem;
  }
}
.event-block .text {
  flex: 1;
}
.event-block .text h3 {
  font-size: 4.8vw;
  font-weight: 500;
  color: #004098;
  padding-left: 2.2em;
  position: relative;
  margin-bottom: 0.5em;
  margin-left: -2vw;
}
@media screen and (min-width: 992px) {
  .event-block .text h3 {
    font-size: 1.8rem;
    margin-left: 0;
  }
}
.event-block .text h3 .number {
  display: inline-block;
  font-family: "Caveat", cursive;
  font-size: 2em;
  font-weight: 500;
  line-height: 1;
  position: absolute;
  top: -0.2em;
  left: -0.1em;
}
.event-block .text p {
  font-size: 3.2vw;
}
@media screen and (min-width: 992px) {
  .event-block .text p {
    font-size: 1.2rem;
  }
}
.event-block .image {
  width: 38vw;
  height: 38vw;
  border-radius: 50%;
  overflow: hidden;
  margin-left: 4vw;
}
@media screen and (min-width: 992px) {
  .event-block .image {
    width: 158px;
    height: 158px;
    margin-left: 1.5rem;
  }
}
.event-block .image img {
  aspect-ratio: 1/1;
  object-fit: cover;
  width: 100%;
  object-position: center center;
}

/*--------------- 開催日程 ---------------*/
.schedule-block {
  border: 2px solid #004098;
  background-color: rgba(255, 255, 255, 0.8);
  padding: 5.332vw;
  border-radius: 5.332vw;
  margin-bottom: 5.332vw;
}
@media screen and (min-width: 992px) {
  .schedule-block {
    padding: 2rem;
    border-radius: 2rem;
    margin-bottom: 2rem;
  }
}
.schedule-block .date-area {
  text-align: center;
  margin-bottom: 2vw;
}
@media screen and (min-width: 992px) {
  .schedule-block .date-area {
    margin-bottom: 0.8rem;
  }
}
.schedule-block .date-area span {
  display: inline-block;
  color: #004098;
}
.schedule-block .date-area .year {
  font-size: 6.4vw;
  font-family: "Noto Serif JP", serif;
  padding-right: 0.6em;
}
@media screen and (min-width: 992px) {
  .schedule-block .date-area .year {
    font-size: 2.4rem;
  }
}
.schedule-block .date-area .date {
  font-size: 14.4vw;
  font-family: "Noto Serif JP", serif;
  line-height: 1.2;
}
@media screen and (min-width: 992px) {
  .schedule-block .date-area .date {
    font-size: 5.4rem;
  }
}
.schedule-block .date-area .week {
  font-weight: 600;
}
.schedule-block .schedule-title {
  font-size: 4.8vw;
  color: #004098;
  text-align: center;
  margin-bottom: 2vw;
}
@media screen and (min-width: 992px) {
  .schedule-block .schedule-title {
    font-size: 1.8rem;
    margin-bottom: 0.8rem;
  }
}
.schedule-block .btn-entry {
  display: block;
  text-decoration: none;
  border: 2px solid;
  text-align: center;
  padding: 3.2vw;
  border-radius: 10vw;
  font-size: 4.8vw;
  font-weight: 500;
  margin-top: 5.332vw;
  transition: 0.2s;
  user-select: none;
}
@media screen and (min-width: 992px) {
  .schedule-block .btn-entry {
    padding: 1.2rem;
    font-size: 1.8rem;
    border-radius: 5rem;
    margin-top: 2rem;
  }
}
.schedule-block .btn-entry.open {
  border-color: #004098;
  background-color: #004098;
  color: #fff;
}
.schedule-block .btn-entry.open:hover {
  border-color: #022b62;
  background-color: #022b62;
}
.schedule-block .btn-entry.preparation {
  border-color: #004098;
  color: #004098;
  cursor: default;
}
.schedule-block .btn-entry.end {
  border-color: #b0b0b0;
  background-color: #b0b0b0;
  color: #fff;
  cursor: default;
}
.detail-area img {
  display: inline-block;
  max-width: 100%;
  height: auto;
}
/*--------------- 開催場所 ---------------*/
.section-area.location-area {
  padding-bottom: 2rem;
}
.section-area.location-area .txt-location {
  text-align: center;
  line-height: 2.5;
  font-size: 3.2vw;
}
@media screen and (min-width: 992px) {
  .section-area.location-area .txt-location {
    font-size: 1.2rem;
  }
}
.section-area.location-area .txt-location .college {
  display: block;
  font-size: 1.8em;
  line-height: 2;
}
.section-area.location-area .button-area a.btn-access {
  display: block;
  background-color: #004098;
  color: #fff;
  text-decoration: none;
  text-align: center;
  padding: 1.2rem;
  border-radius: 10vw;
  font-size: 4.8vw;
  margin-top: 5.332vw;
  margin-left: auto;
  margin-right: auto;
  width: 83vw;
  transition: 0.2s;
}
@media screen and (min-width: 992px) {
  .section-area.location-area .button-area a.btn-access {
    padding: 1.2rem;
    font-size: 1.8rem;
    border-radius: 5rem;
    margin-top: 2rem;
    width: 312px;
  }
}
.section-area.location-area .button-area a.btn-access:hover {
  background-color: #022b62;
}

/*--------------- フッター ---------------*/
footer {
  background: linear-gradient(to top, #fff 70%, rgba(255, 255, 255, 0) 100%);
  padding: 7rem 2rem 9rem;
}
@media screen and (min-width: 992px) {
  footer {
    padding-bottom: 3rem;
  }
}
footer img.logo {
  display: block;
  margin: 0 auto 2rem;
  max-width: 100%;
  width: 220px;
  height: auto;
}
footer .copyright {
  text-align: center;
  font-size: 1rem;
}
@media screen and (min-width: 992px) {
  footer .copyright {
    font-size: 1.2rem;
  }
}

/*----------------------------------------------------
  右側
----------------------------------------------------*/
.right-wrap {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 51;
  width: 100%;
}
@media screen and (min-width: 992px) {
  .right-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
}
.right-wrap ul.conversion-button {
  list-style: none;
  padding-left: 0;
  display: flex;
}
@media screen and (min-width: 992px) {
  .right-wrap ul.conversion-button {
    flex-direction: column;
  }
}
.right-wrap ul.conversion-button li {
  width: 50%;
}
@media screen and (min-width: 992px) {
  .right-wrap ul.conversion-button li {
    width: 200px;
    margin: 1.5rem 0;
  }
}
.right-wrap ul.conversion-button li a {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1.6rem 0 1.8rem;
  text-align: center;
  color: #fff;
  text-decoration: none;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1;
  transition: 0.2s;
}
.right-wrap ul.conversion-button li a.request {
  background-color: #004098;
}
.right-wrap ul.conversion-button li a.request:hover {
  background-color: #022b62;
}
.right-wrap ul.conversion-button li a.application {
  background-color: #066AD5;
}
.right-wrap ul.conversion-button li a.application:hover {
  background-color: #0c59ab;
}
.right-wrap ul.conversion-button li a span {
  display: inline-block;
  vertical-align: middle;
}
.right-wrap ul.conversion-button li a img {
  display: inline-block;
  vertical-align: middle;
  margin-right: 0.3rem;
  margin-top: 0.3rem;
}/*# sourceMappingURL=home.css.map */