@charset "UTF-8";
@font-face {
  font-family: "Helvetica Light";
  src: url("../font/helvetica-light.ttf") format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Helvetica Light";
  src: url("../font/helvetica-light.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
/*!
 * Generated CSS: ../oc06-13_06-14.css
 * Edit this SCSS file, then compile.
 */
:root {
  --oc-red: #d50028;
  --oc-red-dark: #c30025;
  --oc-red-deep: #b90023;
  --oc-blue: #00a6e9;
  --oc-pink: #f07e94;
  --oc-white: #fff;
  --oc-gray: #5d5d5d;
  --oc-black: #282828;
}

@media (min-width: 768px) {
  html {
    font-size: 10px;
  }
}
@media (max-width: 767px) {
  html {
    font-size: 2.6666666667vw;
  }
}

html,
body {
  min-height: 100%;
}

html.is-animation-preparing .oc-hero__copy,
html.is-animation-preparing .oc-hero__tag {
  opacity: 0;
}

body.underpage {
  color: #fff;
  background: #d50028;
  letter-spacing: 0.05em;
}
body.underpage main,
body.underpage .wrap {
  overflow: visible;
}
body.underpage main {
  position: relative;
}
@media (min-width: 768px) {
  body.underpage {
    --pc-shell-left: calc(50vw - 2rem);
    --pc-shell-width: 39rem;
    --pc-nav-width: 17rem;
    --pc-nav-safe-right: 3rem;
    height: 100dvh;
    overflow: hidden;
    background: #d50028;
  }
}

.header {
  display: none;
}
@media (max-width: 767px) {
  .header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 80;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 6rem;
    padding: 0 0 0 1.5rem;
    background: #d50028;
  }
}
.header * {
  pointer-events: all;
}
.header__logo {
  position: relative;
  z-index: 2;
}
.header__logo img {
  width: 18rem;
}
.header__overlay {
  display: none;
}
.header__btn {
  margin: 0;
  padding: 0;
  color: inherit;
  font: inherit;
  border: 0;
  border-radius: 0;
  background: transparent;
  appearance: none;
  cursor: pointer;
  position: relative;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6rem;
  aspect-ratio: 1;
  padding: 1rem 0;
  color: #fff;
  overflow: hidden;
}
.header__btn-icon {
  position: relative;
  width: 3rem;
  height: 2rem;
}
.header__btn-icon span {
  position: absolute;
  left: 0;
  display: block;
  width: 100%;
  border-bottom: 1px solid currentColor;
  transform-origin: center;
  transition: transform 0.2s, top 0.2s 0.2s, width 0.2s, color 0.2s;
}
.header__btn-icon span:nth-child(1) {
  top: 0;
}
.header__btn-icon span:nth-child(2) {
  top: calc(50% - 1px);
}
.header__btn-icon span:nth-child(3) {
  top: calc(100% - 2px);
  width: 66.66%;
}
@media (max-width: 767px) {
  .header__nav {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 4;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100vh;
    height: 100dvh;
    font-weight: 500;
    background: #d50028;
    overflow-y: auto;
    visibility: hidden;
    pointer-events: none;
    transform: translateX(100%);
    transition: transform 0.35s ease, visibility 0s linear 0.35s;
    will-change: transform;
  }
}
@media (max-width: 767px) {
  .header__nav-inner {
    padding: 6rem 2rem 4rem;
  }
}
.header__menu {
  margin: 0;
  padding: 0;
  list-style: none;
}
.header__menu-item {
  margin-bottom: 3rem;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1;
  text-align: center;
}
.header__menu-item a {
  color: #fff;
}
.header__menu-item--btn {
  margin: 1rem auto 0;
  font-size: 1.6rem;
}
.header__menu-item--btn a {
  display: block;
  width: 19rem;
  margin: 0 auto;
  color: #d50028;
  line-height: 4rem;
  text-align: center;
  background: #fff;
}

@media (max-width: 767px) {
  body.is-header-open {
    overflow: hidden;
  }
  body.is-header-open .header__btn-icon span {
    transition: transform 0.2s 0.2s, top 0.2s, width 0.2s;
  }
  body.is-header-open .header__btn-icon span:nth-child(1) {
    top: calc(50% - 1px);
    width: 100%;
    transform: rotate(-45deg);
  }
  body.is-header-open .header__btn-icon span:nth-child(2) {
    transform: translateX(190%);
  }
  body.is-header-open .header__btn-icon span:nth-child(3) {
    top: calc(50% - 1px);
    width: 100%;
    transform: rotate(45deg);
  }
  body.is-header-open .header__nav {
    visibility: visible;
    pointer-events: auto;
    transform: translateX(0);
    transition: transform 0.35s ease;
  }
}
.oc-page {
  position: relative;
  width: 100%;
  min-height: 100dvh;
  background: #d50028;
  z-index: 2;
}
@media (min-width: 768px) {
  .oc-page {
    width: 39rem;
    height: 100dvh;
    min-height: 0;
    margin: 0 auto;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-color: #00a6e9 #b90023;
    scrollbar-width: thin;
    box-shadow: 0 0 2rem rgba(0, 0, 0, 0.3);
  }
  .oc-page::-webkit-scrollbar {
    width: 0.8rem;
  }
  .oc-page::-webkit-scrollbar-track {
    background: #b90023;
  }
  .oc-page::-webkit-scrollbar-thumb {
    background: #00a6e9;
  }
}
@media (min-width: 1200px) {
  .oc-page {
    position: fixed;
    top: 0;
    left: var(--pc-shell-left);
    margin: 0;
  }
}
.oc-page .container {
  position: relative;
  width: auto;
  max-width: none;
  margin: 0 2rem;
  z-index: 1;
}

.pc-side {
  display: none;
}
@media (min-width: 1200px) {
  .pc-side {
    position: fixed;
    top: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    min-width: 0;
    color: #00a6e9;
    z-index: 1;
  }
  .pc-side a {
    pointer-events: auto;
  }
  .pc-side--left {
    justify-content: space-between;
    gap: clamp(4rem, 8vh, 9rem);
    left: 0;
    width: var(--pc-shell-left);
    padding: clamp(5rem, 8vh, 7.9rem) 0 clamp(5rem, 8vh, 7.9rem) 8.9rem;
  }
  .pc-side--right {
    left: min(calc(var(--pc-shell-left) + var(--pc-shell-width) + 8rem), calc(100vw - var(--pc-nav-width) - var(--pc-nav-safe-right)));
    right: 0;
    align-items: flex-start;
    padding-top: 10.2rem;
  }
  .pc-side__en {
    margin: 0;
    font-family: "Helvetica Light", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 3.1rem;
    font-weight: 400;
    line-height: 1.28;
    letter-spacing: 0.11em;
  }
  .pc-side__copy {
    margin: 0;
    font-size: 5.5rem;
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: 0.2em;
  }
  .pc-side__logo {
    width: 25.8rem;
    margin-top: 0;
  }
  .pc-side__logo img {
    width: 100%;
  }
}

@media (min-width: 1200px) {
  .pc-nav {
    width: var(--pc-nav-width);
    margin: 0;
  }
  .pc-nav__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 1.9rem;
  }
  .pc-nav a {
    display: inline;
    color: #fff;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.35;
    letter-spacing: 0.06em;
    background-image: linear-gradient(#00a6e9, #00a6e9);
    background-repeat: no-repeat;
    background-size: 0 100%;
    background-position: right top;
    transition: background-size 0.36s cubic-bezier(0.4, 0, 0.2, 1), color 0.36s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.36s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.36s cubic-bezier(0.4, 0, 0.2, 1);
  }
}
@media (min-width: 1200px) and (hover: hover) {
  .pc-nav a:hover, .pc-nav a:focus-visible {
    background-position: left top;
    background-size: 100% 100%;
    color: #d50028;
  }
}
@media (min-width: 1200px) {
  .pc-nav__entry {
    margin-top: 1.4rem;
  }
  .pc-nav__entry a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--pc-nav-width);
    min-height: 4rem;
    color: #d50028;
    background-color: #fff;
  }
}

