@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&family=Zen+Maru+Gothic:wght@300;400;500;700;900&display=swap");
/*-----------------------------------------------------------------
Reset
-----------------------------------------------------------------*/
html {
  overflow-y: scroll;
}

body, div, p, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, blockquote, pre, form, input, textarea, header, footer, nav, figure, figcaption {
  margin: 0;
  padding: 0;
  zoom: 1;
}

header, footer, main, nav, article, aside, section {
  display: block;
}

ul, ol {
  list-style-type: none;
}

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

img {
  max-width: 100%;
  height: auto;
  border: none;
  vertical-align: middle;
}

hr {
  display: none;
  margin: 0;
  padding: 0;
  width: 1px;
  height: 1px;
}

a {
  outline: none;
}

@media all and (-ms-high-contrast: none) {
  select::-ms-expand {
    display: none;
  }
}
input, button, textarea, select {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/*-----------------------------------------------------------------
Base
-----------------------------------------------------------------*/
/* Font
----------------------------------------*/
* {
  font-style: normal;
  font-weight: 500;
}

/* Default
----------------------------------------*/
body {
  position: relative;
  font-family: "Zen Maru Gothic", serif;
  color: #000;
}
@media screen and (max-width: 768px) {
  body {
    font-size: 0.875rem;
    line-height: 1.8;
    -webkit-text-size-adjust: 100%;
  }
}
@media screen and (min-width: 769px) {
  body {
    min-width: 1200px;
    font-size: 1rem;
    line-height: 2;
  }
}
body a {
  color: #000;
  text-decoration: none;
}

button, input {
  font-family: "Zen Maru Gothic", serif;
}

*:focus-visible {
  outline: 3px solid #333 !important;
}

/*-----------------------------------------------------------------
Common
-----------------------------------------------------------------*/
/* loading */
.loading {
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  background: #fff;
  z-index: 50;
}
.loading-logo img {
  width: 195px;
}
@media screen and (max-width: 768px) {
  .loading-logo img {
    width: 150px;
  }
}
.loading-ic {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}
.loading-ic li {
  display: block;
  width: 15px;
  height: 15px;
  background-color: #333;
  border-radius: 50%;
  margin: 0 5px;
  animation: animateLoading 1.5s linear 10;
}
.loading-ic li:nth-child(1) {
  background-color: #10069f;
  animation-delay: 0s;
}
.loading-ic li:nth-child(2) {
  background-color: #00b388;
  animation-delay: .2s;
}
.loading-ic li:nth-child(3) {
  background-color: #5bc2e7;
  animation-delay: .4s;
}
.loading-ic li:nth-child(4) {
  background-color: #ffbf3f;
  animation-delay: .6s;
}

@keyframes animateLoading {
  0% {
    transform: translateY(0);
  }
  10% {
    transform: translateY(-15px);
  }
  20% {
    transform: translateY(0);
  }
  80% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(0);
  }
}
/* js-scroll */
.js-scroll {
  visibility: hidden;
}

.page.is-show .js-scroll-in {
  opacity: 0;
  visibility: visible;
  animation: animateScroll .5s ease .3s forwards;
}

@keyframes animateScroll {
  0% {
    transform: translateY(0);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
/* main */
.main {
  padding-top: 47px;
}

.page {
  opacity: 0;
  visibility: hidden;
  overflow: hidden;
  transition: all .5s;
}
.page.is-show {
  opacity: 1;
  visibility: visible;
}

.compensate-for-scrollbar {
  margin-right: 0 !important;
}

.bg01 {
  aspect-ratio: 1920/420;
  background-image: url("/application/themes/admissions_new/event_v4/img/bg_01.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  .bg01 {
    aspect-ratio: 375/240;
    background-image: url("/application/themes/admissions_new/event_v4/img/bg_01_sp.png");
  }
}

.pagetop {
  position: fixed;
  bottom: 30px;
  right: 30px;
  z-index: 10;
  visibility: hidden;
  opacity: 0;
  cursor: pointer;
  transition: all .5s;
}
@media screen and (max-width: 768px) {
  .pagetop {
    bottom: 15px;
    right: 15px;
    width: 50px;
  }
}
.pagetop.is-show {
  visibility: visible;
  opacity: 1;
}

/*-----------------------------------------------------------------
Header
-----------------------------------------------------------------*/
.header {
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  gap: 0 70px;
  width: 100%;
  height: 47px;
  white-space: nowrap;
  background-color: #EDF446;
  overflow: hidden;
  z-index: 100;
}

.header-inner {
  display: flex;
  align-items: center;
  padding: 5px 0;
  animation: animateMarquee 20s linear infinite;
}

.header-txt1 {
  font-style: italic;
  font-family: "Figtree", sans-serif;
  font-size: 0.875rem;
  font-weight: 700;
  color: #535377;
  margin-right: 15px;
}

.header-txt2 {
  font-style: italic;
  display: flex;
  align-items: center;
  gap: 0 5px;
  font-family: "Figtree", sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: #535377;
  margin-right: 15px;
}
.header-txt2 i {
  font-size: 60%;
}

.header-txt3 {
  font-size: 0.875rem;
  font-weight: 700;
  color: #535377;
}

.header-list {
  display: flex;
  margin-right: 1em;
}
.header-list li {
  font-size: 0.75rem;
  font-weight: 500;
  color: #fff;
  line-height: 1;
  padding: 4px 10px;
  margin-right: 3px;
  border-radius: 2em;
}
.header-list li:nth-child(1) {
  background-color: #AD2C47;
}
.header-list li:nth-child(2) {
  background-color: #F675C5;
}
.header-list li:nth-child(3) {
  background-color: #74C9C9;
}

@keyframes animateMarquee {
  0% {
    transform: translate(0);
  }
  100% {
    transform: translate(calc(-100% - 70px));
  }
}
/*-----------------------------------------------------------------
ナビ
-----------------------------------------------------------------*/
.gnav {
  position: fixed;
  top: 0;
  width: 100%;
  height: 0;
  overscroll-behavior-y: contain;
  transition: all .5s;
  z-index: 100;
}
.gnav.is-active {
  height: auto;
  background-image: url("/application/themes/admissions_new/event_v4/img/gnav_bg_sp.png");
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
}
@media screen and (min-width: 769px) {
  .gnav {
    display: none;
  }
}

.gnav-cont {
  height: 100vh;
  padding: 30px 8% 20px;
  overscroll-behavior-y: contain;
  overflow-y: scroll;
  opacity: 0;
  visibility: hidden;
  transition: all .5s;
}
.gnav-cont.is-active {
  opacity: 1;
  visibility: visible;
}

.gnav-bm {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 55px;
  height: 55px;
  padding: 10px;
  text-align: center;
  background-color: #000E62;
  border: 2px solid #fff;
  border-radius: 10px;
  transition: all .5s;
  cursor: pointer;
  z-index: 100;
}
.gnav-bm::after {
  content: 'MENU';
  font-style: italic;
  font-family: "Figtree", sans-serif;
  font-size: 0.625rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
  transform: translateY(5px);
  opacity: 1;
  visibility: visible;
  transition: all .5s;
}
.gnav-bm.is-active::after {
  content: 'CLOSE';
}
.gnav-bm-trigger {
  position: relative;
  width: 80%;
  height: 22px;
  margin: 0 auto;
  transform: translateY(0);
  transition: all .5s;
}
.gnav-bm-trigger > span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #fff;
  transition: all .5s;
}
.gnav-bm-trigger > span:nth-of-type(1) {
  top: 2px;
}
.gnav-bm-trigger > span:nth-of-type(2) {
  top: 10px;
}
.gnav-bm-trigger > span:nth-of-type(3) {
  top: 18px;
}
.gnav-bm-trigger.is-active {
  transform: translateY(8px);
}
.gnav-bm-trigger.is-active > span {
  background-color: #fff;
}
.gnav-bm-trigger.is-active > span:nth-of-type(1) {
  top: 2px;
  transform: translateY(0) rotate(-45deg);
}
.gnav-bm-trigger.is-active > span:nth-of-type(2) {
  top: 8px;
  transform: translateY(-6px) rotate(45deg);
}
.gnav-bm-trigger.is-active > span:nth-of-type(3) {
  opacity: 0;
}

.gnav-menu {
  margin-top: 20px;
}
.gnav-menu__list {
  border-top: 2px dotted #1B5A98;
}
.gnav-menu__list li {
  border-bottom: 2px dotted #1B5A98;
}
.gnav-menu__list li a {
  display: block;
  font-family: "Zen Maru Gothic", serif;
  font-size: 1.0625rem;
  color: #fff;
  background-image: url("/application/themes/admissions_new/event_v4/img/ic_gnav_arrow.svg");
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 15px auto;
  padding: 10px 0;
}

.gnav-btn {
  margin-top: 30px;
}
.gnav-btn__list {
  display: flex;
  flex-direction: column;
  gap: 10px 0;
}
.gnav-btn__list li a {
  position: relative;
  display: block;
  font-size: 1rem;
  text-align: center;
  background-repeat: no-repeat;
  background-position: right 15px center;
  background-size: 15px auto;
  border: 2px solid #fff;
  border-radius: 2em;
  padding: 5px 10px;
}
.gnav-btn__list li a.-contact {
  color: #000E62;
  background-color: #E5FD54;
  background-image: url("/application/themes/admissions_new/event_v4/img/ic_circle_blue_arrow_white_right.svg");
}
.gnav-btn__list li a.-admission {
  color: #fff;
  background-color: #EF5550;
  background-image: url("/application/themes/admissions_new/event_v4/img/ic_gnav_arrow.svg");
}
.gnav-btn__list li a.-insta {
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-weight: 700;
  color: #fff;
  background-color: #000E62;
  background-image: url("/application/themes/admissions_new/event_v4/img/ic_gnav_arrow.svg");
}
.gnav-btn__list li a::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 15px;
  width: 25px;
  height: 25px;
  background-repeat: no-repeat;
  background-position: center center;
  margin: auto 0;
}
.gnav-btn__list li a.-contact::before {
  background-image: url("/application/themes/admissions_new/event_v4/img/gnav_ic_contact.png");
}
.gnav-btn__list li a.-admission::before {
  background-image: url("/application/themes/admissions_new/event_v4/img/gnav_ic_admission.png");
}
.gnav-btn__list li a.-insta::before {
  left: 20px;
  width: 20px;
  height: 20px;
  background-image: url("/application/themes/admissions_new/event_v4/img/gnav_ic_insta.png");
}

.gnav-logo {
  text-align: center;
}

.gnav-cr {
  font-style: italic;
  font-family: "Figtree", sans-serif;
  font-size: 0.6875rem;
  color: #000E62;
  text-align: center;
  margin: 20px 0 0;
}

/*-----------------------------------------------------------------
フッター
-----------------------------------------------------------------*/
.footer {
  position: relative;
  background-color: #fff;
  padding: 80px 0;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .footer {
    padding: 40px 0;
  }
}
.footer__inner {
  width: 92%;
  max-width: 1600px;
  margin: 0 auto;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .footer__inner {
    flex-direction: column;
  }
}
.footer__logo {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .footer__logo img {
    width: 80%;
    max-width: 290px;
  }
}
.footer__img01 {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 1591px;
  text-align: center;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .footer__img01 {
    position: relative;
    left: 0;
    transform: translateX(0);
    margin-top: 30px;
  }
}
.footer__list {
  display: flex;
  justify-content: center;
  gap: 0 10px;
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .footer__list {
    flex-direction: column;
    gap: 10px 0;
    margin-top: -30px;
  }
}
.footer__list > li a {
  display: block;
  transition: all .5s;
}
@media screen and (max-width: 768px) {
  .footer__list > li a {
    text-align: center;
  }
}
.footer__list > li a:hover {
  opacity: .7;
}
.footer__cr {
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 0.875rem;
  color: #000E62;
  text-align: center;
  padding-top: 30px;
}
@media screen and (max-width: 768px) {
  .footer__cr {
    font-size: 0.75rem;
  }
}

/*-----------------------------------------------------------------
メインビジュアル
-----------------------------------------------------------------*/
.mvH {
  position: relative;
  width: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/mvH_bg.png");
  background-position: center center;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  .mvH {
    background-image: url("/application/themes/admissions_new/event_v4/img/mvH_bg_sp.png");
  }
}
.mvH__inner {
  position: relative;
  width: 92%;
  max-width: 1557px;
  aspect-ratio: 1557 / 1055;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .mvH__inner {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 442px;
    aspect-ratio: 442 / 797;
  }
}
.mvH__inner::before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/mvH_people.png");
  background-position: center center;
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 1;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvH__inner::before {
    background-position: 0 10%;
    background-size: 107% auto;
    background-image: url("/application/themes/admissions_new/event_v4/img/mvH_people_sp.png");
  }
}
.page.is-show .mvH__inner::before {
  opacity: 1;
}
.mvH__title {
  position: relative;
  width: 51.44%;
  max-width: 801px;
  margin: 0 auto;
  padding-top: 3%;
  z-index: 2;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvH__title {
    width: 80%;
    padding-top: 37%;
  }
}
.page.is-show .mvH__title {
  opacity: 1;
}
.mvH__sch {
  position: relative;
  width: 27%;
  max-width: 411px;
  margin: 0 auto;
  padding-top: 20px;
  z-index: 2;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvH__sch {
    width: 60%;
  }
}
.page.is-show .mvH__sch {
  opacity: 1;
}
.mvH__en {
  position: absolute;
  bottom: 0;
  left: 50%;
  right: 50%;
  transform: translateX(-50%);
  width: 92%;
  max-width: 1897px;
  aspect-ratio: 1897 / 107;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvH__en {
    max-width: 374px;
    aspect-ratio: 374 / 94;
  }
}
.page.is-show .mvH__en {
  opacity: 1;
}

.mvD {
  position: relative;
  width: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/mvD_bg.png");
  background-position: center center;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  .mvD {
    background-image: url("/application/themes/admissions_new/event_v4/img/mvD_bg_sp.png");
  }
}
.mvD__inner {
  position: relative;
  width: 92%;
  max-width: 1557px;
  aspect-ratio: 1557 / 1055;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .mvD__inner {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 442px;
    aspect-ratio: 442 / 797;
  }
}
.mvD__inner::before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/mvD_people.png");
  background-position: 100% 90%;
  background-size: 16% auto;
  background-repeat: no-repeat;
  z-index: 1;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvD__inner::before {
    background-position: 85% 90%;
    background-size: 26% auto;
  }
}
.page.is-show .mvD__inner::before {
  opacity: 1;
}
.mvD__photo {
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (min-width: 769px) {
  .mvD__photo {
    width: 90%;
    margin: 0 auto;
  }
}
.page.is-show .mvD__photo {
  opacity: 1;
}
.mvD__photo img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .mvD__photo img {
    aspect-ratio: 375 / 280;
    object-fit: cover;
  }
}
.mvD__thumb {
  position: absolute;
  transform: translate(35%, -50%);
  width: 20%;
  max-width: 345px;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvD__thumb {
    display: none;
  }
}
.page.is-show .mvD__thumb {
  opacity: 1;
}
.mvD__sch {
  position: relative;
  width: 27%;
  max-width: 411px;
  margin: -14% auto 0;
  z-index: 1;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvD__sch {
    width: 60%;
    margin: -30% auto 0;
  }
}
.page.is-show .mvD__sch {
  opacity: 1;
}
.mvD__copy {
  width: 44%;
  max-width: 680px;
  margin: 3% auto 0;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvD__copy {
    width: 80%;
    margin: 4% auto 0;
  }
}
.page.is-show .mvD__copy {
  opacity: 1;
}
.mvD__txt {
  font-size: clamp(15px, 1.2vw, 20px);
  font-weight: 700;
  text-align: center;
  color: #fff;
  margin-top: 1.5%;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvD__txt {
    font-size: 0.8125rem;
    padding: 0 4%;
    margin-top: 3%;
  }
}
.page.is-show .mvD__txt {
  opacity: 1;
}
.mvD__logo {
  position: absolute;
  top: 5%;
  left: 0;
  max-width: 340px;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvD__logo {
    position: relative;
    top: inherit;
    left: inherit;
    width: 50%;
    margin: 3% 10%;
  }
}
.page.is-show .mvD__logo {
  opacity: 1;
}
.mvD__scroll {
  max-width: 169px;
  margin: 2% auto 0;
  opacity: 0;
  transition: all 1s;
  transition-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .mvD__scroll {
    width: 30%;
    margin-top: 2%;
  }
}
.page.is-show .mvD__scroll {
  opacity: 1;
}

/*-----------------------------------------------------------------
オープンキャンパス開催予定日
-----------------------------------------------------------------*/
.allsch {
  position: relative;
  background-color: #FBF34A;
  background-image: url("/application/themes/admissions_new/event_v4/img/allsch_bg.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  padding: 100px 0;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .allsch {
    padding: 40px 0;
  }
}
.allsch::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/allsch_bg_obj.png");
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: 100% auto;
}
@media screen and (max-width: 768px) {
  .allsch::before {
    background-image: url("/application/themes/admissions_new/event_v4/img/allsch_bg_obj_sp.png");
    background-position: 50% -10%;
    background-size: 100% auto;
  }
}
.allsch__inner {
  position: relative;
  width: 92%;
  max-width: 1130px;
  margin: 0 auto;
  z-index: 1;
}
.allsch__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
.allsch__head-en {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .allsch__head-en {
    width: 60%;
    max-width: 223px;
  }
}
.allsch__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .allsch__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.allsch__yoyaku {
  text-align: center;
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .allsch__yoyaku {
    margin-top: 10px;
  }
}
.allsch__subttl {
  text-align: center;
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .allsch__subttl {
    margin: 20px -4% 0;
  }
}
@media screen and (max-width: 768px) {
  .allsch__subttl img {
    width: 100%;
    max-width: 420px;
  }
}
.allsch__lead {
  position: relative;
  font-size: 1rem;
  color: #000E62;
  text-align: center;
  padding-top: 20px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .allsch__lead {
    font-size: 0.8125rem;
    padding: 10px 0 20px;
  }
}
.allsch__img01 {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 130%;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .allsch__img01 {
    position: relative;
    transform: translateX(-50%);
    width: 110%;
    max-width: 410px;
    margin-top: -100px;
  }
}
@media screen and (max-width: 768px) {
  .allsch__img01 img {
    width: 100%;
  }
}
.allsch__list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 40px 25px;
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .allsch__list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 15px 10px;
    margin-top: 0;
  }
}
.allsch__list > li a {
  display: block;
  transition: all .5s;
}
.allsch__list > li a:hover {
  opacity: .7;
}
.allsch__img img {
  width: 100%;
}
.allsch__info {
  margin-top: 5px;
}
@media screen and (max-width: 768px) {
  .allsch__info {
    margin-top: 0;
  }
}
.allsch__info img {
  width: 100%;
}

/*-----------------------------------------------------------------
ローカルナビ
-----------------------------------------------------------------*/
.localnav {
  display: none;
  position: relative;
  background-color: #B2DEDE;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .localnav {
    display: none;
  }
}
.localnav__inner {
  width: 92%;
  max-width: 1500px;
  margin: 0 auto;
  padding: 80px 0;
}
@media screen and (max-width: 768px) {
  .localnav__inner {
    padding: 40px 0;
  }
}

.localnav-list {
  display: flex;
  gap: 0 20px;
}
@media screen and (max-width: 768px) {
  .localnav-list {
    flex-wrap: wrap;
    gap: 10px;
  }
}
.localnav-list li {
  flex: auto;
}
@media screen and (max-width: 768px) {
  .localnav-list li {
    width: calc(50% - 10px);
  }
}
.localnav-list li a {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  font-size: 1.25rem;
  font-weight: 500;
  color: #fff;
  text-align: center;
  line-height: 1.2;
  background-color: #2A2867;
  background-image: url("/application/themes/admissions_new/event_v4/img/ic_circle_green_arrow_blue_down.svg");
  background-repeat: no-repeat;
  background-size: 18px auto;
  background-position: right 15px center;
  box-shadow: 0px 3px 6px -2px rgba(0, 0, 0, 0.16);
  border-radius: 8px;
  padding: 10px 35px 10px 10px;
  transition: all .5s;
}
@media screen and (max-width: 768px) {
  .localnav-list li a {
    font-size: 0.875rem;
  }
  .localnav-list li a.-sm {
    font-size: 0.6875rem;
  }
}
.localnav-list li a:hover {
  opacity: .7;
}

/*-----------------------------------------------------------------
Fix背景
-----------------------------------------------------------------*/
.fix {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/fix_bg.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  z-index: -1;
}

/*-----------------------------------------------------------------
Side
-----------------------------------------------------------------*/
.sideBtn {
  position: fixed;
  top: 20%;
  right: 0;
  z-index: 10;
}
@media screen and (max-width: 768px) {
  .sideBtn {
    position: relative;
    top: inherit;
    right: inherit;
    margin: auto auto 15px;
  }
}
@media screen and (max-width: 768px) {
  .sideBtn__list {
    display: flex;
    gap: 0 5px;
  }
}
@media screen and (max-width: 768px) {
  .sideBtn__list li {
    flex: 1;
  }
}
.sideBtn__list li:nth-child(n+2) {
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .sideBtn__list li:nth-child(n+2) {
    margin: 0;
  }
}

/*-----------------------------------------------------------------
オープンキャンパスのポイント
-----------------------------------------------------------------*/
.point {
  position: relative;
  background-color: #47D1DE;
  padding: 100px 0;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .point {
    padding: 40px 0;
  }
}
.point::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  /*max-width: 1800px;*/
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/point_bg_obj.png");
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: 100% auto;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .point::before {
    width: 100%;
    background-image: url("/application/themes/admissions_new/event_v4/img/point_bg_obj_sp.png");
  }
}
.point__inner {
  position: relative;
  width: 92%;
  max-width: 1480px;
  margin: 0 auto;
}
.point__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
.point__head-en {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .point__head-en {
    width: 80%;
    max-width: 550px;
  }
}
.point__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .point__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.point__img01 {
  position: absolute;
  top: -45px;
  right: 5%;
}
@media screen and (max-width: 768px) {
  .point__img01 {
    top: -35px;
    right: 0;
    width: 70px;
  }
}
.point__img02 {
  position: absolute;
  bottom: -40px;
  left: calc(100% - 30px);
  width: 124px;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .point__img02 {
    display: none;
  }
}

.point-oc {
  position: relative;
  overflow: hidden;
}
.point-oc__body {
  color: #fff;
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .point-oc__body {
    margin-top: 25px;
  }
}
@media screen and (min-width: 769px) {
  .point-oc__body .swiper-wrapper {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.point-oc__body .swiper-slide {
  height: auto;
}
.point-oc__body .swiper-pagination {
  position: relative;
  bottom: auto;
  text-align: center;
  margin-top: 10px;
}
@media screen and (min-width: 769px) {
  .point-oc__body .swiper-pagination {
    display: none;
  }
}
.point-oc__body .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  background: #000E62;
  margin: 0 8px !important;
  opacity: .25;
}
.point-oc__body .swiper-pagination-bullet-active {
  background: #000E62;
  opacity: 1;
}
.point-oc__item {
  height: 100%;
  background-color: #fff;
}
.point-oc__photo {
  text-align: center;
}
.point-oc__photo img {
  width: 100%;
}
.point-oc__cont {
  position: relative;
  padding: 40px 30px 30px;
}
@media screen and (max-width: 768px) {
  .point-oc__cont {
    padding: 30px 25px 25px;
  }
}
.point-oc__cont::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 10px;
  background-color: #000E62;
}
@media screen and (max-width: 768px) {
  .point-oc__cont::before {
    height: 7px;
  }
}
.point-oc__no {
  display: block;
  text-align: center;
}
.point-oc__no i {
  display: block;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 0.875rem;
  font-weight: 700;
  color: #000E62;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .point-oc__no i {
    font-size: 0.75rem;
  }
}
.point-oc__no span {
  display: block;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 3.75rem;
  font-weight: 800;
  color: #000E62;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .point-oc__no span {
    font-size: 2.8125rem;
  }
}
.point-oc__title {
  position: relative;
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 600;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  padding: 15px 0 20px;
}
@media screen and (max-width: 768px) {
  .point-oc__title {
    padding: 10px 0 15px;
  }
}
.point-oc__lead::after {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 60px;
  height: 1px;
  background-color: #000E62;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .point-oc__lead::after {
    width: 36px;
  }
}
.point-oc__txt {
  color: #000E62;
  padding-top: 20px;
}
@media screen and (max-width: 768px) {
  .point-oc__txt {
    padding-top: 15px;
  }
}

.point-item {
  position: relative;
}
.point-item__no {
  position: absolute;
  top: 0;
  right: 0;
  display: inline-block;
  font-family: "Lato", sans-serif;
  font-size: 5.9375rem;
  font-weight: 600;
  color: #2A2867;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .point-item__no {
    font-size: 4.375rem;
  }
}
.point-item__no::after {
  content: '';
  display: block;
  width: 60%;
  height: 1px;
  background-color: #2A2867;
  margin: 0 auto;
}
.point-item__photo {
  text-align: center;
}
.point-item__photo img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .point-item__photo img {
    width: 80%;
    max-width: 398px;
  }
}
.point-item__lead {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-top: -.6em;
}
@media screen and (max-width: 768px) {
  .point-item__lead {
    gap: 5px;
  }
}
.point-item__lead1, .point-item__lead2 {
  font-family: "Zen Old Mincho", serif;
  font-size: 1.875rem;
  font-weight: 500;
  line-height: 1;
  border: 1px solid #E8407A;
  padding: 7px 15px;
}
@media screen and (max-width: 768px) {
  .point-item__lead1, .point-item__lead2 {
    font-size: 1.25rem;
  }
}
.point-item__lead1 {
  color: #E8407A;
  background-color: #fff;
}
.point-item__lead2 {
  color: #fff;
  background-color: #E8407A;
}
.point-item__txt {
  font-weight: 500;
  padding-top: 15px;
}

/*-----------------------------------------------------------------
プログラム
-----------------------------------------------------------------*/
.program {
  position: relative;
  background-color: #F675C5;
  background-image: url("/application/themes/admissions_new/event_v4/img/program_bg.png");
  background-repeat: repeat;
  background-position: 0 0;
  padding: 100px 0;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .program {
    padding: 40px 0;
  }
}
.program::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/program_bg_obj.png");
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: 100% auto;
}
@media screen and (max-width: 768px) {
  .program::before {
    background-image: url("/application/themes/admissions_new/event_v4/img/program_bg_obj_sp.png");
  }
}
.program__inner {
  position: relative;
  width: 92%;
  max-width: 1600px;
  margin: 0 auto;
}