.oc-hero {
  padding: 2rem 2rem 4.8rem;
  color: #00a6e9;
  overflow: hidden;
}
.oc-hero__logo {
  position: relative;
  z-index: 2;
  width: 18rem;
  transition: opacity 0.3s;
}
@media (hover: hover) {
  .oc-hero__logo:hover, .oc-hero__logo:focus-visible {
    opacity: 0.6;
  }
}
.oc-hero__logo img {
  width: 100%;
}
.oc-hero__copy {
  width: 100%;
  margin-top: 6rem;
  font-size: 3.7rem;
  font-weight: 500;
  line-height: 1.38;
  letter-spacing: 0.16em;
}
.oc-hero__tag {
  display: inline-block;
  margin-top: 1.2rem;
  padding: 0.25rem 0.45rem;
  color: #d50028;
  font-family: "Helvetica Light", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 1.4rem;
  line-height: 1;
  letter-spacing: 0.08em;
  background: #00a6e9;
}
.oc-hero__title {
  width: 100%;
  margin-top: 4rem;
  font-family: "Helvetica Light", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 2.4rem;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.18em;
}
.oc-hero__dates {
  display: grid;
  gap: 1.8rem;
  width: 100%;
  margin-top: 1.8rem;
  font-weight: 500;
}
.oc-hero__lead {
  width: 100%;
  margin-top: 10rem;
  color: #00a6e9;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
}
.oc-hero__lead + .oc-hero__lead {
  margin-top: 1.6em;
}

.oc-fixed-entry {
  position: fixed;
  right: 2rem;
  bottom: 2rem;
  left: 2rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  min-height: 5.8rem;
  background-color: #d50028;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(1.2rem);
  z-index: 30;
  transition: opacity 0.28s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.28s cubic-bezier(0.4, 0, 0.2, 1), transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}
.oc-fixed-entry.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}
.oc-fixed-entry__link {
  position: relative;
  isolation: isolate;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 5.8rem;
  padding: 0.8rem 2.2rem 0.8rem 1rem;
  color: #d50028;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.35;
  text-align: center;
  background-color: #00a6e9;
  overflow: hidden;
  background-image: linear-gradient(#fff, #fff);
  background-repeat: no-repeat;
  background-size: 0 100%;
  background-position: right top;
  transition: background-size 0.36s cubic-bezier(0.4, 0, 0.2, 1), color 0.36s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.36s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.36s cubic-bezier(0.4, 0, 0.2, 1);
}
.oc-fixed-entry__link span {
  position: relative;
  z-index: 1;
  white-space: nowrap;
}
.oc-fixed-entry__link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.2rem;
  z-index: 1;
  width: 0.8rem;
  aspect-ratio: 1;
  border-top: 1px solid currentColor;
  border-right: 1px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}
@media (hover: hover) {
  .oc-fixed-entry__link:hover, .oc-fixed-entry__link:focus-visible {
    background-position: left top;
    background-size: 100% 100%;
  }
}
@media (min-width: 768px) {
  .oc-fixed-entry {
    display: none;
  }
}

.oc-date {
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  column-gap: 0.8rem;
  align-items: end;
}
.oc-date__day {
  display: flex;
  align-items: flex-end;
  gap: 0.8rem;
  margin: 0;
  font-family: "Helvetica Light", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 5.6rem;
  font-weight: 300;
  line-height: 0.85;
  letter-spacing: 0.04em;
}
.oc-date__day span {
  padding-bottom: 0.4rem;
  font-size: 2rem;
  font-weight: 400;
  letter-spacing: 0.08em;
}
.oc-date__campus {
  margin: 0 0 0.35rem;
  font-size: 1.9rem;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
}
.oc-date__area {
  grid-column: 1/-1;
  margin-top: 0.8rem;
  font-size: 1.7rem;
  line-height: 1.6;
}

.u-nowrap {
  white-space: nowrap;
}

.oc-heading {
  margin: 0;
  color: #00a6e9;
  font-size: 3.3rem;
  font-weight: 500;
  line-height: 1.25;
  text-align: center;
  letter-spacing: 0.08em;
}
.oc-heading::after {
  content: "";
  display: block;
  width: 100%;
  margin-top: 1.2rem;
  border-bottom: 1px solid currentColor;
}

.oc-section-title,
.entry-title {
  color: #00a6e9;
  text-align: center;
}
.oc-section-title > span,
.entry-title > span {
  display: block;
  font-family: "Helvetica Light", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 2rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.18em;
}
.oc-section-title h2,
.entry-title h2 {
  margin-top: 0.9rem;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: 0.08em;
  text-wrap: balance;
}

.oc-section-title h2 {
  font-size: 3.3rem;
}

.entry-title h2 {
  font-size: 1.8rem;
}

.section-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  margin-bottom: 3.5rem;
  color: #00a6e9;
  line-height: 1;
  text-align: center;
  word-break: normal;
}
.section-title__jp {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-wrap: balance;
}
.section-title__en {
  font-family: "Helvetica Light", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 3.6rem;
  font-weight: 300;
  line-height: 1;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.section-title--under {
  margin-bottom: 3.5rem;
}

.point-section,
.timetable-section,
.single-program,
.common-program,
.access-section,
.info-section {
  padding: 6rem 0;
}

.point-section {
  background: #C30025;
}

.point-section,
.timetable-section,
.area-section,
.single-program,
.common-program,
.access-section,
.info-section {
  overflow: hidden;
}

.point-list {
  display: grid;
  gap: 5rem;
  margin-top: 3.5rem;
}

.point-card {
  position: relative;
  padding-top: 2.2rem;
  color: #fff;
}
.point-card img {
  width: 100%;
  aspect-ratio: 31/20;
  object-fit: cover;
}
.point-card__num {
  position: absolute;
  top: 0;
  right: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  color: #fff;
  font-weight: 400;
  font-family: "Helvetica Light", "Helvetica Neue", Helvetica, Arial, sans-serif;
  line-height: 1;
  text-align: right;
  z-index: 1;
}
.point-card__num span {
  display: inline-block;
  transform: translateY(-20%);
  color: #fff;
  font-size: 5.5rem;
  font-weight: 300;
  line-height: 0.82;
}
.point-card__title {
  margin-top: 1.5rem;
  font-size: 2rem;
  line-height: 1.55;
  letter-spacing: 0.06em;
}
.point-card__text {
  margin-top: 1.8rem;
  font-size: 1.5rem;
  line-height: 1.9;
}

.badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  margin-top: 1.4rem;
}
.badge-row span {
  display: inline-flex;
  align-items: center;
  min-height: 2.3rem;
  padding: 0.25rem 1rem;
  color: #d50028;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.2;
  background: #fff;
}