/* 特別プログラム */
.program-special {
  position: relative;
}
.program-special__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-image: url("/application/themes/admissions_new/event_v4/img/program_special_head_bg.png");
  background-repeat: no-repeat;
  background-position: 18% 0;
  padding-top: 70px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .program-special__head {
    background-image: none;
    padding-top: 0;
  }
}
.program-special__head-en {
  text-align: center;
}
.program-special__head-title img {
  height: 70px;
}
@media screen and (max-width: 768px) {
  .program-special__head-title img {
    height: 30px;
  }
}
.program-special__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .program-special__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.program-special__img01 {
  position: absolute;
  top: 0;
  right: 0;
  width: 21.5%;
  max-width: 347px;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .program-special__img01 {
    right: -8%;
    width: 30%;
  }
}
.program-special__body {
  margin-top: 70px;
}
@media screen and (max-width: 768px) {
  .program-special__body {
    gap: 15px 0;
    margin-top: 25px;
  }
}
.program-special__body .swiper {
  padding: 0 30px;
}
@media screen and (max-width: 768px) {
  .program-special__body .swiper {
    padding: 0;
  }
}
.program-special__body .swiper-wrapper {
  transition-timing-function: linear;
  margin-left: 15px;
}
@media screen and (max-width: 768px) {
  .program-special__body .swiper-wrapper {
    margin-left: 0;
  }
}
.program-special__body .swiper-slide {
  max-width: 480px !important;
  height: auto;
  margin-right: 30px;
}
@media screen and (max-width: 768px) {
  .program-special__body .swiper-slide {
    margin: 0 20px;
  }
}
@media screen and (min-width: 769px) {
  .program-special__body .swiper.-fixed {
    touch-action: none;
    pointer-events: none;
    padding: 0;
  }
}
@media screen and (min-width: 769px) {
  .program-special__body .swiper.-fixed .swiper-wrapper {
    justify-content: center;
    transform: none !important;
    gap: 0 30px;
    margin-left: 0;
  }
}
@media screen and (min-width: 769px) {
  .program-special__body .swiper.-fixed .swiper-slide {
    flex: 1;
    max-width: 513.33px !important;
    margin-right: 0;
  }
}
@media screen and (min-width: 769px) {
  .program-special__body .swiper.-fixed .swiper-foot {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .program-special__body .swiper-foot {
    display: flex;
    align-items: center;
    gap: 0 15px;
    margin-top: 15px;
  }
}
@media screen and (max-width: 768px) {
  .program-special__body .swiper-btn {
    display: flex;
    gap: 0 5px;
    width: 94px;
  }
}
@media screen and (min-width: 769px) {
  .program-special__body .swiper-btn {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .program-special__body .swiper-button-disabled {
    opacity: .5;
  }
}
@media screen and (max-width: 768px) {
  .program-special__body .swiper-scrollbar-wrap {
    flex: 1;
  }
}
@media screen and (min-width: 769px) {
  .program-special__body .swiper-scrollbar-wrap {
    width: 92%;
    max-width: 1000px;
    margin: 60px auto 0;
  }
}
@media screen and (max-width: 768px) {
  .program-special__body .swiper-scrollbar {
    flex: 1;
    position: relative !important;
    left: auto !important;
    bottom: auto !important;
    height: 5px !important;
    background: rgba(0, 0, 0, 0.1);
  }
}
@media screen and (min-width: 769px) {
  .program-special__body .swiper-scrollbar {
    position: relative;
    left: auto;
    bottom: auto;
    height: 6px;
    background-color: #fff;
  }
}
@media screen and (max-width: 768px) {
  .program-special__body .swiper-scrollbar-drag {
    background: #292867 !important;
  }
}
@media screen and (min-width: 769px) {
  .program-special__body .swiper-scrollbar-drag {
    background-color: #000E62;
  }
}
.program-special__item {
  height: 100%;
  background-color: #FFF4D5;
}
.program-special__photo {
  text-align: center;
}
.program-special__photo img {
  width: 100%;
}
.program-special__cont {
  position: relative;
  padding: 40px 30px 30px;
}
@media screen and (max-width: 768px) {
  .program-special__cont {
    padding: 30px 25px 25px;
  }
}
.program-special__cont::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 10px;
  background: #4EA0F8;
  background: linear-gradient(90deg, #4ea0f8 0%, #f4ff00 33%, #fdaa40 66%, #a71f26 100%);
}
@media screen and (max-width: 768px) {
  .program-special__cont::before {
    height: 7px;
  }
}
.program-special__no {
  display: block;
  text-align: center;
}
.program-special__no i {
  display: block;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 0.875rem;
  font-weight: 700;
  color: #000E62;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .program-special__no i {
    font-size: 0.75rem;
  }
}
.program-special__no span {
  display: block;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 3.75rem;
  font-weight: 800;
  color: #000E62;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .program-special__no span {
    font-size: 2.8125rem;
  }
}
.program-special__tag {
  text-align: center;
  margin-top: 15px;
}
.program-special__tag i {
  display: inline-block;
  font-size: clamp(14px, 1.2vw, 17px);
  color: #fff;
  line-height: 1.2;
  background-color: #F675C5;
  padding: 7px 20px;
}
@media screen and (max-width: 768px) {
  .program-special__tag i {
    font-size: 0.875rem;
    padding: 7px 15px;
  }
}
.program-special__tag i span {
  font-size: 82.35%;
}
.program-special__title {
  position: relative;
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 600;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  padding: 15px 0 0;
}
@media screen and (max-width: 768px) {
  .program-special__title {
    padding: 10px 0 0;
  }
}
.program-special__txt {
  color: #000E62;
  padding-top: 20px;
}
@media screen and (max-width: 768px) {
  .program-special__txt {
    padding-top: 15px;
  }
}

/* 通常プログラム */
.program-normal {
  position: relative;
  padding-top: 150px;
}
@media screen and (max-width: 768px) {
  .program-normal {
    padding-top: 40px;
  }
}
.program-normal__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-image: url("/application/themes/admissions_new/event_v4/img/program_normal_head_bg.png");
  background-repeat: no-repeat;
  background-position: 18% 0;
  padding-top: 70px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .program-normal__head {
    background-image: none;
    padding-top: 0;
  }
}
.program-normal__head-en {
  text-align: center;
}
.program-normal__head-title img {
  height: 70px;
}
@media screen and (max-width: 768px) {
  .program-normal__head-title img {
    height: 30px;
  }
}
.program-normal__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .program-normal__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.program-normal__img01 {
  position: absolute;
  left: 0;
  max-width: 172px;
  transform: translateY(-80px);
}
@media screen and (max-width: 768px) {
  .program-normal__img01 {
    width: 70px;
    max-width: none;
    transform: translateY(8px);
  }
}
.program-normal__img02 {
  position: absolute;
  top: 150px;
  left: 95%;
  width: 30%;
  max-width: 480px;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  .program-normal__img02 {
    display: none;
  }
}
.program-normal__lead {
  font-size: 1.25rem;
  color: #fff;
  text-align: center;
  padding-top: 40px;
}
@media screen and (max-width: 768px) {
  .program-normal__lead {
    font-size: 0.8125rem;
    text-align: left;
    padding: 20px 0 0 80px;
  }
}
.program-normal__body {
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .program-normal__body {
    margin-top: 20px;
  }
}
@media screen and (min-width: 769px) {
  .program-normal__body .swiper-wrapper {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 30px;
  }
}
@media screen and (min-width: 769px) {
  .program-normal__body.-minioc .swiper-wrapper {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media screen and (min-width: 769px) {
  .program-normal__body.-minioc .program-normal__photo img {
    width: auto !important;
  }
}
.program-normal__body .swiper-slide {
  height: auto;
}
.program-normal__body .swiper-foot {
  display: flex;
  align-items: center;
  gap: 0 15px;
  margin-top: 15px;
}
@media screen and (min-width: 769px) {
  .program-normal__body .swiper-foot {
    display: none;
  }
}
.program-normal__body .swiper-btn {
  display: flex;
  gap: 0 5px;
  width: 94px;
}
.program-normal__body .swiper-button-disabled {
  opacity: .5;
}
.program-normal__body .swiper-scrollbar-wrap {
  flex: 1;
}
.program-normal__body .swiper-scrollbar {
  flex: 1;
  position: relative !important;
  left: auto !important;
  bottom: auto !important;
  height: 5px !important;
  background: rgba(0, 0, 0, 0.1);
}
.program-normal__body .swiper-scrollbar .swiper-scrollbar-drag {
  background: #292867 !important;
}
.program-normal__item {
  height: 100%;
  background-color: #fff;
}
.program-normal__photo {
  text-align: center;
}
.program-normal__photo img {
  width: 100%;
}
.program-normal__cont {
  position: relative;
  padding: 40px 30px 30px;
}
@media screen and (max-width: 768px) {
  .program-normal__cont {
    padding: 30px 25px 25px;
  }
}
.program-normal__cont::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 10px;
  background-color: #000E62;
}
@media screen and (max-width: 768px) {
  .program-normal__cont::before {
    height: 7px;
  }
}
.program-normal__no {
  display: block;
  text-align: center;
}
.program-normal__no i {
  display: block;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 0.875rem;
  font-weight: 700;
  color: #000E62;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .program-normal__no i {
    font-size: 0.75rem;
  }
}
.program-normal__no span {
  display: block;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 3.75rem;
  font-weight: 800;
  color: #000E62;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .program-normal__no span {
    font-size: 2.8125rem;
  }
}
.program-normal__tag {
  text-align: center;
  margin-top: 15px;
}
.program-normal__tag i {
  display: inline-block;
  font-size: clamp(14px, 1.2vw, 17px);
  color: #fff;
  line-height: 1.2;
  background-color: #00B2BE;
  padding: 7px 20px;
}
@media screen and (max-width: 768px) {
  .program-normal__tag i {
    font-size: 0.875rem;
    padding: 7px 15px;
  }
}
.program-normal__tag i span {
  font-size: 82.35%;
}
.program-normal__title {
  position: relative;
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 600;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  padding: 15px 0 0;
}
@media screen and (max-width: 768px) {
  .program-normal__title {
    padding: 10px 0 0;
  }
}
.program-normal__txt {
  color: #000E62;
  padding-top: 20px;
}
@media screen and (max-width: 768px) {
  .program-normal__txt {
    padding-top: 15px;
  }
}

/*-----------------------------------------------------------------
タイムスケジュール
-----------------------------------------------------------------*/
.timesch {
  position: relative;
  background-color: #7856C5;
  padding: 100px 0;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .timesch {
    padding: 40px 0;
  }
}
.timesch__frame {
  width: 92%;
  max-width: 1800px;
  background-image: url("/application/themes/admissions_new/event_v4/img/timesch_frame_bg.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100% 100%;
  margin: 0 auto;
  padding: 80px 4%;
}
@media screen and (max-width: 768px) {
  .timesch__frame {
    background-image: url("/application/themes/admissions_new/event_v4/img/timesch_frame_bg_sp.png");
    padding: 30px 5%;
  }
}
.timesch__inner {
  max-width: 1350px;
  margin: 0 auto;
}
.timesch__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-image: url("/application/themes/admissions_new/event_v4/img/timesch_head_bg.png");
  background-repeat: no-repeat;
  background-position: 50% 100%;
  padding-top: 20px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .timesch__head {
    background-image: url("/application/themes/admissions_new/event_v4/img/timesch_head_bg_sp.png");
    background-position: 50% 0;
    padding-top: 40px;
  }
}
.timesch__head-en {
  text-align: center;
}
.timesch__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .timesch__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.timesch__table {
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .timesch__table {
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    margin-top: 25px;
  }
}
.timesch__table img, .timesch__table svg {
  width: 100%;
  max-width: 100%;
}
@media screen and (max-width: 768px) {
  .timesch__table img, .timesch__table svg {
    width: 768px;
    max-width: none;
  }
}

/*-----------------------------------------------------------------
オープンキャンパスの周り方
-----------------------------------------------------------------*/
.howto {
  position: relative;
  background-image: url("/application/themes/admissions_new/event_v4/img/howto_bg.png");
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
  padding: 120px 0 120px;
}
@media screen and (max-width: 768px) {
  .howto {
    background-position: 100% 100%;
    padding: 80px 0 100px;
  }
}
.howto::after {
  content: '';
  display: block;
  position: absolute;
  bottom: 40px;
  left: 0;
  right: 0;
  width: 96%;
  max-width: 1896px;
  aspect-ratio: 1896/106;
  background-image: url("/application/themes/admissions_new/event_v4/img/howto_txt_en.svg");
  background-repeat: no-repeat;
  background-size: contain;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .howto::after {
    bottom: 10px;
    max-width: 372px;
    aspect-ratio: 372/92;
    background-image: url("/application/themes/admissions_new/event_v4/img/howto_txt_en_sp.svg");
  }
}
.howto__frame {
  width: 92%;
  max-width: 1600px;
  background-color: #E5FD54;
  border-radius: 30px;
  margin: 0 auto;
}
.howto__inner {
  width: 92%;
  margin: 0 auto;
}
.howto__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  transform: translateY(-35px);
  z-index: 1;
}
.howto__head-en {
  text-align: center;
}
.howto__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .howto__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.howto__lead {
  width: 80%;
  max-width: 900px;
  font-size: 1.25rem;
  font-weight: 600;
  color: #000E62;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .howto__lead {
    width: 100%;
    font-size: 0.8125rem;
    text-align: center;
    margin-top: -15px;
  }
}
.howto__img01 {
  position: absolute;
  top: -50px;
  right: -3%;
  width: 40%;
  max-width: 558px;
}
@media screen and (max-width: 768px) {
  .howto__img01 {
    display: none;
  }
}
.howto__img02 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40%;
  max-width: 558px;
}
@media screen and (max-width: 768px) {
  .howto__img02 {
    display: none;
  }
}
.howto__step {
  text-align: center;
  padding: 50px 0;
}
@media screen and (max-width: 768px) {
  .howto__step {
    padding: 30px 0;
    margin-right: -20px;
  }
}