.timetable-section .oc-section-title > span {
  font-size: 4.4rem;
  letter-spacing: 0.16em;
}
.timetable-section .oc-section-title h2 {
  display: none;
}
.timetable-card {
  display: grid;
  gap: 4.2rem;
  margin-top: 2.8rem;
  padding: 3rem 1.5rem;
  color: #d50028;
  background: #fff;
}
.timetable-day {
  display: grid;
  gap: 1.6rem;
}
.timetable-day__title {
  margin: 0;
  color: #d50028;
  font-size: clamp(2.5rem, 6.6vw, 3rem);
  font-weight: 500;
  line-height: 1.35;
  letter-spacing: 0.03em;
  text-align: center;
  white-space: nowrap;
}
.timetable-table {
  width: 100%;
  color: #282828;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.45;
  border-collapse: collapse;
}
.timetable-table tr:nth-child(even) td {
  background: #eee;
}
.timetable-table tr:first-child th {
  border-top-color: #d50028;
}
.timetable-table tr:last-child th {
  border-bottom-color: #d50028;
}
.timetable-table th,
.timetable-table td {
  padding: 0.95rem 1rem;
  border: 1px solid #d50028;
  vertical-align: middle;
}
.timetable-table th {
  width: 8rem;
  color: #fff;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.2;
  text-align: left;
  white-space: nowrap;
  background: #d50028;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
}
.timetable-table ul {
  margin: 0;
  padding-left: 0;
  list-style: none;
}
.timetable-table ul li {
  padding-left: 1em;
  text-indent: -1em;
}
.timetable-table ul li::before {
  content: "・";
}

.area-section {
  padding: 6.5rem 0;
  background: #c30025;
  overflow-anchor: none;
}

.area-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.4rem;
  margin: 3.2rem 0 0;
}
body.underpage .area-tabs button {
  margin: 0;
  padding: 0;
  color: inherit;
  font: inherit;
  border: 0;
  border-radius: 0;
  background: transparent;
  appearance: none;
  cursor: pointer;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 6rem;
  padding: 1rem 3rem 1rem 1.5rem;
  color: #d50028;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.25;
  text-align: left;
  background-color: #fff;
  transition: color 0.36s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.36s cubic-bezier(0.4, 0, 0.2, 1);
}
body.underpage .area-tabs button span {
  position: relative;
  z-index: 1;
}
body.underpage .area-tabs button::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #00a6e9;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.36s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 0;
}
body.underpage .area-tabs button::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.4rem;
  width: 0.8rem;
  aspect-ratio: 1;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: translateY(-65%) rotate(45deg);
  transition: transform 0.36s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1;
}
@media (hover: hover) {
  body.underpage .area-tabs button:hover::before, body.underpage .area-tabs button:focus-visible::before {
    transform: scaleX(1);
    transform-origin: left center;
  }
}
body.underpage .area-tabs button[aria-selected=true] {
  color: #d50028;
  pointer-events: none;
  cursor: default;
}
body.underpage .area-tabs button[aria-selected=true]::before {
  transform: scaleX(1);
  transform-origin: left center;
}
body.underpage .area-tabs button[aria-selected=true]::after {
  transform: translateY(-35%) rotate(225deg);
}
body.underpage .area-tabs button.is-leaving::before {
  transform: scaleX(0);
  transform-origin: right center;
}
.area-tabs--bottom {
  margin-top: 5rem;
}

.area-panels {
  margin-top: 4.5rem;
}

.area-panel[hidden] {
  display: none;
}
.area-panel__head {
  color: #00a6e9;
  text-align: center;
}
.area-panel__campus {
  display: inline-block;
  padding: 0.25rem 1.4rem;
  color: #d50028;
  font-size: 1.4rem;
  font-weight: 500;
  background: #00a6e9;
}
.area-panel__title {
  margin-top: 1.2rem;
  font-size: 4rem;
  font-weight: 500;
  line-height: 1.2;
}