.howto-step {
  position: relative;
  max-width: 1667px;
  margin: 40px auto 0;
}
@media screen and (max-width: 768px) {
  .howto-step {
    max-width: 365px;
    margin: 30px auto 0;
  }
}
.howto-step::before, .howto-step::after {
  content: '';
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
}
.howto-step::before {
  bottom: 0;
  left: -12%;
  width: 79px;
  aspect-ratio: 79/715;
  background-image: url("/application/themes/admissions_new/event_v4/img/howto_txt_need.svg");
}
@media screen and (max-width: 768px) {
  .howto-step::before {
    bottom: 44.5%;
    left: -3.5%;
    width: 10%;
  }
}
.howto-step::after {
  bottom: 0;
  left: 0;
  width: 550px;
  aspect-ratio: 550/368;
  background-image: url("/application/themes/admissions_new/event_v4/img/howto_txt_tanosi.svg");
}
@media screen and (max-width: 768px) {
  .howto-step::after {
    bottom: 20.5%;
    left: 1.5%;
    width: 42%;
  }
}
.howto-step__list {
  position: relative;
  aspect-ratio: 1667/1424;
  background-image: url("/application/themes/admissions_new/event_v4/img/howto_step_arrow.png");
  background-repeat: no-repeat;
  background-position: left 74.5% top 35.1%;
  background-size: 66.52% auto;
  margin: 0 auto;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .howto-step__list {
    aspect-ratio: 365/1383;
    background-image: url("/application/themes/admissions_new/event_v4/img/howto_step_arrow_sp.png");
    background-position: left 45% top 53%;
    background-size: 49.44% auto;
  }
}
.howto-step.-c251214 .howto-step__list {
  background-image: url("/application/themes/admissions_new/event_v4/img/howto_step_arrow_251214.png");
}
@media screen and (max-width: 768px) {
  .howto-step.-c251214 .howto-step__list {
    background-image: url("/application/themes/admissions_new/event_v4/img/howto_step_arrow_251214_sp.png");
  }
}
.howto-step__list li {
  position: absolute;
}
.howto-step__list li img {
  width: 100%;
}
.howto-step__list li.-step01 {
  top: 5.1%;
  left: 0;
  width: 28.19%;
}
@media screen and (max-width: 768px) {
  .howto-step__list li.-step01 {
    top: 0;
    left: 6.2%;
    width: 77.8%;
  }
}
.howto-step__list li.-step02 {
  top: 6.2%;
  left: 31.9%;
  width: 33.11%;
}
@media screen and (max-width: 768px) {
  .howto-step__list li.-step02 {
    top: 4.7%;
    left: 31.9%;
    width: 67.67%;
  }
}
.howto-step__list li.-step03 {
  top: 0;
  right: 9.5%;
  width: 19.25%;
}
@media screen and (max-width: 768px) {
  .howto-step__list li.-step03 {
    top: 32%;
    right: 52%;
    width: 47.39%;
  }
}
.howto-step__list li.-step04 {
  top: 30%;
  right: 0;
  width: 22.49%;
}
@media screen and (max-width: 768px) {
  .howto-step__list li.-step04 {
    top: 41.5%;
    right: 4%;
    width: 52.87%;
  }
}
.howto-step__list li.-step05 {
  top: 39.6%;
  right: 24.5%;
  width: 23.63%;
}
@media screen and (max-width: 768px) {
  .howto-step__list li.-step05 {
    top: 51.25%;
    right: 41%;
    width: 58.63%;
  }
}
.howto-step__list li.-step06 {
  bottom: 29.9%;
  left: 8.8%;
  width: 37.67%;
}
@media screen and (max-width: 768px) {
  .howto-step__list li.-step06 {
    bottom: 17.5%;
    left: 9%;
    width: 86.57%;
  }
}
.howto-step__list li.-step07 {
  bottom: 0;
  right: 3.5%;
  width: 45.17%;
}
@media screen and (max-width: 768px) {
  .howto-step__list li.-step07 {
    bottom: 0;
    right: 4.5%;
    width: 94.52%;
  }
}

/*.howto-step {
	position: relative;
	width: 92%;
	max-width: 1392px;
	padding-top: 50px;
	margin: 0 auto;
	@include mq(sp) {
		max-width: 349px;
		padding-top: 30px;
	}
	&__list {
		position: relative;
		width: 100%;
		aspect-ratio: 1392/1690;
		margin: 0 auto;
		z-index: 1;
		@include mq(sp) {
			aspect-ratio: 349/1330;
		}
	}
	&__item {
		position: absolute;
		&.-step01 {
			top: .3%;
			left: 1%;
			width: 55.962643678%;
			@include mq(sp) {
				top: 0;
				left: 5.2%;
				width: 93.696275071%;
				z-index: 1;
			}
		}
		&.-step02 {
			top: 0;
			right: 5.2%;
			width: 36.278735632%;
			@include mq(sp) {
				top: 17.2%;
				right: inherit;
				left: 24.6%;
				width: 75.071633237%;
				z-index: 2;
			}
		}
		&.-step03 {
			top: 31.3%;
			right: 0;
			width: 30.100574712%;
			@include mq(sp) {
				top: 28.85%;
				right: inherit;
				left: 0;
				width: 51.862464183%;
				z-index: 3;
			}
		}
		&.-step04 {
			top: 35%;
			left: 35%;
			width: 31.25%;
			@include mq(sp) {
				top: 38.4%;
				left: 5.3%;
				width: 94.269340974%;
				z-index: 4;
			}
		}
		&.-step05 {
			top: 38.5%;
			left: 0;
			width: 33.477011494%;
			@include mq(sp) {
				top: 52.2%;
				left: 0;
				width: 93.123209169%;
				z-index: 5;
			}
		}
		&.-step06 {
			bottom: 0;
			left: 14.7%;
			width: 42.097701149%;
			@include mq(sp) {
				bottom: 14.5%;
				left: 28.3%;
				width: 71.346704871%;
				z-index: 6;
			}
		}
		&.-step07 {
			bottom: 9.28%;
			right: 3.4%;
			width: 34.554597701%;
			@include mq(sp) {
				bottom: 0%;
				right: inherit;
				left: 0;
				width: 72.779369627%;
				z-index: 7;
			}
		}
		&.-stepEnd {
			bottom: 1.3%;
			right: 4.8%;
			width: 36.709770114%;
			@include mq(sp) {
				bottom: -65px;
				right: 0;
				width: 36.389684813%;
			}
		}
		picture {
			display: block;
		}
	}
	&__arrow {
		position: absolute;
		top: 17.7%;
		left: 15.4%;
		width: 78.089080459%;
		@include mq(sp) {
			top: 14.7%;
			left: 11.5%;
			width: 63.896848137%
		}
	}
}*/
/*-----------------------------------------------------------------
参加者の声
-----------------------------------------------------------------*/
.voice {
  position: relative;
  background-color: #D4E83A;
  background-image: url("/application/themes/admissions_new/event_v4/img/voice_bg.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  padding: 100px 0;
  z-index: 2;
  /*&__item-no {
      display: block;
  }
  &__item-no img {
      @include mq(sp) {
          width: 45px;
      }
  }*/
}
@media screen and (max-width: 768px) {
  .voice {
    padding: 40px 0;
  }
}
.voice::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/voice_bg_obj.png");
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: 100% auto;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .voice::before {
    width: 100%;
    background-image: url("/application/themes/admissions_new/event_v4/img/voice_bg_obj_sp.png");
  }
}
.voice__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
.voice__head-en {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .voice__head-en {
    width: 60%;
    max-width: 417px;
  }
}
.voice__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .voice__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.voice__img01 {
  position: absolute;
  top: -75px;
  left: 50%;
  transform: translateX(-50%);
  width: 96%;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .voice__img01 {
    top: 20px;
    width: 110%;
    max-width: 373px;
  }
}
@media screen and (max-width: 768px) {
  .voice__img01 img {
    width: 100%;
  }
}
.voice__body {
  margin-top: clamp(50px, 4%, 90px);
}
@media screen and (max-width: 768px) {
  .voice__body {
    margin-top: 30px;
  }
}
.voice__body .swiper {
  padding: 0 30px;
}
.voice__body .swiper-wrapper {
  transition-timing-function: linear;
}
.voice__body .swiper-slide {
  max-width: 400px !important;
  height: auto;
}
@media screen and (max-width: 768px) {
  .voice__body .swiper-slide {
    width: inherit !important;
  }
}
.voice__body .swiper-scrollbar-wrap {
  width: 92%;
  max-width: 1000px;
  margin: 60px auto 0;
}
@media screen and (max-width: 768px) {
  .voice__body .swiper-scrollbar-wrap {
    margin-top: 30px;
  }
}
.voice__body .swiper-scrollbar {
  position: relative;
  left: auto;
  bottom: auto;
  height: 6px;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .voice__body .swiper-scrollbar {
    height: 5px;
  }
}
.voice__body .swiper-scrollbar-drag {
  background-color: #000E62;
}
.voice__item {
  position: relative;
  height: 100%;
  background-color: #fff;
  padding: 40px 35px 35px;
  margin-right: 30px;
}
@media screen and (max-width: 768px) {
  .voice__item {
    padding: 30px 25px 25px;
    margin-right: 20px;
  }
}
.voice__item::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 10px;
  background: #E5FD54;
  background: linear-gradient(90deg, #e5fd54 0%, #f4ff00 33%, #fdaa40 66%, #f675c5 100%);
}
.voice__item-head {
  display: flex;
  justify-content: space-between;
}
.voice__item-no {
  display: block;
  text-align: center;
}
.voice__item-no i {
  display: block;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 0.875rem;
  font-weight: 700;
  color: #000E62;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .voice__item-no i {
    font-size: 0.875rem;
  }
}
.voice__item-no span {
  display: block;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 3.75rem;
  font-weight: 800;
  color: #000E62;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .voice__item-no span {
    font-size: 3.4375rem;
  }
}
.voice__item-ic {
  display: grid;
  width: 125px;
  aspect-ratio: 1/1;
  background-color: #FBF34A;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .voice__item-ic {
    width: 100px;
  }
}
.voice__item-ic img {
  width: 95px;
  align-self: flex-end;
  justify-self: center;
}
@media screen and (max-width: 768px) {
  .voice__item-ic img {
    width: 70px;
  }
}
.voice__item-txt {
  font-size: 1.125rem;
  color: #000E62;
  line-height: 1.6;
  padding-top: 25px;
}
@media screen and (max-width: 768px) {
  .voice__item-txt {
    font-size: 0.875rem;
  }
}
.voice__item-label {
  text-align: center;
  margin-top: 20px;
}
.voice__item-label span {
  display: inline-block;
  font-size: 0.9375rem;
  font-weight: 500;
  color: #fff;
  text-align: center;
  line-height: 1;
  background-color: #FC5FB7;
  padding: 10px 30px;
}
@media screen and (max-width: 768px) {
  .voice__item-label span {
    font-size: 0.75rem;
    padding: 7px 25px;
  }
}
.voice__item-label.-man span {
  background-color: #00B2BE;
}
.voice__item-label.-woman span {
  background-color: #F675C5;
}
.voice__item-label.-guardian span {
  background-color: #41B3FF;
}

/*-----------------------------------------------------------------
動画で見るオープンキャンパス
-----------------------------------------------------------------*/
.movie {
  position: relative;
  background-color: #7856C5;
  background-image: url("/application/themes/admissions_new/event_v4/img/movie_bg.png");
  background-repeat: repeat;
  background-position: 0 0;
  padding: 100px 0;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .movie {
    padding: 40px 0;
  }
}
.movie::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/movie_bg_obj.png");
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: 100% auto;
}
@media screen and (max-width: 768px) {
  .movie::before {
    background-image: url("/application/themes/admissions_new/event_v4/img/movie_bg_obj_sp.png");
  }
}
.movie__inner {
  position: relative;
  width: 92%;
  max-width: 1400px;
  margin: 0 auto;
}
.movie__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
.movie__head-en {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .movie__head-en {
    width: 60%;
    max-width: 124px;
  }
}
.movie__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .movie__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.movie__img01 {
  position: absolute;
  top: -110px;
  left: 50%;
  transform: translateX(-53%);
  width: 100%;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .movie__img01 {
    top: -45px;
    width: 110%;
    max-width: 375px;
  }
}
.movie__img01 img {
  width: clamp(300px, 90%, 1100px);
}
@media screen and (max-width: 768px) {
  .movie__img01 img {
    width: 100%;
  }
}
.movie__body {
  position: relative;
  margin-top: clamp(20px, 4.5%, 80px);
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .movie__body {
    margin-top: 20px;
  }
}
.movie__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .movie__list {
    justify-content: flex-start;
  }
}
.movie__list > li a {
  display: block;
  transition: all .5s;
}
.movie__list > li a:hover {
  opacity: .7;
}
.movie__list.-col2 {
  gap: 30px;
}
@media screen and (max-width: 768px) {
  .movie__list.-col2 {
    gap: 15px;
  }
}
.movie__list.-col4 {
  gap: 30px 15px;
}
@media screen and (max-width: 768px) {
  .movie__list.-col4 {
    gap: 15px 10px;
  }
}
.movie__list.-col2 > li {
  width: calc(50% - 15px);
}
@media screen and (max-width: 768px) {
  .movie__list.-col2 > li {
    width: 100%;
  }
}
.movie__list.-col4 > li {
  width: calc(25% - 11.5px);
}
@media screen and (max-width: 768px) {
  .movie__list.-col4 > li {
    width: calc(50% - 5px);
  }
}
.movie__head + .movie__list {
  margin-top: 80px;
}
@media screen and (max-width: 768px) {
  .movie__head + .movie__list {
    margin-top: 30px;
  }
}
.movie__list > li iframe {
  width: 100%;
  aspect-ratio: 16/9;
  vertical-align: middle;
}
.movie__group {
  background-color: #fff;
  border: 2px solid #000E61;
  margin-top: 100px;
  padding: 0 5% 50px;
}
@media screen and (max-width: 768px) {
  .movie__group {
    margin-top: 40px;
    padding: 0 4% 20px;
  }
}
.movie__heading {
  text-align: center;
  margin-top: -35px;
}
@media screen and (max-width: 768px) {
  .movie__heading {
    margin-top: -20.5px;
  }
}
.movie__heading span {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 860px;
  font-size: 1.5625rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background-color: #000E61;
  background-image: url("/application/themes/admissions_new/event_v4/img/movie_heading_ic_star.svg"), url("/application/themes/admissions_new/event_v4/img/movie_heading_ic_star.svg");
  background-repeat: no-repeat, no-repeat;
  background-position: left 50px center, right 50px center;
  background-size: 27px auto, 36px auto;
  padding: 10px;
}
@media screen and (max-width: 768px) {
  .movie__heading span {
    font-size: 0.9375rem;
    background-position: left 20px center, right 20px center;
    background-size: 15px auto, 25px auto;
    padding: 7px 10px;
  }
}
.movie__group.-type2 {
  border-color: #AF1C40;
}
.movie__group.-type2 .movie__heading span {
  background-color: #AF1C40;
}
.movie__heading + .movie__list {
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .movie__heading + .movie__list {
    margin-top: 20px;
  }
}
.movie__thumb {
  position: relative;
}
.movie__thumb::after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 72px;
  aspect-ratio: 110/77;
  background-image: url("/application/themes/admissions_new/event_v4/img/movie_ic_play.svg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  .movie__thumb::after {
    width: 45px;
  }
}
.movie__thumb img {
  width: 100%;
  aspect-ratio: 16/9;
}
.movie__figure figcaption {
  font-size: 1.125rem;
  color: #000E62;
  text-align: center;
  line-height: 1.4;
  padding-top: 15px;
}
@media screen and (max-width: 768px) {
  .movie__figure figcaption {
    font-size: 0.875rem;
    padding-top: 10px;
  }
}

/*-----------------------------------------------------------------
帝塚山大学に行こう
-----------------------------------------------------------------*/
.access {
  position: relative;
  background-color: #47D1DE;
  background-image: url("/application/themes/admissions_new/event_v4/img/access_bg.png");
  background-repeat: repeat;
  background-position: 0 0;
  padding: 100px 0;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .access {
    padding: 40px 0;
  }
}
.access__frame {
  position: relative;
  width: 92%;
  max-width: 1800px;
  background-image: url("/application/themes/admissions_new/event_v4/img/access_frame_bg.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100% 100%;
  margin: 0 auto;
  padding: 80px 4%;
}
@media screen and (max-width: 768px) {
  .access__frame {
    background-image: url("/application/themes/admissions_new/event_v4/img/access_frame_bg_sp.png");
    padding: 30px 5%;
  }
}
.access__frame::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/access_frame_bg_obj.png");
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: 92% auto;
}
@media screen and (max-width: 768px) {
  .access__frame::before {
    display: none;
  }
}
.access__inner {
  position: relative;
  max-width: 1600px;
  margin: 0 auto;
}
.access__top {
  display: grid;
  grid-template-columns: 0.8fr 1fr;
  gap: 0 30px;
}
@media screen and (max-width: 768px) {
  .access__top {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 20px 0;
  }
}
.access__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-image: url("/application/themes/admissions_new/event_v4/img/access_head_bg.png");
  background-repeat: no-repeat;
  background-position: 65% 0;
  background-size: auto 100%;
  padding: 60px 0 0;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .access__head {
    background-image: url("/application/themes/admissions_new/event_v4/img/access_head_bg_sp.png");
    background-position: 50% 50%;
    background-size: contain;
    padding: 30px 0 0;
  }
}
.access__head-en {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .access__head-en {
    width: 60%;
    max-width: 160px;
  }
}
.access__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .access__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.access__img01 {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 15%;
  max-width: 220px;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .access__img01 {
    position: relative;
    width: 100%;
    max-width: inherit;
    text-align: center;
    margin-top: 15px;
  }
}
.access__img02 {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 20%;
  max-width: 300px;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .access__img02 {
    display: none;
  }
}
.access__subttl {
  text-align: center;
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .access__subttl {
    margin-top: 30px;
  }
}
.access__subttl span {
  display: inline-block;
  position: relative;
  font-size: clamp(30px, 2.5vw, 40px);
  font-weight: 700;
  color: #000E62;
  line-height: 1.2;
}
@media screen and (max-width: 768px) {
  .access__subttl span {
    font-size: 20px;
  }
}
.access__subttl span::before, .access__subttl span::after {
  content: '';
  display: block;
  position: absolute;
  bottom: 10px;
  width: 50px;
  aspect-ratio: 50/70;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  .access__subttl span::before, .access__subttl span::after {
    bottom: 3px;
    width: 30px;
  }
}
.access__subttl span::before {
  left: -40px;
  background-image: url("/application/themes/admissions_new/event_v4/img/access_subttl_line_l.svg");
}
@media screen and (max-width: 768px) {
  .access__subttl span::before {
    left: -30px;
  }
}
.access__subttl span::after {
  right: -40px;
  background-image: url("/application/themes/admissions_new/event_v4/img/access_subttl_line_r.svg");
}
@media screen and (max-width: 768px) {
  .access__subttl span::after {
    right: -30px;
  }
}
.access__lead {
  font-size: 1.25rem;
  font-weight: 700;
  color: #000E62;
  text-align: center;
  line-height: 1.8;
  padding-top: 30px;
}
@media screen and (max-width: 768px) {
  .access__lead {
    font-size: 0.875rem;
    padding-top: 10px;
  }
}
.access__station {
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .access__station {
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    margin-top: 0;
  }
}
.access__station img {
  width: 100%;
  max-width: 100%;
}
@media screen and (max-width: 768px) {
  .access__station img {
    width: 600px;
    max-width: none;
  }
}

.access-this {
  width: 60%;
  max-width: 950px;
  margin: 0 auto;
  padding-top: 50px;
  transform: translateX(-3%);
}
@media screen and (max-width: 768px) {
  .access-this {
    width: 100%;
    padding-top: 30px;
    transform: translateX(0);
  }
}
.access-this__hn {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.access-this__hn span {
  position: relative;
  font-size: 1.75rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  padding: 0 10px;
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .access-this__hn span {
    font-size: 1rem;
    margin-top: 15px;
  }
}
.access-this__hn span::before, .access-this__hn span::after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  width: 100px;
  height: 1px;
  background-color: #000E62;
}
@media screen and (max-width: 768px) {
  .access-this__hn span::before, .access-this__hn span::after {
    width: 35px;
  }
}
.access-this__hn span::before {
  right: 100%;
}
.access-this__hn span::after {
  left: 100%;
}
.access-this__info {
  padding-top: 20px;
}
@media screen and (max-width: 768px) {
  .access-this__info {
    padding-top: 15px;
  }
}
.access-this__campus {
  display: flex;
  align-items: flex-start;
  gap: 0 30px;
  color: #fff;
  background-repeat: no-repeat, no-repeat;
  background-position: right 10px center;
  background-size: auto 90%;
  padding: 20px;
}
@media screen and (max-width: 768px) {
  .access-this__campus {
    flex-direction: column;
    gap: 20px 0;
    background-size: 30px auto;
    background-position: right 10px top 80%;
  }
}
.access-this__campus.is-hidden {
  display: none;
}
.access-this__campus.-gakuenmae {
  background-color: #FC5FB7;
  background-image: url("/application/themes/admissions_new/event_v4/img/access_bgtxt_gakuenmae.svg");
}
.access-this__campus.-higashiikoma {
  background-color: #000E62;
  background-image: url("/application/themes/admissions_new/event_v4/img/access_bgtxt_higashiikoma.svg");
}
.access-this__campus-map {
  display: flex;
  align-items: center;
  width: 35%;
  background-color: #fff;
  border-radius: 16px;
}
@media screen and (max-width: 768px) {
  .access-this__campus-map {
    width: 100%;
  }
}
.access-this__campus-map img {
  width: 100%;
}
.access-this__campus-dl {
  flex: 1;
  padding: 0 30px 0 0;
}
@media screen and (max-width: 768px) {
  .access-this__campus-dl {
    width: 100%;
    padding: 0;
  }
}
.access-this__campus-dl dt {
  text-align: center;
  border-bottom: 2px dotted #fff;
  padding-bottom: 10px;
  margin-bottom: 10px;
}
.access-this__campus-dl dd {
  text-align: center;
}
.access-this__campus-title {
  font-size: 2.1875rem;
  font-weight: 700;
  line-height: 1.2;
}
@media screen and (max-width: 768px) {
  .access-this__campus-title {
    font-size: 1.125rem;
  }
}
.access-this__campus-address {
  line-height: 1.6;
  padding-top: 10px;
}
.access-this__campus-txt {
  font-size: clamp(17px, 1.5vw, 22px);
  line-height: 1.6;
  padding: 10px 0 15px;
}
@media screen and (max-width: 768px) {
  .access-this__campus-txt {
    font-size: 0.875rem;
  }
}
.access-this__campus-note {
  font-size: 0.875rem;
  color: #FFF600;
  text-align: left;
  text-indent: -1em;
  line-height: 1.5;
  padding: 0 0 0 1em;
}
@media screen and (max-width: 768px) {
  .access-this__campus-note {
    font-size: 0.75rem;
  }
}
.access-this__campus-btn {
  text-align: center;
  margin-top: 20px;
}
.access-this__campus-btn a {
  display: inline-block;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-weight: 700;
  background-color: #fff;
  background-repeat: no-repeat;
  background-position: right 15px center;
  background-size: 18px auto;
  padding: 5px 70px 5px 20px;
  transition: all .5s;
}
.access-this__campus-btn a:hover {
  opacity: .7;
}
.access-this__campus.-gakuenmae .access-this__campus-btn a {
  color: #FC5FB7;
  background-image: url("/application/themes/admissions_new/event_v4/img/ic_circle_pink_arrow_right.svg");
}
.access-this__campus.-higashiikoma .access-this__campus-btn a {
  color: #000E62;
  background-image: url("/application/themes/admissions_new/event_v4/img/ic_circle_blue_arrow_white_right.svg");
}

/*-----------------------------------------------------------------
よくある質問
-----------------------------------------------------------------*/
.faq {
  position: relative;
  background-color: #D8D8D8;
  background-image: url("/application/themes/admissions_new/event_v4/img/faq_bg.png");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  padding: 100px 0;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .faq {
    padding: 40px 0;
  }
}
.faq::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("/application/themes/admissions_new/event_v4/img/faq_bg_obj.png");
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: 100% auto;
}
@media screen and (max-width: 768px) {
  .faq::before {
    background-image: url("/application/themes/admissions_new/event_v4/img/faq_bg_obj_sp.png");
    background-size: 100% auto;
  }
}
.faq__inner {
  position: relative;
  display: flex;
  gap: 0 40px;
  width: 92%;
  max-width: 1600px;
  margin: 0 auto;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .faq__inner {
    flex-direction: column;
  }
}
.faq__left {
  width: 359px;
}
@media screen and (max-width: 768px) {
  .faq__left {
    width: 100%;
  }
}
.faq__right {
  flex: 1;
}
.faq__head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
.faq__head-en {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .faq__head-en {
    width: 60%;
    max-width: 80px;
  }
}
.faq__head-jp {
  position: relative;
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
  color: #000E62;
  line-height: 1.4;
  background-color: #fff;
  border-radius: 2em;
  padding: 10px 35px;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .faq__head-jp {
    font-size: 0.875rem;
    padding: 5px 20px;
    margin-top: 15px;
  }
}
.faq__img01 {
  text-align: center;
  margin-top: 70px;
}
@media screen and (max-width: 768px) {
  .faq__img01 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    text-align: center;
    margin-top: 0;
  }
}
@media screen and (max-width: 768px) {
  .faq__img01 img {
    width: 90%;
    max-width: 380px;
    transform: translateX(-5%);
  }
}