.download-link {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  width: 30rem;
  max-width: 100%;
  margin-top: 2rem;
  padding: 1rem 1.8rem 0.7rem;
  --motion-band: #00a6e9;
  color: #fff;
  font-weight: 500;
  border: 1px solid #fff;
  background-image: linear-gradient(var(--motion-band), var(--motion-band));
  background-repeat: no-repeat;
  background-size: 0 100%;
  background-position: right top;
  transition: background-size 0.36s cubic-bezier(0.4, 0, 0.2, 1), color 0.36s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.36s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.36s cubic-bezier(0.4, 0, 0.2, 1);
}
.download-link img {
  flex: 0 0 auto;
  width: 1.8rem;
  height: auto;
  transition: none;
}
.download-link__text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  line-height: 1.2;
}
.download-link__program {
  font-size: 1.2rem;
  line-height: 1;
}
.download-link__schedule {
  font-size: 2rem;
  line-height: 1.2;
}
.download-link__pdf {
  font-size: 1.4rem;
  line-height: 1.2;
}
@media (hover: hover) {
  .download-link:hover, .download-link:focus-visible {
    background-position: left top;
    background-size: 100% 100%;
    color: #d50028;
    border-color: #00a6e9;
  }
  .download-link:hover img, .download-link:focus-visible img {
    filter: brightness(0) saturate(100%) invert(15%) sepia(93%) saturate(5837%) hue-rotate(340deg) brightness(86%) contrast(111%);
  }
}

.program-block {
  margin: 4rem 0 0;
  padding: 3rem 1.5rem;
  color: #d50028;
  background: #fff;
}
.program-block__head {
  text-align: center;
}
.program-block__title {
  margin-top: 0;
  font-size: 3.3rem;
  font-weight: 500;
  line-height: 1.35;
  text-wrap: balance;
}
.program-block__kicker {
  display: block;
  font-size: 3.3rem;
  font-weight: 500;
  line-height: 1.35;
  text-wrap: balance;
}
.program-block__meta {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1.4rem;
  margin-top: 1rem;
}
.program-block__reserve {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 10rem;
  min-height: 2.8rem;
  padding: 0.3rem 1rem;
  color: #d50028;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.2;
  border: 1px solid currentColor;
}
.program-block__target {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  color: #d50028;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.2;
}
.program-block__target-label {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 10rem;
  min-height: 2.8rem;
  padding: 0.2rem 1rem;
  color: #fff;
  background: #d50028;
}
.program-block__target-text {
  display: inline-flex;
  align-items: center;
  min-height: 2.8rem;
}
.program-block--experience .program-card {
  padding-top: 0;
  overflow: hidden;
}
.program-block--experience .program-card__course {
  margin: 0 -1.5rem 1.5rem;
  padding: 1rem 1.5rem;
  color: #fff;
  line-height: 1.35;
  background: #d50028;
}
.program-block--experience .program-card__course::before {
  content: none;
}
.program-block--experience .program-card__title {
  margin-top: 0;
}
.program-block--info {
  margin-top: 2rem;
  padding: 1.5rem;
}
.program-block--info .program-card-list {
  gap: 0;
  margin-top: 1.7rem;
}
.program-block--info .program-card {
  padding: 0;
  border: 0;
}
.program-block--info .program-card__image {
  margin-top: 0;
}
.program-block--info .program-card__title {
  margin-top: 1.7rem;
  font-size: 2rem;
  line-height: 1.45;
}
.program-block--info .program-card__time,
.program-block--info .program-card__text {
  margin-top: 1.3rem;
}
.program-block .reserve-link {
  margin: 3rem auto 0;
}