.faq-list {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 20px 0;
  max-width: 1100px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .faq-list {
    gap: 10px 0;
    padding-top: 30px;
  }
}
.faq-list__item {
  background-color: #fff;
  overflow: hidden;
}
.faq-list__item dt, .faq-list__item dd {
  padding: 25px 30px;
}
.faq-list__item dt p, .faq-list__item dd p {
  position: relative;
  padding-left: 65px;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .faq-list__item dt p, .faq-list__item dd p {
    padding-left: 40px;
  }
}
.faq-list__item dt p::before, .faq-list__item dd p::before {
  position: absolute;
  top: -5px;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 45px;
  height: 45px;
  font-family: "Figtree", sans-serif;
  font-style: italic;
  font-size: 2.125rem;
  font-weight: 700;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .faq-list__item dt p::before, .faq-list__item dd p::before {
    width: 30px;
    height: 30px;
    font-size: 1.125rem;
  }
}
.faq-list__item dt {
  position: relative;
  background-color: #E6E52C;
  cursor: pointer;
  transition: all .5s;
}
@media screen and (max-width: 768px) {
  .faq-list__item dt {
    padding: 15px 25px 15px 15px;
  }
}
.faq-list__item dt p {
  font-size: 1.375rem;
  font-weight: 700;
  color: #000E62;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .faq-list__item dt p {
    font-size: 0.875rem;
  }
}
.faq-list__item dt:hover {
  opacity: .7;
}
.faq-list__item dt::after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  background-image: url("/application/themes/admissions_new/event_v4/img/faq_ic_close.svg");
  background-repeat: no-repeat;
  background-size: 28px 28px;
}
@media screen and (max-width: 768px) {
  .faq-list__item dt::after {
    right: 15px;
    width: 15px;
    height: 15px;
    background-size: 15px 15px;
  }
}
.faq-list__item dt.is-open::after {
  background-image: url("/application/themes/admissions_new/event_v4/img/faq_ic_open.svg");
}
.faq-list__item dt p::before {
  content: 'Q';
  color: #fff;
  background-color: #000E62;
}
@media screen and (max-width: 768px) {
  .faq-list__item dt p::before {
    top: -3px;
  }
}
.faq-list__item dd {
  display: none;
  color: #000E62;
  background-color: #fff;
  border: 2px solid #E6E52C;
}
@media screen and (max-width: 768px) {
  .faq-list__item dd {
    padding: 15px;
  }
}
.faq-list__item dd p {
  color: #000E62;
}
.faq-list__item dd p::before {
  content: 'A';
  color: #fff;
  background-color: #AF1C40;
}
@media screen and (max-width: 768px) {
  .faq-list__item dd p::before {
    top: 0;
  }
}

/*-----------------------------------------------------------------
入試対策講座
-----------------------------------------------------------------*/
.taisaku {
  position: relative;
}

.taisaku-inner {
  position: relative;
  width: 92%;
  max-width: 1500px;
  margin: 0 auto;
  padding: 100px 0 30px;
}
@media screen and (max-width: 768px) {
  .taisaku-inner {
    padding: 50px 0;
  }
}

.taisaku-hnjp {
  text-align: center;
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .taisaku-hnjp {
    margin-bottom: 30px;
  }
}