.program-card {
  position: relative;
  padding: 1.5rem;
  color: #282828;
  border: 0.2rem solid #d50028;
  background: #fff;
}
.program-card-list {
  display: grid;
  gap: 1.5rem;
  margin-top: 2.8rem;
}
.program-card__course {
  position: relative;
  display: block;
  margin: 0 0 0.6rem;
  color: #282828;
  font-weight: 700;
  line-height: 1.45;
}
.program-card__course::before {
  content: "";
  position: absolute;
  top: 0.6em;
  left: -1.5rem;
  width: 1rem;
  height: 0.6rem;
  background: #d50028;
}
.program-card__title {
  margin: 0.2rem 0 0;
  color: #282828;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: 0.05em;
  line-break: strict;
  word-break: normal;
  overflow-wrap: normal;
  text-wrap: wrap;
}
.program-card__badges {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 1.5rem;
}
.program-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 1rem;
  color: #d50028;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.25;
  border: 1px solid currentColor;
}
.program-card__badge--split {
  gap: 0;
  padding-right: 0;
  padding-left: 0;
  border: 0;
}
.program-card__badge--text {
  padding-right: 0;
  padding-left: 0;
  border: 0;
}
.program-card__badge-label {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0;
}
.program-card__badge-label::after {
  content: "：";
}
.program-card__badge-text {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0;
}
.program-card__time {
  display: block;
  margin-top: 1rem;
}
.program-card__time span {
  display: inline;
  padding: 0.2rem 0.55rem;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.9;
  letter-spacing: 0.04em;
  background: #5d5d5d;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
.program-card__text {
  margin-top: 1.5rem;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
}
.program-card__image {
  margin-top: 1.5rem;
}
.program-card__image img {
  display: block;
  width: 100%;
  aspect-ratio: 750/425;
  object-fit: cover;
}

.time-label {
  display: block;
  margin-top: 1rem;
}
.time-label span {
  display: inline;
  padding: 0.2rem 0.55rem;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.9;
  letter-spacing: 0.04em;
  background: #5d5d5d;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.reserve-link {
  box-sizing: border-box;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 5.4rem;
  margin-top: 3rem;
  padding: 1rem 5rem 1rem 2rem;
  --motion-band: #fff;
  color: #d50028;
  font-size: 1.5rem;
  font-weight: 500;
  text-align: center;
  border: 1px solid #00a6e9;
  background-color: #00a6e9;
  background-image: linear-gradient(var(--motion-band), var(--motion-band));
  background-repeat: no-repeat;
  background-size: 0 100%;
  background-position: right top;
  transition: background-size 0.36s cubic-bezier(0.4, 0, 0.2, 1), color 0.36s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.36s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.36s cubic-bezier(0.4, 0, 0.2, 1);
}
.reserve-link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 3.6rem;
  width: 0.9rem;
  aspect-ratio: 1;
  border-top: 1px solid currentColor;
  border-right: 1px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}
@media (hover: hover) {
  .reserve-link:hover, .reserve-link:focus-visible {
    background-position: left top;
    background-size: 100% 100%;
  }
}

.single-program {
  background: #d50028;
}
.single-program + .single-program {
  padding-top: 2rem;
}

.feature-card {
  margin-top: 3rem;
}
.feature-card img {
  width: 100%;
  aspect-ratio: 825/525;
  object-fit: cover;
}
.feature-card img + .time-label {
  margin-top: 2rem;
}
.feature-card__title {
  margin-top: 1.6rem;
  font-size: 2rem;
  line-height: 1.45;
}
.feature-card__text {
  margin-top: 1.4rem;
  font-size: 1.5rem;
  line-height: 1.9;
}

.common-program {
  --common-slide-width: 30rem;
  --common-slide-padding: 1.5rem;
  --common-image-height: calc((var(--common-slide-width) - var(--common-slide-padding) * 2) * 525 / 750);
  background: #c30025;
}
.common-program__swiper {
  position: relative;
  margin: 3rem -2rem 0;
  overflow: visible;
}
.common-program__nav {
  margin: 0;
  padding: 0;
  color: inherit;
  font: inherit;
  border: 0;
  border-radius: 0;
  background: transparent;
  appearance: none;
  cursor: pointer;
  position: absolute;
  top: calc(var(--common-image-height) / 2);
  width: 3rem;
  height: 3rem;
  color: #00a6e9;
  transform: translateY(-50%);
  transition: color 0.25s ease, opacity 0.25s ease;
  z-index: 2;
}
.common-program__nav::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1.5rem;
  aspect-ratio: 1;
  border-top: 2px solid currentColor;
  border-left: 2px solid currentColor;
}
.common-program__nav--prev {
  left: 2.7rem;
}
.common-program__nav--prev::before {
  transform: translate(-35%, -50%) rotate(-45deg);
}
.common-program__nav--next {
  right: 2.7rem;
}
.common-program__nav--next::before {
  transform: translate(-65%, -50%) rotate(135deg);
}
@media (hover: hover) {
  .common-program__nav:hover, .common-program__nav:focus-visible {
    opacity: 0.72;
  }
}
.common-program__pagination {
  display: none;
}

.common-slide {
  width: var(--common-slide-width);
  padding: 0 var(--common-slide-padding);
  color: #fff;
}
.common-slide img {
  width: 100%;
  aspect-ratio: 750/525;
  object-fit: cover;
}
.common-slide__title {
  margin-top: 2rem;
  font-size: 2.8rem;
  line-height: 1.4;
  text-align: center;
}
.common-slide__text {
  margin-top: 1.8rem;
  font-size: 1.5rem;
  line-height: 1.9;
}
.common-slide__text small {
  font-size: 0.85em;
}