.taisaku-hnjp span {
  font-family: "Noto Serif JP", serif;
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1.6;
  background: linear-gradient(transparent 60%, #fff000 60%);
}
@media screen and (max-width: 768px) {
  .taisaku-hnjp span {
    font-size: 1.375rem;
  }
}

.taisaku-image {
  text-align: center;
}

.taisaku-timetable {
  font-family: "Noto Serif JP", serif;
}

@media screen and (min-width: 769px) {
  .taisaku-timetable {
    max-width: 1200px;
    width: 92%;
    margin: 80px auto 20px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }

  .taisaku-timetable li {
    width: 31%;
    margin-right: 2%;
  }

  .taisaku-timetable li:nth-child(3n) {
    margin-right: 0;
  }
}
@media screen and (max-width: 768px) {
  .taisaku-timetable {
    margin: 50px auto 20px;
  }

  .taisaku-timetable li {
    margin-bottom: 20px;
  }
}
.taisaku-period {
  background-color: #2969b5;
  color: #fff;
  padding: 5px 10px;
  line-height: 1.0;
  font-size: 1.625rem;
}

.taisaku-period-num {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .taisaku-period-num {
    font-size: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .taisaku-period-num {
    font-size: 2.375rem;
  }
}

.taisaku-period-time {
  font-family: "Noto Sans JP", sans-serif;
  display: block;
  text-align: right;
}
@media screen and (min-width: 769px) {
  .taisaku-period-time {
    font-size: 1.375rem;
  }
}
@media screen and (max-width: 768px) {
  .taisaku-period-time {
    font-size: 0.875rem;
  }
}

.taisaku-period-title {
  font-weight: bold;
  text-align: center;
  background-color: #fff;
}
@media screen and (min-width: 769px) {
  .taisaku-period-title {
    font-size: 2.25rem;
  }
}
@media screen and (max-width: 768px) {
  .taisaku-period-title {
    font-size: 1.75rem;
  }
}

.taisaku-text {
  margin: 20px auto;
}
@media screen and (min-width: 769px) {
  .taisaku-text {
    max-width: 1200px;
    width: 92%;
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 768px) {
  .taisaku-text {
    font-size: 1rem;
  }
}

/* LAYOUT
---------------------------------------*/
/*--- ディスプレイ ---*/
.none {
  display: none;
}
@media screen and (max-width: 768px) {
  .none-sp {
    display: none;
  }
}
@media screen and (min-width: 769px) {
  .none-pc {
    display: none;
  }
}

/* SPACING
---------------------------------------*/
/*--- padding ---*/
.pt-0 {
  padding-top: 0px !important;
}
.pt-5 {
  padding-top: 5px !important;
}
.pt-10 {
  padding-top: 10px !important;
}
.pt-15 {
  padding-top: 15px !important;
}
.pt-20 {
  padding-top: 20px !important;
}
.pt-25 {
  padding-top: 25px !important;
}
.pt-30 {
  padding-top: 30px !important;
}
.pt-35 {
  padding-top: 35px !important;
}
.pt-40 {
  padding-top: 40px !important;
}
.pt-45 {
  padding-top: 45px !important;
}
.pt-50 {
  padding-top: 50px !important;
}
.pt-55 {
  padding-top: 55px !important;
}
.pt-60 {
  padding-top: 60px !important;
}
.pt-65 {
  padding-top: 65px !important;
}
.pt-70 {
  padding-top: 70px !important;
}
.pt-75 {
  padding-top: 75px !important;
}
.pt-80 {
  padding-top: 80px !important;
}
.pt-85 {
  padding-top: 85px !important;
}
.pt-90 {
  padding-top: 90px !important;
}
.pt-95 {
  padding-top: 95px !important;
}
.pt-100 {
  padding-top: 100px !important;
}
@media screen and (max-width: 768px) {
  .pt-0-sp {
    padding-top: 0px !important;
  }
  .pt-5-sp {
    padding-top: 5px !important;
  }
  .pt-10-sp {
    padding-top: 10px !important;
  }
  .pt-15-sp {
    padding-top: 15px !important;
  }
  .pt-20-sp {
    padding-top: 20px !important;
  }
  .pt-25-sp {
    padding-top: 25px !important;
  }
  .pt-30-sp {
    padding-top: 30px !important;
  }
  .pt-35-sp {
    padding-top: 35px !important;
  }
  .pt-40-sp {
    padding-top: 40px !important;
  }
  .pt-45-sp {
    padding-top: 45px !important;
  }
  .pt-50-sp {
    padding-top: 50px !important;
  }
  .pt-55-sp {
    padding-top: 55px !important;
  }
  .pt-60-sp {
    padding-top: 60px !important;
  }
  .pt-65-sp {
    padding-top: 65px !important;
  }
  .pt-70-sp {
    padding-top: 70px !important;
  }
  .pt-75-sp {
    padding-top: 75px !important;
  }
  .pt-80-sp {
    padding-top: 80px !important;
  }
  .pt-85-sp {
    padding-top: 85px !important;
  }
  .pt-90-sp {
    padding-top: 90px !important;
  }
  .pt-95-sp {
    padding-top: 95px !important;
  }
  .pt-100-sp {
    padding-top: 100px !important;
  }
}
@media screen and (min-width: 769px) {
  .pt-0-pc {
    padding-top: 0px !important;
  }
  .pt-5-pc {
    padding-top: 5px !important;
  }
  .pt-10-pc {
    padding-top: 10px !important;
  }
  .pt-15-pc {
    padding-top: 15px !important;
  }
  .pt-20-pc {
    padding-top: 20px !important;
  }
  .pt-25-pc {
    padding-top: 25px !important;
  }
  .pt-30-pc {
    padding-top: 30px !important;
  }
  .pt-35-pc {
    padding-top: 35px !important;
  }
  .pt-40-pc {
    padding-top: 40px !important;
  }
  .pt-45-pc {
    padding-top: 45px !important;
  }
  .pt-50-pc {
    padding-top: 50px !important;
  }
  .pt-55-pc {
    padding-top: 55px !important;
  }
  .pt-60-pc {
    padding-top: 60px !important;
  }
  .pt-65-pc {
    padding-top: 65px !important;
  }
  .pt-70-pc {
    padding-top: 70px !important;
  }
  .pt-75-pc {
    padding-top: 75px !important;
  }
  .pt-80-pc {
    padding-top: 80px !important;
  }
  .pt-85-pc {
    padding-top: 85px !important;
  }
  .pt-90-pc {
    padding-top: 90px !important;
  }
  .pt-95-pc {
    padding-top: 95px !important;
  }
  .pt-100-pc {
    padding-top: 100px !important;
  }
}

.pr-0 {
  padding-right: 0px !important;
}
.pr-5 {
  padding-right: 5px !important;
}
.pr-10 {
  padding-right: 10px !important;
}
.pr-15 {
  padding-right: 15px !important;
}
.pr-20 {
  padding-right: 20px !important;
}
.pr-25 {
  padding-right: 25px !important;
}
.pr-30 {
  padding-right: 30px !important;
}
.pr-35 {
  padding-right: 35px !important;
}
.pr-40 {
  padding-right: 40px !important;
}
.pr-45 {
  padding-right: 45px !important;
}
.pr-50 {
  padding-right: 50px !important;
}
.pr-55 {
  padding-right: 55px !important;
}
.pr-60 {
  padding-right: 60px !important;
}
.pr-65 {
  padding-right: 65px !important;
}
.pr-70 {
  padding-right: 70px !important;
}
.pr-75 {
  padding-right: 75px !important;
}
.pr-80 {
  padding-right: 80px !important;
}
.pr-85 {
  padding-right: 85px !important;
}
.pr-90 {
  padding-right: 90px !important;
}
.pr-95 {
  padding-right: 95px !important;
}
.pr-100 {
  padding-right: 100px !important;
}
@media screen and (max-width: 768px) {
  .pr-0-sp {
    padding-right: 0px !important;
  }
  .pr-5-sp {
    padding-right: 5px !important;
  }
  .pr-10-sp {
    padding-right: 10px !important;
  }
  .pr-15-sp {
    padding-right: 15px !important;
  }
  .pr-20-sp {
    padding-right: 20px !important;
  }
  .pr-25-sp {
    padding-right: 25px !important;
  }
  .pr-30-sp {
    padding-right: 30px !important;
  }
  .pr-35-sp {
    padding-right: 35px !important;
  }
  .pr-40-sp {
    padding-right: 40px !important;
  }
  .pr-45-sp {
    padding-right: 45px !important;
  }
  .pr-50-sp {
    padding-right: 50px !important;
  }
  .pr-55-sp {
    padding-right: 55px !important;
  }
  .pr-60-sp {
    padding-right: 60px !important;
  }
  .pr-65-sp {
    padding-right: 65px !important;
  }
  .pr-70-sp {
    padding-right: 70px !important;
  }
  .pr-75-sp {
    padding-right: 75px !important;
  }
  .pr-80-sp {
    padding-right: 80px !important;
  }
  .pr-85-sp {
    padding-right: 85px !important;
  }
  .pr-90-sp {
    padding-right: 90px !important;
  }
  .pr-95-sp {
    padding-right: 95px !important;
  }
  .pr-100-sp {
    padding-right: 100px !important;
  }
}
@media screen and (min-width: 769px) {
  .pr-0-pc {
    padding-right: 0px !important;
  }
  .pr-5-pc {
    padding-right: 5px !important;
  }
  .pr-10-pc {
    padding-right: 10px !important;
  }
  .pr-15-pc {
    padding-right: 15px !important;
  }
  .pr-20-pc {
    padding-right: 20px !important;
  }
  .pr-25-pc {
    padding-right: 25px !important;
  }
  .pr-30-pc {
    padding-right: 30px !important;
  }
  .pr-35-pc {
    padding-right: 35px !important;
  }
  .pr-40-pc {
    padding-right: 40px !important;
  }
  .pr-45-pc {
    padding-right: 45px !important;
  }
  .pr-50-pc {
    padding-right: 50px !important;
  }
  .pr-55-pc {
    padding-right: 55px !important;
  }
  .pr-60-pc {
    padding-right: 60px !important;
  }
  .pr-65-pc {
    padding-right: 65px !important;
  }
  .pr-70-pc {
    padding-right: 70px !important;
  }
  .pr-75-pc {
    padding-right: 75px !important;
  }
  .pr-80-pc {
    padding-right: 80px !important;
  }
  .pr-85-pc {
    padding-right: 85px !important;
  }
  .pr-90-pc {
    padding-right: 90px !important;
  }
  .pr-95-pc {
    padding-right: 95px !important;
  }
  .pr-100-pc {
    padding-right: 100px !important;
  }
}

.pb-0 {
  padding-bottom: 0px !important;
}
.pb-5 {
  padding-bottom: 5px !important;
}
.pb-10 {
  padding-bottom: 10px !important;
}
.pb-15 {
  padding-bottom: 15px !important;
}
.pb-20 {
  padding-bottom: 20px !important;
}
.pb-25 {
  padding-bottom: 25px !important;
}
.pb-30 {
  padding-bottom: 30px !important;
}
.pb-35 {
  padding-bottom: 35px !important;
}
.pb-40 {
  padding-bottom: 40px !important;
}
.pb-45 {
  padding-bottom: 45px !important;
}
.pb-50 {
  padding-bottom: 50px !important;
}
.pb-55 {
  padding-bottom: 55px !important;
}
.pb-60 {
  padding-bottom: 60px !important;
}
.pb-65 {
  padding-bottom: 65px !important;
}
.pb-70 {
  padding-bottom: 70px !important;
}
.pb-75 {
  padding-bottom: 75px !important;
}
.pb-80 {
  padding-bottom: 80px !important;
}
.pb-85 {
  padding-bottom: 85px !important;
}
.pb-90 {
  padding-bottom: 90px !important;
}
.pb-95 {
  padding-bottom: 95px !important;
}
.pb-100 {
  padding-bottom: 100px !important;
}
@media screen and (max-width: 768px) {
  .pb-0-sp {
    padding-bottom: 0px !important;
  }
  .pb-5-sp {
    padding-bottom: 5px !important;
  }
  .pb-10-sp {
    padding-bottom: 10px !important;
  }
  .pb-15-sp {
    padding-bottom: 15px !important;
  }
  .pb-20-sp {
    padding-bottom: 20px !important;
  }
  .pb-25-sp {
    padding-bottom: 25px !important;
  }
  .pb-30-sp {
    padding-bottom: 30px !important;
  }
  .pb-35-sp {
    padding-bottom: 35px !important;
  }
  .pb-40-sp {
    padding-bottom: 40px !important;
  }
  .pb-45-sp {
    padding-bottom: 45px !important;
  }
  .pb-50-sp {
    padding-bottom: 50px !important;
  }
  .pb-55-sp {
    padding-bottom: 55px !important;
  }
  .pb-60-sp {
    padding-bottom: 60px !important;
  }
  .pb-65-sp {
    padding-bottom: 65px !important;
  }
  .pb-70-sp {
    padding-bottom: 70px !important;
  }
  .pb-75-sp {
    padding-bottom: 75px !important;
  }
  .pb-80-sp {
    padding-bottom: 80px !important;
  }
  .pb-85-sp {
    padding-bottom: 85px !important;
  }
  .pb-90-sp {
    padding-bottom: 90px !important;
  }
  .pb-95-sp {
    padding-bottom: 95px !important;
  }
  .pb-100-sp {
    padding-bottom: 100px !important;
  }
}
@media screen and (min-width: 769px) {
  .pb-0-pc {
    padding-bottom: 0px !important;
  }
  .pb-5-pc {
    padding-bottom: 5px !important;
  }
  .pb-10-pc {
    padding-bottom: 10px !important;
  }
  .pb-15-pc {
    padding-bottom: 15px !important;
  }
  .pb-20-pc {
    padding-bottom: 20px !important;
  }
  .pb-25-pc {
    padding-bottom: 25px !important;
  }
  .pb-30-pc {
    padding-bottom: 30px !important;
  }
  .pb-35-pc {
    padding-bottom: 35px !important;
  }
  .pb-40-pc {
    padding-bottom: 40px !important;
  }
  .pb-45-pc {
    padding-bottom: 45px !important;
  }
  .pb-50-pc {
    padding-bottom: 50px !important;
  }
  .pb-55-pc {
    padding-bottom: 55px !important;
  }
  .pb-60-pc {
    padding-bottom: 60px !important;
  }
  .pb-65-pc {
    padding-bottom: 65px !important;
  }
  .pb-70-pc {
    padding-bottom: 70px !important;
  }
  .pb-75-pc {
    padding-bottom: 75px !important;
  }
  .pb-80-pc {
    padding-bottom: 80px !important;
  }
  .pb-85-pc {
    padding-bottom: 85px !important;
  }
  .pb-90-pc {
    padding-bottom: 90px !important;
  }
  .pb-95-pc {
    padding-bottom: 95px !important;
  }
  .pb-100-pc {
    padding-bottom: 100px !important;
  }
}

.pl-0 {
  padding-left: 0px !important;
}
.pl-5 {
  padding-left: 5px !important;
}
.pl-10 {
  padding-left: 10px !important;
}
.pl-15 {
  padding-left: 15px !important;
}
.pl-20 {
  padding-left: 20px !important;
}
.pl-25 {
  padding-left: 25px !important;
}
.pl-30 {
  padding-left: 30px !important;
}
.pl-35 {
  padding-left: 35px !important;
}
.pl-40 {
  padding-left: 40px !important;
}
.pl-45 {
  padding-left: 45px !important;
}
.pl-50 {
  padding-left: 50px !important;
}
.pl-55 {
  padding-left: 55px !important;
}
.pl-60 {
  padding-left: 60px !important;
}
.pl-65 {
  padding-left: 65px !important;
}
.pl-70 {
  padding-left: 70px !important;
}
.pl-75 {
  padding-left: 75px !important;
}
.pl-80 {
  padding-left: 80px !important;
}
.pl-85 {
  padding-left: 85px !important;
}
.pl-90 {
  padding-left: 90px !important;
}
.pl-95 {
  padding-left: 95px !important;
}
.pl-100 {
  padding-left: 100px !important;
}
@media screen and (max-width: 768px) {
  .pl-0-sp {
    padding-left: 0px !important;
  }
  .pl-5-sp {
    padding-left: 5px !important;
  }
  .pl-10-sp {
    padding-left: 10px !important;
  }
  .pl-15-sp {
    padding-left: 15px !important;
  }
  .pl-20-sp {
    padding-left: 20px !important;
  }
  .pl-25-sp {
    padding-left: 25px !important;
  }
  .pl-30-sp {
    padding-left: 30px !important;
  }
  .pl-35-sp {
    padding-left: 35px !important;
  }
  .pl-40-sp {
    padding-left: 40px !important;
  }
  .pl-45-sp {
    padding-left: 45px !important;
  }
  .pl-50-sp {
    padding-left: 50px !important;
  }
  .pl-55-sp {
    padding-left: 55px !important;
  }
  .pl-60-sp {
    padding-left: 60px !important;
  }
  .pl-65-sp {
    padding-left: 65px !important;
  }
  .pl-70-sp {
    padding-left: 70px !important;
  }
  .pl-75-sp {
    padding-left: 75px !important;
  }
  .pl-80-sp {
    padding-left: 80px !important;
  }
  .pl-85-sp {
    padding-left: 85px !important;
  }
  .pl-90-sp {
    padding-left: 90px !important;
  }
  .pl-95-sp {
    padding-left: 95px !important;
  }
  .pl-100-sp {
    padding-left: 100px !important;
  }
}
@media screen and (min-width: 769px) {
  .pl-0-pc {
    padding-left: 0px !important;
  }
  .pl-5-pc {
    padding-left: 5px !important;
  }
  .pl-10-pc {
    padding-left: 10px !important;
  }
  .pl-15-pc {
    padding-left: 15px !important;
  }
  .pl-20-pc {
    padding-left: 20px !important;
  }
  .pl-25-pc {
    padding-left: 25px !important;
  }
  .pl-30-pc {
    padding-left: 30px !important;
  }
  .pl-35-pc {
    padding-left: 35px !important;
  }
  .pl-40-pc {
    padding-left: 40px !important;
  }
  .pl-45-pc {
    padding-left: 45px !important;
  }
  .pl-50-pc {
    padding-left: 50px !important;
  }
  .pl-55-pc {
    padding-left: 55px !important;
  }
  .pl-60-pc {
    padding-left: 60px !important;
  }
  .pl-65-pc {
    padding-left: 65px !important;
  }
  .pl-70-pc {
    padding-left: 70px !important;
  }
  .pl-75-pc {
    padding-left: 75px !important;
  }
  .pl-80-pc {
    padding-left: 80px !important;
  }
  .pl-85-pc {
    padding-left: 85px !important;
  }
  .pl-90-pc {
    padding-left: 90px !important;
  }
  .pl-95-pc {
    padding-left: 95px !important;
  }
  .pl-100-pc {
    padding-left: 100px !important;
  }
}

/*--- マージン ---*/
.mt-0 {
  margin-top: 0px !important;
}
.mt-5 {
  margin-top: 5px !important;
}
.mt-10 {
  margin-top: 10px !important;
}
.mt-15 {
  margin-top: 15px !important;
}
.mt-20 {
  margin-top: 20px !important;
}
.mt-25 {
  margin-top: 25px !important;
}
.mt-30 {
  margin-top: 30px !important;
}
.mt-35 {
  margin-top: 35px !important;
}
.mt-40 {
  margin-top: 40px !important;
}
.mt-45 {
  margin-top: 45px !important;
}
.mt-50 {
  margin-top: 50px !important;
}
.mt-55 {
  margin-top: 55px !important;
}
.mt-60 {
  margin-top: 60px !important;
}
.mt-65 {
  margin-top: 65px !important;
}
.mt-70 {
  margin-top: 70px !important;
}
.mt-75 {
  margin-top: 75px !important;
}
.mt-80 {
  margin-top: 80px !important;
}
.mt-85 {
  margin-top: 85px !important;
}
.mt-90 {
  margin-top: 90px !important;
}
.mt-95 {
  margin-top: 95px !important;
}
.mt-100 {
  margin-top: 100px !important;
}
@media screen and (max-width: 768px) {
  .mt-0-sp {
    margin-top: 0px !important;
  }
  .mt-5-sp {
    margin-top: 5px !important;
  }
  .mt-10-sp {
    margin-top: 10px !important;
  }
  .mt-15-sp {
    margin-top: 15px !important;
  }
  .mt-20-sp {
    margin-top: 20px !important;
  }
  .mt-25-sp {
    margin-top: 25px !important;
  }
  .mt-30-sp {
    margin-top: 30px !important;
  }
  .mt-35-sp {
    margin-top: 35px !important;
  }
  .mt-40-sp {
    margin-top: 40px !important;
  }
  .mt-45-sp {
    margin-top: 45px !important;
  }
  .mt-50-sp {
    margin-top: 50px !important;
  }
  .mt-55-sp {
    margin-top: 55px !important;
  }
  .mt-60-sp {
    margin-top: 60px !important;
  }
  .mt-65-sp {
    margin-top: 65px !important;
  }
  .mt-70-sp {
    margin-top: 70px !important;
  }
  .mt-75-sp {
    margin-top: 75px !important;
  }
  .mt-80-sp {
    margin-top: 80px !important;
  }
  .mt-85-sp {
    margin-top: 85px !important;
  }
  .mt-90-sp {
    margin-top: 90px !important;
  }
  .mt-95-sp {
    margin-top: 95px !important;
  }
  .mt-100-sp {
    margin-top: 100px !important;
  }
}
@media screen and (min-width: 769px) {
  .mt-0-pc {
    margin-top: 0px !important;
  }
  .mt-5-pc {
    margin-top: 5px !important;
  }
  .mt-10-pc {
    margin-top: 10px !important;
  }
  .mt-15-pc {
    margin-top: 15px !important;
  }
  .mt-20-pc {
    margin-top: 20px !important;
  }
  .mt-25-pc {
    margin-top: 25px !important;
  }
  .mt-30-pc {
    margin-top: 30px !important;
  }
  .mt-35-pc {
    margin-top: 35px !important;
  }
  .mt-40-pc {
    margin-top: 40px !important;
  }
  .mt-45-pc {
    margin-top: 45px !important;
  }
  .mt-50-pc {
    margin-top: 50px !important;
  }
  .mt-55-pc {
    margin-top: 55px !important;
  }
  .mt-60-pc {
    margin-top: 60px !important;
  }
  .mt-65-pc {
    margin-top: 65px !important;
  }
  .mt-70-pc {
    margin-top: 70px !important;
  }
  .mt-75-pc {
    margin-top: 75px !important;
  }
  .mt-80-pc {
    margin-top: 80px !important;
  }
  .mt-85-pc {
    margin-top: 85px !important;
  }
  .mt-90-pc {
    margin-top: 90px !important;
  }
  .mt-95-pc {
    margin-top: 95px !important;
  }
  .mt-100-pc {
    margin-top: 100px !important;
  }
}

.mr-0 {
  margin-right: 0px !important;
}
.mr-5 {
  margin-right: 5px !important;
}
.mr-10 {
  margin-right: 10px !important;
}
.mr-15 {
  margin-right: 15px !important;
}
.mr-20 {
  margin-right: 20px !important;
}
.mr-25 {
  margin-right: 25px !important;
}
.mr-30 {
  margin-right: 30px !important;
}
.mr-35 {
  margin-right: 35px !important;
}
.mr-40 {
  margin-right: 40px !important;
}
.mr-45 {
  margin-right: 45px !important;
}
.mr-50 {
  margin-right: 50px !important;
}
.mr-55 {
  margin-right: 55px !important;
}
.mr-60 {
  margin-right: 60px !important;
}
.mr-65 {
  margin-right: 65px !important;
}
.mr-70 {
  margin-right: 70px !important;
}
.mr-75 {
  margin-right: 75px !important;
}
.mr-80 {
  margin-right: 80px !important;
}
.mr-85 {
  margin-right: 85px !important;
}
.mr-90 {
  margin-right: 90px !important;
}
.mr-95 {
  margin-right: 95px !important;
}
.mr-100 {
  margin-right: 100px !important;
}
@media screen and (max-width: 768px) {
  .mr-0-sp {
    margin-right: 0px !important;
  }
  .mr-5-sp {
    margin-right: 5px !important;
  }
  .mr-10-sp {
    margin-right: 10px !important;
  }
  .mr-15-sp {
    margin-right: 15px !important;
  }
  .mr-20-sp {
    margin-right: 20px !important;
  }
  .mr-25-sp {
    margin-right: 25px !important;
  }
  .mr-30-sp {
    margin-right: 30px !important;
  }
  .mr-35-sp {
    margin-right: 35px !important;
  }
  .mr-40-sp {
    margin-right: 40px !important;
  }
  .mr-45-sp {
    margin-right: 45px !important;
  }
  .mr-50-sp {
    margin-right: 50px !important;
  }
  .mr-55-sp {
    margin-right: 55px !important;
  }
  .mr-60-sp {
    margin-right: 60px !important;
  }
  .mr-65-sp {
    margin-right: 65px !important;
  }
  .mr-70-sp {
    margin-right: 70px !important;
  }
  .mr-75-sp {
    margin-right: 75px !important;
  }
  .mr-80-sp {
    margin-right: 80px !important;
  }
  .mr-85-sp {
    margin-right: 85px !important;
  }
  .mr-90-sp {
    margin-right: 90px !important;
  }
  .mr-95-sp {
    margin-right: 95px !important;
  }
  .mr-100-sp {
    margin-right: 100px !important;
  }
}
@media screen and (min-width: 769px) {
  .mr-0-pc {
    margin-right: 0px !important;
  }
  .mr-5-pc {
    margin-right: 5px !important;
  }
  .mr-10-pc {
    margin-right: 10px !important;
  }
  .mr-15-pc {
    margin-right: 15px !important;
  }
  .mr-20-pc {
    margin-right: 20px !important;
  }
  .mr-25-pc {
    margin-right: 25px !important;
  }
  .mr-30-pc {
    margin-right: 30px !important;
  }
  .mr-35-pc {
    margin-right: 35px !important;
  }
  .mr-40-pc {
    margin-right: 40px !important;
  }
  .mr-45-pc {
    margin-right: 45px !important;
  }
  .mr-50-pc {
    margin-right: 50px !important;
  }
  .mr-55-pc {
    margin-right: 55px !important;
  }
  .mr-60-pc {
    margin-right: 60px !important;
  }
  .mr-65-pc {
    margin-right: 65px !important;
  }
  .mr-70-pc {
    margin-right: 70px !important;
  }
  .mr-75-pc {
    margin-right: 75px !important;
  }
  .mr-80-pc {
    margin-right: 80px !important;
  }
  .mr-85-pc {
    margin-right: 85px !important;
  }
  .mr-90-pc {
    margin-right: 90px !important;
  }
  .mr-95-pc {
    margin-right: 95px !important;
  }
  .mr-100-pc {
    margin-right: 100px !important;
  }
}

.mb-0 {
  margin-bottom: 0px !important;
}
.mb-5 {
  margin-bottom: 5px !important;
}
.mb-10 {
  margin-bottom: 10px !important;
}
.mb-15 {
  margin-bottom: 15px !important;
}
.mb-20 {
  margin-bottom: 20px !important;
}
.mb-25 {
  margin-bottom: 25px !important;
}
.mb-30 {
  margin-bottom: 30px !important;
}
.mb-35 {
  margin-bottom: 35px !important;
}
.mb-40 {
  margin-bottom: 40px !important;
}
.mb-45 {
  margin-bottom: 45px !important;
}
.mb-50 {
  margin-bottom: 50px !important;
}
.mb-55 {
  margin-bottom: 55px !important;
}
.mb-60 {
  margin-bottom: 60px !important;
}
.mb-65 {
  margin-bottom: 65px !important;
}
.mb-70 {
  margin-bottom: 70px !important;
}
.mb-75 {
  margin-bottom: 75px !important;
}
.mb-80 {
  margin-bottom: 80px !important;
}
.mb-85 {
  margin-bottom: 85px !important;
}
.mb-90 {
  margin-bottom: 90px !important;
}
.mb-95 {
  margin-bottom: 95px !important;
}
.mb-100 {
  margin-bottom: 100px !important;
}
@media screen and (max-width: 768px) {
  .mb-0-sp {
    margin-bottom: 0px !important;
  }
  .mb-5-sp {
    margin-bottom: 5px !important;
  }
  .mb-10-sp {
    margin-bottom: 10px !important;
  }
  .mb-15-sp {
    margin-bottom: 15px !important;
  }
  .mb-20-sp {
    margin-bottom: 20px !important;
  }
  .mb-25-sp {
    margin-bottom: 25px !important;
  }
  .mb-30-sp {
    margin-bottom: 30px !important;
  }
  .mb-35-sp {
    margin-bottom: 35px !important;
  }
  .mb-40-sp {
    margin-bottom: 40px !important;
  }
  .mb-45-sp {
    margin-bottom: 45px !important;
  }
  .mb-50-sp {
    margin-bottom: 50px !important;
  }
  .mb-55-sp {
    margin-bottom: 55px !important;
  }
  .mb-60-sp {
    margin-bottom: 60px !important;
  }
  .mb-65-sp {
    margin-bottom: 65px !important;
  }
  .mb-70-sp {
    margin-bottom: 70px !important;
  }
  .mb-75-sp {
    margin-bottom: 75px !important;
  }
  .mb-80-sp {
    margin-bottom: 80px !important;
  }
  .mb-85-sp {
    margin-bottom: 85px !important;
  }
  .mb-90-sp {
    margin-bottom: 90px !important;
  }
  .mb-95-sp {
    margin-bottom: 95px !important;
  }
  .mb-100-sp {
    margin-bottom: 100px !important;
  }
}
@media screen and (min-width: 769px) {
  .mb-0-pc {
    margin-bottom: 0px !important;
  }
  .mb-5-pc {
    margin-bottom: 5px !important;
  }
  .mb-10-pc {
    margin-bottom: 10px !important;
  }
  .mb-15-pc {
    margin-bottom: 15px !important;
  }
  .mb-20-pc {
    margin-bottom: 20px !important;
  }
  .mb-25-pc {
    margin-bottom: 25px !important;
  }
  .mb-30-pc {
    margin-bottom: 30px !important;
  }
  .mb-35-pc {
    margin-bottom: 35px !important;
  }
  .mb-40-pc {
    margin-bottom: 40px !important;
  }
  .mb-45-pc {
    margin-bottom: 45px !important;
  }
  .mb-50-pc {
    margin-bottom: 50px !important;
  }
  .mb-55-pc {
    margin-bottom: 55px !important;
  }
  .mb-60-pc {
    margin-bottom: 60px !important;
  }
  .mb-65-pc {
    margin-bottom: 65px !important;
  }
  .mb-70-pc {
    margin-bottom: 70px !important;
  }
  .mb-75-pc {
    margin-bottom: 75px !important;
  }
  .mb-80-pc {
    margin-bottom: 80px !important;
  }
  .mb-85-pc {
    margin-bottom: 85px !important;
  }
  .mb-90-pc {
    margin-bottom: 90px !important;
  }
  .mb-95-pc {
    margin-bottom: 95px !important;
  }
  .mb-100-pc {
    margin-bottom: 100px !important;
  }
}

.ml-0 {
  margin-left: 0px !important;
}
.ml-5 {
  margin-left: 5px !important;
}
.ml-10 {
  margin-left: 10px !important;
}
.ml-15 {
  margin-left: 15px !important;
}
.ml-20 {
  margin-left: 20px !important;
}
.ml-25 {
  margin-left: 25px !important;
}
.ml-30 {
  margin-left: 30px !important;
}
.ml-35 {
  margin-left: 35px !important;
}
.ml-40 {
  margin-left: 40px !important;
}
.ml-45 {
  margin-left: 45px !important;
}
.ml-50 {
  margin-left: 50px !important;
}
.ml-55 {
  margin-left: 55px !important;
}
.ml-60 {
  margin-left: 60px !important;
}
.ml-65 {
  margin-left: 65px !important;
}
.ml-70 {
  margin-left: 70px !important;
}
.ml-75 {
  margin-left: 75px !important;
}
.ml-80 {
  margin-left: 80px !important;
}
.ml-85 {
  margin-left: 85px !important;
}
.ml-90 {
  margin-left: 90px !important;
}
.ml-95 {
  margin-left: 95px !important;
}
.ml-100 {
  margin-left: 100px !important;
}
@media screen and (max-width: 768px) {
  .ml-0-sp {
    margin-left: 0px !important;
  }
  .ml-5-sp {
    margin-left: 5px !important;
  }
  .ml-10-sp {
    margin-left: 10px !important;
  }
  .ml-15-sp {
    margin-left: 15px !important;
  }
  .ml-20-sp {
    margin-left: 20px !important;
  }
  .ml-25-sp {
    margin-left: 25px !important;
  }
  .ml-30-sp {
    margin-left: 30px !important;
  }
  .ml-35-sp {
    margin-left: 35px !important;
  }
  .ml-40-sp {
    margin-left: 40px !important;
  }
  .ml-45-sp {
    margin-left: 45px !important;
  }
  .ml-50-sp {
    margin-left: 50px !important;
  }
  .ml-55-sp {
    margin-left: 55px !important;
  }
  .ml-60-sp {
    margin-left: 60px !important;
  }
  .ml-65-sp {
    margin-left: 65px !important;
  }
  .ml-70-sp {
    margin-left: 70px !important;
  }
  .ml-75-sp {
    margin-left: 75px !important;
  }
  .ml-80-sp {
    margin-left: 80px !important;
  }
  .ml-85-sp {
    margin-left: 85px !important;
  }
  .ml-90-sp {
    margin-left: 90px !important;
  }
  .ml-95-sp {
    margin-left: 95px !important;
  }
  .ml-100-sp {
    margin-left: 100px !important;
  }
}
@media screen and (min-width: 769px) {
  .ml-0-pc {
    margin-left: 0px !important;
  }
  .ml-5-pc {
    margin-left: 5px !important;
  }
  .ml-10-pc {
    margin-left: 10px !important;
  }
  .ml-15-pc {
    margin-left: 15px !important;
  }
  .ml-20-pc {
    margin-left: 20px !important;
  }
  .ml-25-pc {
    margin-left: 25px !important;
  }
  .ml-30-pc {
    margin-left: 30px !important;
  }
  .ml-35-pc {
    margin-left: 35px !important;
  }
  .ml-40-pc {
    margin-left: 40px !important;
  }
  .ml-45-pc {
    margin-left: 45px !important;
  }
  .ml-50-pc {
    margin-left: 50px !important;
  }
  .ml-55-pc {
    margin-left: 55px !important;
  }
  .ml-60-pc {
    margin-left: 60px !important;
  }
  .ml-65-pc {
    margin-left: 65px !important;
  }
  .ml-70-pc {
    margin-left: 70px !important;
  }
  .ml-75-pc {
    margin-left: 75px !important;
  }
  .ml-80-pc {
    margin-left: 80px !important;
  }
  .ml-85-pc {
    margin-left: 85px !important;
  }
  .ml-90-pc {
    margin-left: 90px !important;
  }
  .ml-95-pc {
    margin-left: 95px !important;
  }
  .ml-100-pc {
    margin-left: 100px !important;
  }
}

/* SIZING
---------------------------------------*/
/*--- 幅 ---*/
.w-auto {
  width: auto;
}
@media screen and (max-width: 768px) {
  .w-auto-sp {
    width: auto;
  }
}
@media screen and (min-width: 769px) {
  .w-auto-pc {
    width: auto;
  }
}

.w-0 {
  width: 0;
}
@media screen and (max-width: 768px) {
  .w-0-sp {
    width: 0;
  }
}
@media screen and (min-width: 769px) {
  .w-0-pc {
    width: 0;
  }
}

.w-full {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .w-full-sp {
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .w-full-pc {
    width: 100%;
  }
}

.w-screen {
  width: 100vw;
}
@media screen and (max-width: 768px) {
  .w-screen-sp {
    width: 100vw;
  }
}
@media screen and (min-width: 769px) {
  .w-screen-pc {
    width: 100vw;
  }
}

/*--- 高さ ---*/
.h-full {
  height: 100%;
}
@media screen and (max-width: 768px) {
  .h-full-sp {
    height: 100%;
  }
}
@media screen and (min-width: 769px) {
  .h-full-pc {
    height: 100%;
  }
}

.h-screen {
  height: 100vh;
}
@media screen and (max-width: 768px) {
  .h-screen-sp {
    height: 100vh;
  }
}
@media screen and (min-width: 769px) {
  .h-screen-pc {
    height: 100vh;
  }
}

/* TYPOGRAPHY
---------------------------------------*/
/* ---フォントウェイト ---*/
.font-normal {
  font-weight: normal;
}
@media screen and (max-width: 768px) {
  .font-normal-sp {
    font-weight: normal;
  }
}
@media screen and (min-width: 769px) {
  .font-normal-pc {
    font-weight: normal;
  }
}

.font-bold {
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .font-bold-sp {
    font-weight: bold;
  }
}
@media screen and (min-width: 769px) {
  .font-bold-pc {
    font-weight: bold;
  }
}

/*--- テキストアライン ---*/
.text-left {
  text-align: left;
}
@media screen and (max-width: 768px) {
  .text-left-sp {
    text-align: left;
  }
}
@media screen and (min-width: 769px) {
  .text-left-pc {
    text-align: left;
  }
}

.text-center {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .text-center-sp {
    text-align: center;
  }
}
@media screen and (min-width: 769px) {
  .text-center-pc {
    text-align: center;
  }
}

.text-right {
  text-align: right;
}
@media screen and (max-width: 768px) {
  .text-right-sp {
    text-align: right;
  }
}
@media screen and (min-width: 769px) {
  .text-right-pc {
    text-align: right;
  }
}

/*--- バーティカルアライン ---*/
.align-top {
  vertical-align: top;
}
@media screen and (max-width: 768px) {
  .align-top-sp {
    vertical-align: top;
  }
}
@media screen and (min-width: 769px) {
  .align-top-pc {
    vertical-align: top;
  }
}

.align-middle {
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .align-middle-sp {
    vertical-align: middle;
  }
}
@media screen and (min-width: 769px) {
  .align-middle-pc {
    vertical-align: middle;
  }
}

.align-bottom {
  vertical-align: bottom;
}
@media screen and (max-width: 768px) {
  .align-bottom-sp {
    vertical-align: bottom;
  }
}
@media screen and (min-width: 769px) {
  .align-bottom-pc {
    vertical-align: bottom;
  }
}