.entry-section {
  padding: 6.5rem 0;
  color: #fff;
  background: #00a6e9;
}
.entry-title {
  color: #d50028;
}
.entry-title > span {
  font-size: 6.5rem;
  letter-spacing: 0.1em;
}
.entry-lead {
  margin-top: 3rem;
  padding: 1.6rem 0;
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
  border-top: 1px solid rgba(255, 255, 255, 0.72);
  border-bottom: 1px solid rgba(255, 255, 255, 0.72);
}
.entry-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 1rem;
  margin-top: 3rem;
  counter-reset: entry;
}
.entry-list__item {
  display: grid;
  grid-template-columns: 1.6rem minmax(0, 1fr);
  gap: 0.8rem;
  font-size: 1.5rem;
  line-height: 1.65;
  counter-increment: entry;
}
.entry-list__item::before {
  content: counter(entry);
  display: grid;
  place-items: center;
  width: 1.6rem;
  aspect-ratio: 1;
  border: 1px solid currentColor;
  border-radius: 50%;
  font-size: 1rem;
  line-height: 1;
}
.entry-free, .entry-note {
  margin-top: 1.8rem;
  font-size: 1.2rem;
  line-height: 1.8;
}
.entry-buttons {
  display: grid;
  gap: 1.4rem;
  margin-top: 3rem;
  justify-items: center;
}
.entry-button {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 34rem;
  min-height: 5.8rem;
  padding: 1.4rem 3rem 1.4rem 5.4rem;
  color: #d50028;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.08em;
  text-align: center;
  --motion-band: #00a6e9;
  border: 1px solid #fff;
  background-color: #fff;
  background-image: linear-gradient(var(--motion-band), var(--motion-band));
  background-repeat: no-repeat;
  background-size: 0 100%;
  background-position: right top;
  transition: background-size 0.36s cubic-bezier(0.4, 0, 0.2, 1), color 0.36s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.36s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.36s cubic-bezier(0.4, 0, 0.2, 1);
}
.entry-button * {
  color: inherit;
}
.entry-button__icon {
  position: absolute;
  top: 50%;
  left: 2rem;
  display: block;
  height: auto;
  transform: translateY(-50%);
}
.entry-button__icon--new {
  width: 2.3rem;
}
.entry-button__icon--login {
  width: 2.2rem;
}
@media (hover: hover) {
  .entry-button:hover, .entry-button:focus-visible {
    background-position: left top;
    background-size: 100% 100%;
    color: #d50028;
  }
}

.access-section {
  background: #d50028;
}
.access-section .section-title {
  margin-bottom: 0;
}
.access-section .section-title__en {
  font-size: 3.8rem;
  letter-spacing: 0.1em;
}
.access-section__lead {
  margin-top: 1.8rem;
  color: #fff;
  text-align: center;
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.9;
}
.access-list {
  display: grid;
  gap: 6rem;
  margin-top: 3.5rem;
}
.access-card {
  text-align: center;
}
.access-card__area {
  color: #00a6e9;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.5;
}
.access-card__map {
  margin-top: 1.4rem;
  background: #898989;
}
.access-card__map iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 1.45;
  border: 0;
}
.access-card__title {
  margin: 1.5rem 0;
  color: #fff;
  font-size: 3rem;
  line-height: 1.35;
}
.access-card__address {
  margin-top: 0.8rem;
  font-size: 1.5rem;
  line-height: 1.7;
}

.info-section {
  padding: 6rem 0 8rem;
  color: #00a6e9;
  background: #c30025;
}
.info-section .section-title {
  margin-bottom: 4rem;
}
.info-links {
  display: grid;
  gap: 1.5rem;
}
.info-links a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: 6.5rem;
  padding: 1.2rem 2rem 1.2rem 6.4rem;
  --motion-band: #00a6e9;
  color: #d50028;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.2;
  text-align: center;
  background-color: #fff;
  background-image: linear-gradient(var(--motion-band), var(--motion-band));
  background-repeat: no-repeat;
  background-size: 0 100%;
  background-position: right top;
  transition: background-size 0.36s cubic-bezier(0.4, 0, 0.2, 1), color 0.36s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.36s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.36s cubic-bezier(0.4, 0, 0.2, 1);
}
@media (hover: hover) {
  .info-links a:hover, .info-links a:focus-visible {
    background-position: left top;
    background-size: 100% 100%;
  }
}
.info-links img {
  position: absolute;
  top: 50%;
  left: 2rem;
  width: 3.2rem;
  margin-right: 0;
  transform: translateY(-50%);
}
.info-links img[src*=magazine] {
  width: 2.8rem;
}
.info-links span {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  font-size: inherit;
  line-height: 1.2;
}
.info-links small {
  font-size: 1rem;
  line-height: 1.2;
}
.info-sns {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 2rem;
  margin-top: 3rem;
  padding-bottom: 1.2rem;
  border-bottom: 1px solid #f07e94;
}
.info-sns__label {
  margin: 0;
  color: #fff;
}
.info-sns__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 2rem;
}
.info-sns img {
  width: auto;
  height: 2.6rem;
}
.info-sns a {
  display: block;
  transition: opacity 0.3s;
}
@media (hover: hover) {
  .info-sns a:hover, .info-sns a:focus-visible {
    opacity: 0.65;
  }
}

.oc-footer {
  padding: 2.5rem 2rem;
  color: #d50028;
  background: #00a6e9;
}
.oc-footer__inner {
  display: grid;
  justify-items: center;
  align-items: center;
  gap: 2rem;
  text-align: center;
}
.oc-footer__copy {
  font-size: 1.2rem;
  line-height: 1.2;
}
.oc-footer__logo img {
  width: 28rem;
  filter: brightness(0) saturate(100%) invert(15%) sepia(93%) saturate(5837%) hue-rotate(340deg) brightness(86%) contrast(111%);
}
.oc-footer__links {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
  font-size: 1.4rem;
  font-weight: 500;
}
.oc-footer a {
  transition: opacity 0.3s;
}
@media (hover: hover) {
  .oc-footer a:hover, .oc-footer a:focus-visible {
    opacity: 0.65;
  }
}

.oc-animate {
  opacity: 0;
  transform: translate3d(0, 2.8rem, 0);
  transition: opacity 0.72s cubic-bezier(0.25, 1, 0.5, 1) var(--oc-delay, 0s), transform 0.72s cubic-bezier(0.25, 1, 0.5, 1) var(--oc-delay, 0s);
  will-change: opacity, transform;
}
.oc-animate.is-show {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}
.oc-animate.reserve-link, .oc-animate.download-link {
  transition: opacity 0.72s cubic-bezier(0.25, 1, 0.5, 1) var(--oc-delay, 0s), transform 0.72s cubic-bezier(0.25, 1, 0.5, 1) var(--oc-delay, 0s), background-size 0.36s cubic-bezier(0.4, 0, 0.2, 1), color 0.36s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.36s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (hover: hover) {
  .hover-opacity.oc-animate.is-show:hover, .hover-opacity.oc-animate.is-show:focus-visible {
    opacity: 0.6;
  }
}

.fv-char {
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
}
.fv-char__inner {
  display: inline-block;
  opacity: 0;
  transform: translateY(110%);
  backface-visibility: hidden;
  will-change: transform, opacity;
}

.fv-text-reveal .fv-char__inner {
  backface-visibility: hidden;
}
.fv-text-reveal.oc-animate {
  opacity: 1;
  transform: none;
  transition: none;
}

.fv-text-reveal.oc-animate.is-show .fv-char__inner,
.oc-animate.is-show .fv-text-reveal .fv-char__inner,
.oc-hero.is-show .fv-text-reveal .fv-char__inner {
  animation: fv-char-rise 0.92s cubic-bezier(0.19, 1, 0.22, 1) both;
  animation-delay: var(--char-delay, 0s);
}

.fv-catch-reveal {
  opacity: 0;
  transform: translate3d(0, 2.5rem, 0);
  transition: opacity 0.66s cubic-bezier(0.25, 1, 0.5, 1), transform 0.66s cubic-bezier(0.25, 1, 0.5, 1);
  transition-delay: var(--hero-catch-delay, 1.2s);
}

.oc-hero.is-show .fv-catch-reveal {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.reveal-char {
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
}
.reveal-char__inner {
  display: inline-block;
  opacity: 0;
  transform: translateY(110%);
  backface-visibility: hidden;
  will-change: transform, opacity;
}

.text-reveal .reveal-char__inner {
  backface-visibility: hidden;
}
.text-reveal.oc-animate {
  opacity: 1;
  transform: none;
  transition: none;
}

.text-reveal.oc-animate.is-show .reveal-char__inner,
.oc-animate.is-show .text-reveal .reveal-char__inner {
  animation: text-char-rise 0.82s cubic-bezier(0.19, 1, 0.22, 1) both;
  animation-delay: var(--reveal-char-delay, 0s);
}

.info-links a.oc-animate {
  transition: opacity 0.72s cubic-bezier(0.25, 1, 0.5, 1) var(--oc-delay, 0s), transform 0.72s cubic-bezier(0.25, 1, 0.5, 1) var(--oc-delay, 0s), background-size 0.36s cubic-bezier(0.4, 0, 0.2, 1), color 0.36s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes fv-char-rise {
  0% {
    opacity: 0;
    transform: translateY(110%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes text-char-rise {
  0% {
    opacity: 0;
    transform: translateY(110%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .oc-animate,
  .fv-char__inner,
  .reveal-char__inner {
    animation: none !important;
    opacity: 1;
    transform: none;
    transition: none !important;
  }
}
