/**
 * オープンキャンパス（リニューアル）専用スタイル
 */

:root {
  --oc-red: #ff0000;
  --oc-red-dark: #cc0000;
  --oc-black: #111111;
  --oc-gray: #666666;
  --oc-gray-light: #f5f5f5;
  --oc-border: #dddddd;
  --oc-container: min(1200px, calc(100% - 3rem));
  --oc-font: "Noto Sans JP", sans-serif;
  --oc-font-en: "Jost", "Noto Sans JP", sans-serif;
  /* footer-renewal.css .footer__group SP 高さと揃える */
  --oc-footer-group-height-sp: 60px;
  --oc-sticky-cta-height-sp: 25.9707vw;
}

/* OC ページ：SPは共通追従メニューを非表示、OC追従CTAのみ表示 */
body.is-open-campus .l-body--open-campus {
  margin-top: 0;
}

body.is-open-campus .p-footer,
body.is-open-campus .footer {
  margin-top: 0;
}

@media (max-width: 767px) {
  /* AUN #39: 共通追従メニューは非表示（OC追従CTAは表示） */
  body.is-open-campus .footer__group {
    display: none !important;
  }

  body.is-open-campus {
    --oc-sticky-cta-height-sp: 18.1333vw;
    padding-bottom: var(--oc-sticky-cta-height-sp);
  }

  /* 次回スケジュールなし：追従CTA用余白を解除し、共通追従メニューを復帰 */
  body.is-open-campus.is-oc-no-next-schedule {
    padding-bottom: 0;
  }

  body.is-open-campus.is-oc-no-next-schedule .footer__group {
    display: block !important;
  }

  body.is-open-campus.is-oc-no-next-schedule .footer,
  body.is-open-campus.is-oc-no-next-schedule .p-footer {
    padding-bottom: 32px;
  }

  body.is-open-campus .oc-sticky-cta.is-visible {
    bottom: 0;
  }

  /* AUN #40: OC追従CTAの上下パディングを極力削る */
  body.is-open-campus .oc-sticky-cta__inner {
    gap: 0.8vw;
    padding: 1.0667vw 4.2667vw 1.6vw;
  }

  body.is-open-campus .oc-sticky-cta__text {
    font-size: 1.2rem;
    line-height: 1.25;
  }

  body.is-open-campus .oc-sticky-cta__btn {
    font-size: 1.2rem;
    min-height: 9.6vw;
    padding: 0.8vw 4.2667vw;
  }

  body.is-open-campus .footer,
  body.is-open-campus .p-footer {
    padding-bottom: calc(var(--oc-sticky-cta-height-sp) + 32px);
  }
}

@media (min-width: 768px) {
  body.is-open-campus {
    padding-bottom: 6.74rem;
  }
}

.oc-page {
  font-family: var(--oc-font);
  color: var(--oc-black);
  overflow-x: hidden;
}

.oc-container {
  width: var(--oc-container);
  margin-inline: auto;
}

.oc-u-sp {
  display: inline;
}

.oc-u-pc-only {
  display: none;
}

.oc-u-visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.oc-section {
  padding-block: clamp(3rem, 6vw, 5rem);
}

.oc-section__title {
  font-family: var(--oc-font-en);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-bottom: 2rem;
}

.oc-section__title--white {
  color: #fff;
}

.oc-btn {
  align-items: center;
  border: 2px solid transparent;
  border-radius: 999px;
  display: inline-flex;
  font-size: 0.9375rem;
  font-weight: 700;
  justify-content: center;
  min-height: 3rem;
  min-width: 11rem;
  padding: 0.75rem 1.5rem;
  text-decoration: none;
  transition: background-color 0.2s, color 0.2s, border-color 0.2s;
}

.oc-btn--primary {
  background: var(--oc-red);
  color: #fff;
}

.oc-btn--primary:hover {
  background: var(--oc-red-dark);
  color: #fff;
}

.oc-btn--outline {
  background: #fff;
  border-color: var(--oc-red);
  color: var(--oc-red);
}

.oc-btn--outline:hover {
  background: var(--oc-red);
  color: #fff;
}

.oc-btn--white {
  background: #fff;
  border-color: #fff;
  color: var(--oc-red);
}

.oc-btn--white:hover {
  background: #fff;
  color: var(--oc-red);
}

.oc-btn--black {
  background: #111;
  color: #fff;
}

.oc-btn--black:hover {
  background: #333;
  color: #fff;
}

/* ========== Hero（Figma PC/SP + index assets） ========== */
.oc-hero {
  isolation: isolate;
  overflow-x: hidden;
  position: relative;
}

.oc-hero__inner {
  margin-inline: auto;
  max-width: 1360px;
  position: relative;
  z-index: 1;
}

.oc-hero__photo {
  display: block;
  margin: 0;
}

.oc-hero::after {
  display: none;
}

.oc-hero__breadcrumb {
  position: relative;
  z-index: 2;
}

/* ----- Hero SP（375px基準 vw） ----- */
@media (max-width: 767px) {
  .oc-hero__bg {
    height: 140.8vw;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
  }

  .oc-hero__bg-img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: 34% 14%;
    width: 100%;
  }

  .oc-hero__inner {
    padding-top: calc(54px + 8vw);
    position: relative;
    z-index: 1;
    transition: .3s;
  }

  .oc-hero__content {
    min-height: 123.7333vw;
    padding: 0 4.2667vw;
    position: relative;
    width: 100%;
    z-index: 2;
  }

  .oc-hero__title {
    line-height: 0;
    margin: 0 0 0;
  }

  .oc-hero__title-img {
    display: block;
    height: auto;
    max-width: 74.6667vw;
    width: 74.6667vw;
  }

  .oc-hero__lead {
    color: #e50012;
    font-feature-settings: "palt" 1;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    line-height: 1.45;
    margin: 0 0 4.8vw;
    max-width: 53.6vw;
  }

  .oc-hero__meta {
    align-items: stretch;
    border-radius: 0.4rem;
    flex-direction: column;
    gap: 0;
    overflow: hidden;
    padding: 0;
    width: 41.6vw;
    max-width: 41.6vw;
  }

  .oc-hero__next {
    display: flex;
    flex-shrink: 0;
    font-size: 1.2rem;
    justify-content: center;
    letter-spacing: 0.12em;
    line-height: 1;
    margin: 0;
    min-height: 1.7rem;
    padding: 0.25rem 0.75rem;
    border-radius: 0;
  }

  .oc-hero__date,
  .oc-hero__time {
    color: var(--oc-black);
    font-weight: 700;
    line-height: 1.4;
    margin: 0;
  }

  .oc-hero__date {
    font-size: 1.5rem;
    padding: 0.4rem 0.5rem 0;
    text-align: center;
  }

  .oc-hero__time {
    color: #666;
    font-family: var(--oc-font-en);
    font-size: 1.1rem;
    font-weight: 400;
    letter-spacing: 0.02em;
    padding: 0 0.5rem 0.4rem;
    text-align: center;
  }

  .oc-hero__visual {
    line-height: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 65.6vw;
    width: 82.8vw;
    z-index: 1;
  }

  .oc-hero__photo {
    height: auto;
    width: 100%;
  }

  .oc-hero__actions--sp {
    align-items: flex-start;
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 2.4vw;
    padding: 0 4.2667vw;
    position: relative;
    width: 100%;
    z-index: 3;
  }

  .oc-hero__actions--sp .oc-hero__p-btn {
    align-items: center;
    box-sizing: border-box;
    flex: 0 0 44.5333vw;
    font-size: 1.2rem;
    height: 15.2vw;
    justify-content: center;
    letter-spacing: 0.04em;
    line-height: 1.25;
    max-height: 15.2vw;
    max-width: none;
    min-height: 15.2vw;
    min-width: 0;
    overflow: hidden;
    padding: 0.4rem 0.4rem;
    text-align: center;
    width: 44.5333vw;
  }

  .oc-hero__breadcrumb {
    align-items: center;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    margin-top: 5.8667vw;
    min-height: 9.3333vw;
    padding: 0 4.2667vw;
  }
}
.oc-hero__p-btn--fill {
  background: var(--oc-black);
  border-color: var(--oc-black);
  color: #fff;
}

.oc-hero__p-btn--fill::before {
  background-color: #333;
}

.oc-hero__p-btn--fill::after {
  border-color: transparent transparent #fff transparent;
}

.oc-hero__p-btn--fill:hover {
  background: var(--oc-black);
  border-color: var(--oc-black);
  color: #fff;
}

.oc-hero__p-btn--fill.is-disabled {
  background: #e8e8e8;
  border-color: #ccc;
  color: #999;
  cursor: not-allowed;
  pointer-events: none;
}

.oc-hero__p-btn--fill.is-disabled::before,
.oc-hero__p-btn--fill.is-disabled::after {
  display: none;
}

.oc-hero__p-btn--outline {
  background: #fff;
  border-color: var(--oc-black);
  color: var(--oc-black);
}

.oc-hero__p-btn--outline::before {
  background-color: var(--oc-black);
}

.oc-hero__p-btn--outline::after {
  border-color: transparent transparent var(--oc-black) transparent;
}

.oc-hero__p-btn--outline:hover {
  background: #fff;
  border-color: var(--oc-black);
  color: #fff;
}

.oc-hero__meta {
  display: flex;
  background: #fff;
  border: 1px solid #E50012;
  overflow: hidden;
}

button.oc-hero__meta {
  appearance: none;
  color: inherit;
  cursor: pointer;
  font: inherit;
  margin: 0;
  padding: 0;
  text-align: inherit;
  transition: opacity 0.2s ease;
}

button.oc-hero__meta:hover {
  opacity: 0.88;
}

.oc-hero__next {
  align-items: center;
  background: #E50012;
  color: #fff;
  display: flex;
  font-family: var(--oc-font-en);
  font-weight: 700;
  justify-content: center;
  letter-spacing: 0.12em;
  line-height: 1;
  margin: -1px 0 0;
}

.oc-hero__date,
.oc-hero__time {
  color: var(--oc-black);
  font-weight: 700;
  margin: 0;
}

.oc-hero__breadcrumb .l-breadcrumb {
  background: transparent;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 400;
  margin: 0;
  padding: 0;
  white-space: nowrap;
  width: 100%;
}

.oc-hero__breadcrumb .l-breadcrumb__inner {
  margin: 0;
  max-width: none;
  padding: 0;
  width: auto;
}

.oc-hero__breadcrumb .l-breadcrumb__container {
  -ms-overflow-style: none;
  overflow: auto;
  scrollbar-width: none;
}

.oc-hero__breadcrumb .l-breadcrumb__container::-webkit-scrollbar {
  display: none;
}

.oc-hero__breadcrumb .l-breadcrumb__list {
  height: auto;
  justify-content: flex-start;
  margin: 0;
  max-width: 100%;
  min-height: 16px;
  padding: 0;
  width: max-content;
}

.oc-hero__breadcrumb .l-breadcrumb__item {
  align-items: center;
  color: #fff;
  display: flex;
}

.oc-hero__breadcrumb .l-breadcrumb__item:first-child .l-breadcrumb__link::before {
  display: none;
}

.oc-hero__breadcrumb .l-breadcrumb__item:not(:last-child)::after {
  background: #fff;
  content: "";
  display: inline-block;
  flex-shrink: 0;
  height: 1px;
  margin: 0 10px;
  width: 12px;
}

.oc-hero__breadcrumb .l-breadcrumb__link {
  color: #fff;
  text-decoration: none;
}

.oc-hero__breadcrumb .l-breadcrumb__link:hover {
  opacity: 0.8;
}

/* ========== Topics ========== */
.oc-topics__list {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-topic-card {
  border: 1px solid var(--oc-border);
  display: grid;
  gap: 1rem;
  grid-template-columns: 120px 1fr;
  padding: 1rem;
}

.oc-topic-card__thumb {
  aspect-ratio: 1;
  background: var(--oc-gray-light);
}

.oc-topic-card__tag {
  color: var(--oc-red);
  font-size: 0.75rem;
  font-weight: 700;
  margin: 0 0 0.25rem;
}

.oc-topic-card__date {
  color: var(--oc-gray);
  display: block;
  font-size: 0.8125rem;
  margin-bottom: 0.5rem;
}

.oc-topic-card__title {
  font-size: 0.9375rem;
  font-weight: 700;
  margin: 0;
}

/* ========== About Open Campus（Figma PC 1440 / SP 375） ========== */
.oc-about {
  background: #fff;
  overflow: visible;
  position: relative;
}

.oc-about__inner {
  margin-inline: auto;
  max-width: 1440px;
  overflow: visible;
}

.oc-about__intro {
  position: relative;
}

.oc-about__head {
  position: relative;
  text-align: center;
  z-index: 2;
}

.oc-about__label {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-about__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-about__lead {
  line-height: 1.8;
  margin: 0;
}

.oc-about__lead-em {
  color: var(--oc-red);
  font-weight: 700;
}

.oc-about__deco {
  display: none;
  height: auto;
  pointer-events: none;
  position: absolute;
}

.oc-about__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-about-card {
  position: relative;
  z-index: 2;
}

.oc-about-card__media {
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.oc-about-card__img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.oc-about-card__num {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 700;
  left: 50%;
  line-height: 1;
  margin: 0;
  position: absolute;
  text-align: center;
  transform: translate(-50%, -50%);
  z-index: 3;
}

.oc-about-card__body {
  background: var(--oc-gray-light);
  box-sizing: border-box;
  position: relative;
  z-index: 2;
}

.oc-about-card__title {
  font-weight: 700;
  margin: 0;
  text-align: center;
}

.oc-about-card__text {
  color: var(--oc-gray);
  line-height: 1.8;
  margin: 0;
  text-align: center;
}

/* ========== Flow & Schedule（Figma PC 1440 / SP 375） ========== */
.oc-flow {
  background: var(--oc-red);
  color: #fff;
  position: relative;
  z-index: 0;
}

.oc-flow__inner {
  margin-inline: auto;
  max-width: 1440px;
}

.oc-flow__head {
  text-align: center;
}

.oc-flow__label {
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-flow__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-flow__steps {
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-flow__step {
  text-align: center;
}

.oc-flow__num {
  font-family: var(--oc-font-en);
  font-weight: 700;
  line-height: 1;
  margin: 0;
}

.oc-flow__name {
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-flow__time {
  font-family: var(--oc-font-en);
  font-weight: 500;
  line-height: 1.4;
  margin: 0;
}

.oc-flow__divider {
  align-items: center;
  display: flex;
  justify-content: center;
  list-style: none;
  position: relative;
}

.oc-flow__line {
  background: rgba(255, 255, 255, 0.45);
  display: block;
}

.oc-flow__arrow {
  display: block;
  flex-shrink: 0;
  height: auto;
}

.oc-flow__steps--sp {
  display: none;
}

/* ----- Flow SP（375px基準 vw） ----- */
@media (max-width: 767px) {
  .oc-flow {
    margin-top: 0;
    padding: 10.1333vw 4.2667vw 17.6vw;
  }

  .oc-flow__label {
    font-size: 1.3rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-flow__title {
    font-size: 2rem;
    line-height: 1.5;
    margin-bottom: 7.7333vw;
  }

  .oc-flow__steps--pc {
    display: none;
  }

  .oc-flow__steps--sp {
    display: block;
    width: 100%;
  }

  .oc-flow__steps--sp .oc-flow__step {
    align-items: center;
    display: grid;
    gap: 0 3.2vw;
    grid-template-columns: 11.7333vw minmax(0, 1fr) auto;
    padding-block: 2.4vw;
    text-align: left;
  }

  .oc-flow__steps--sp .oc-flow__num {
    font-size: 3.4rem;
    text-align: left;
  }

  .oc-flow__steps--sp .oc-flow__name {
    font-size: 1.8rem;
    text-align: left;
  }

  .oc-flow__steps--sp .oc-flow__time {
    font-size: 1.6rem;
    justify-self: end;
    text-align: right;
    white-space: nowrap;
  }

  .oc-flow__steps--sp .oc-flow__divider {
    height: 4.8vw;
    margin: 0.5333vw -4.2667vw;
    width: calc(100% + 8.5334vw);
  }

  .oc-flow__steps--sp .oc-flow__line {
    height: 1px;
    left: 0;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }

  .oc-flow__steps--sp .oc-flow__arrow {
    position: relative;
    transform: rotate(90deg);
    width: 5.8667vw;
    z-index: 1;
  }
}

/* ----- Flow PC（rem/px） ----- */
@media (min-width: 768px) {
  .oc-flow {
    margin-top: -12.9rem;
    padding: 20.7rem 13.5rem 8rem;
  }

  .oc-flow__label {
    font-size: 2rem;
    margin-bottom: 1.2rem;
  }

  .oc-flow__title {
    font-size: 3.6rem;
    margin-bottom: 4.4rem;
  }

  .oc-flow__steps--pc {
    align-items: stretch;
    display: flex;
    justify-content: center;
  }

  .oc-flow__steps--pc .oc-flow__step {
    flex: 1 1 0;
    max-width: 18.1rem;
    min-width: 0;
    padding: 0 0.8rem;
  }

  .oc-flow__steps--pc .oc-flow__num {
    font-size: 2.8rem;
    margin-bottom: 1.6rem;
  }

  .oc-flow__steps--pc .oc-flow__name {
    font-size: 1.6rem;
    margin-bottom: 0.8rem;
  }

  .oc-flow__steps--pc .oc-flow__time {
    font-size: 1.4rem;
    opacity: 0.92;
  }

  .oc-flow__steps--pc .oc-flow__divider {
    flex: 0 0 2.2rem;
    width: 2.2rem;
  }

  .oc-flow__steps--pc .oc-flow__line {
    bottom: 0;
    left: 50%;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: 1px;
  }

  .oc-flow__steps--pc .oc-flow__arrow {
    position: relative;
    width: 2.2rem;
    z-index: 1;
  }
}

/* ----- About SP（375px基準 vw） ----- */
@media (max-width: 767px) {
  .oc-about {
    padding: 8vw 0 8.5333vw;
  }

  .oc-about__inner {
    padding-inline: 4.2667vw;
  }

  .oc-about__intro {
    margin-bottom: 0;
  }

  .oc-about__head {
    margin-bottom: 0;
  }

  .oc-about__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 1.0667vw;
  }

  .oc-about__title {
    font-size: 2rem;
    line-height: 1.5;
    margin-bottom: 4.8vw;
  }

  .oc-about__lead {
    font-size: 1.3rem;
    line-height: 1.85;
    margin-bottom: 6.4vw;
  }

  .oc-about__list {
    display: grid;
    gap: 4.8vw;
  }

  .oc-about-card__media {
    height: 56.4853vw;
  }

  .oc-about-card__num {
    font-size: 4.8rem;
    top: 56.4853vw;
  }

  .oc-about-card__body {
    margin-top: 0;
    min-height: 0;
    padding: 8.5333vw 7.2vw 3.2vw;
  }

  .oc-about-card__title {
    font-size: 1.7rem;
    line-height: 1.45;
    margin-bottom: 1.6vw;
  }

  .oc-about-card__text {
    font-size: 1.3rem;
    line-height: 1.75;
  }
}

/* ----- About PC（rem/px） ----- */
@media (min-width: 768px) {
  .oc-about {
    padding: 4rem 0 0;
  }

  .oc-about__inner {
    padding-inline: 13.5rem;
  }

  .oc-about__intro {
    margin-bottom: 0;
    position: relative;
  }

  .oc-about__head {
    margin-bottom: 0;
    margin-inline: auto;
    max-width: 44.5rem;
  }

  .oc-about__label {
    font-size: 2rem;
    margin-bottom: 1.2rem;
  }

  .oc-about__title {
    font-size: 3.6rem;
    margin-bottom: 2.9rem;
  }

  .oc-about__lead {
    font-size: 1.6rem;
    margin-bottom: 48px;
  }

  .oc-about__deco {
    display: block;
  }

  .oc-about__deco--left {
    bottom: -48px;
    left: min(96px, calc(50% - 22.25rem - 18.6rem - 2.4rem));
    width: 18.6rem;
    z-index: 1;
  }

  .oc-about__deco--right {
    bottom: -48px;
    right: min(31px, calc(50% - 22.25rem - 22rem - 2.4rem));
    width: 22rem;
    z-index: 1;
  }

  .oc-about__list {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(4, 28.5rem);
    justify-content: center;
    margin-bottom: 0;
    position: relative;
    z-index: 2;
  }

  .oc-about-card__media {
    height: 17.6rem;
  }

  .oc-about-card__num {
    font-size: 4rem;
    top: 17.6rem;
  }

  .oc-about-card__body {
    margin-top: 0;
    min-height: 22.6rem;
    padding: 3.6rem 2.5rem 2.4rem;
  }

  .oc-about-card__title {
    font-size: 1.6rem;
    line-height: 1.5;
    margin-bottom: 1.2rem;
    text-align: center;
  }

  .oc-about-card__text {
    font-size: 1.4rem;
    line-height: 1.75;
    text-align: left;
  }
}

/* ========== Next ========== */
.oc-next {
  background: var(--oc-red);
  color: #fff;
}

.oc-next__inner {
  text-align: center;
}

.oc-next__label {
  font-family: var(--oc-font-en);
  font-size: clamp(1.25rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: 0.12em;
  margin: 0 0 0.5rem;
}

.oc-next__date {
  font-family: var(--oc-font-en);
  font-size: clamp(2rem, 6vw, 4rem);
  font-weight: 700;
  margin: 0 0 1rem;
}

.oc-next__dow {
  font-size: 0.45em;
  letter-spacing: 0.08em;
  margin-left: 0.5rem;
}

.oc-next__times {
  display: flex;
  gap: 2rem;
  justify-content: center;
  margin: 0;
}

.oc-next__times div {
  text-align: center;
}

.oc-next__times dt {
  font-family: var(--oc-font-en);
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  margin-bottom: 0.25rem;
}

.oc-next__times dd {
  font-family: var(--oc-font-en);
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0;
}

/* ========== Pickup（Figma PC 1440 / SP 375） ========== */
.oc-pickup {
  background: var(--oc-gray-light);
  overflow: hidden;
}

.oc-pickup__inner {
  margin-inline: auto;
  max-width: 1440px;
}

.oc-pickup__title {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.3em;
  margin: 0;
  text-align: center;
}

.oc-pickup__slider {
  overflow: visible;
}

.oc-pickup__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-pickup-card {
  background: #fff;
  border: 1px solid var(--oc-border);
  box-sizing: border-box;
  display: flex;
  height: 100%;
}

.oc-pickup-card.js-oc-modal-open {
  cursor: pointer;
}

.oc-pickup-card--static {
  cursor: default;
}

.oc-pickup-card__more.is-coming-soon {
  background: #e8e8e8;
  border: 1px solid #ccc;
  color: #999;
  cursor: not-allowed;
  display: inline-flex;
  font-family: var(--oc-font-en);
  font-size: 1.2rem;
  letter-spacing: 0.04em;
  pointer-events: none;
  text-transform: uppercase;
}

.oc-pickup-card__media {
  background-color: #d9d9d9;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  flex-shrink: 0;
}

.oc-pickup-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
}

.oc-pickup-card__year {
  color: var(--oc-gray);
  font-weight: 400;
  line-height: 1.2;
  margin: 0;
}

.oc-pickup-card__date {
  align-items: baseline;
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  line-height: 1.1;
  margin: 0;
}

.oc-pickup-card__date-main {
  color: var(--oc-red);
  font-weight: 700;
}

.oc-pickup-card__date-dow {
  color: var(--oc-red);
  font-weight: 700;
}

.oc-pickup-card__title {
  font-weight: 700;
  margin: 0;
}

.oc-pickup-card__text {
  color: var(--oc-gray);
  margin: 0;
}

.oc-pickup-card__more {
  align-self: flex-start;
  background: #fff;
  border: 1px solid var(--oc-red);
  color: var(--oc-red);
  cursor: pointer;
  font-family: var(--oc-font);
  font-weight: 700;
  line-height: 1.4;
  margin-top: auto;
  padding: 0;
  text-align: center;
}

.oc-pickup-card__more:hover {
  background: var(--oc-red);
  color: #fff;
}

/* ----- Pickup SP（375px基準 vw） ----- */
@media (max-width: 767px) {
  .oc-pickup {
    overflow: visible;
    padding: 8.2667vw 0 10.6667vw;
  }

  .oc-pickup__title {
    font-size: 1.8rem;
    margin-bottom: 4.2667vw;
  }

  .oc-pickup__slider.swiper {
    overflow: visible;
  }

  .oc-pickup__item.swiper-slide {
    width: 78.4427vw;
  }

  .oc-pickup-card {
    gap: 4.8vw;
    min-height: 39.7333vw;
    padding: 5.0667vw 4.2667vw;
  }

  .oc-pickup-card__media {
    height: 28.8787vw;
    width: 23.7579vw;
  }

  .oc-pickup-card__body {
    gap: 1.0667vw;
  }

  .oc-pickup-card__year {
    font-size: 1.1rem;
  }

  .oc-pickup-card__date-main {
    font-size: 1.6rem;
  }

  .oc-pickup-card__date-dow {
    font-size: 1.2rem;
  }

  .oc-pickup-card__title {
    font-size: 1.4rem;
    line-height: 1.4;
  }

  .oc-pickup-card__text {
    font-size: 1.1rem;
    line-height: 1.45;
  }

  .oc-pickup-card__more {
    font-size: 1.2rem;
    margin-top: 1.6vw;
    min-height: 6.3147vw;
    min-width: 22.9387vw;
    padding: 1.024vw 4.936vw;
  }
}

/* ----- Pickup PC（rem/px） ----- */
@media (min-width: 768px) {
  .oc-pickup {
    padding: 4.5rem 13.6rem 4.8rem;
  }

  .oc-pickup__title {
    font-size: 2.2rem;
    margin-bottom: 2.7rem;
  }

  .oc-pickup__slider.swiper {
    overflow: visible;
  }

  .oc-pickup__list.swiper-wrapper {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, 38.3rem);
    transform: none !important;
    justify-content: center;
  }

  .oc-pickup__item.swiper-slide {
    height: auto;
    margin: 0 !important;
    width: auto !important;
  }

  .oc-pickup-card {
    gap: 2.2rem;
    min-height: 19.4rem;
    padding: 2.9rem 2.4rem;
  }

  .oc-pickup-card__media {
    height: 14.1rem;
    width: 11.6rem;
  }

  .oc-pickup-card__body {
    gap: 0.4rem;
  }

  .oc-pickup-card__year {
    font-size: 1.2rem;
  }

  .oc-pickup-card__date-main {
    font-size: 2rem;
  }

  .oc-pickup-card__date-dow {
    font-size: 1.4rem;
  }

  .oc-pickup-card__title {
    font-size: 1.8rem;
    line-height: 1.5;
  }

  .oc-pickup-card__text {
    font-size: 1.2rem;
    line-height: 1.45;
  }

  .oc-pickup-card__more {
    font-size: 1.4rem;
    margin-top: 0.4rem;
    min-height: 3rem;
    min-width: 11.2rem;
    padding: 0.5rem 2.4rem;
  }
}

/* ========== Schedule（Figma PC 1440 / SP 375） ========== */
#oc-schedule {
  scroll-margin-top: 8rem;
}

.oc-schedule {
  background: var(--oc-gray-light);
}

.oc-schedule__inner {
  margin-inline: auto;
  max-width: 1440px;
}

.oc-schedule__head {
  text-align: center;
}

.oc-schedule__label {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-schedule__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-schedule__grid {
  display: grid;
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-schedule-card {
  background: #fff;
  border: 1px solid var(--oc-border);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  height: 100%;
  position: relative;
}

.oc-schedule-card--next {
  border-color: var(--oc-red);
}

.oc-schedule-card__open {
  appearance: none;
  background: transparent;
  border: 0;
  color: inherit;
  cursor: pointer;
  display: flex;
  flex: 1;
  flex-direction: column;
  font: inherit;
  margin: 0;
  padding: 0;
  text-align: inherit;
  width: 100%;
}

.oc-schedule-card__open--static {
  cursor: default;
}

.oc-schedule-card__more.is-coming-soon {
  background: #e8e8e8;
  border: 1px solid #ccc;
  color: #999;
  cursor: not-allowed;
  font-family: var(--oc-font-en);
  font-size: 1.2rem;
  letter-spacing: 0.04em;
  pointer-events: none;
  text-transform: uppercase;
}

.oc-schedule-card__badge {
  background: var(--oc-red);
  color: #fff;
  font-family: var(--oc-font-en);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  margin: 0;
  position: absolute;
  right: 0;
  text-align: center;
  top: 0;
  z-index: 1;
}

.oc-schedule-card__year {
  color: var(--oc-gray);
  font-weight: 400;
  margin: 0;
}

.oc-schedule-card__date {
  align-items: flex-end;
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin: 0;
}

.oc-schedule-card__date-main {
  color: var(--oc-black);
  font-weight: 700;
  line-height: 1;
}

.oc-schedule-card__dow {
  color: var(--oc-black);
  font-weight: 400;
  line-height: 1;
}

.oc-schedule-card__theme {
  border: 0;
  border-top: 1px solid var(--oc-border);
  color: var(--oc-black);
  margin: 0;
  text-align: left;
}

.oc-schedule-card__actions {
  display: flex;
  gap: 0.7rem;
  margin-top: auto;
}

.oc-schedule-card__apply,
.oc-schedule-card__more {
  align-items: center;
  border-radius: 0;
  box-sizing: border-box;
  display: inline-flex;
  flex: 1 1 0;
  font-family: var(--oc-font);
  font-weight: 700;
  justify-content: center;
  line-height: 1.4;
  min-width: 0;
  padding: 0;
  text-align: center;
  text-decoration: none;
}

.oc-schedule-card__apply {
  background: var(--oc-red);
  border: 1px solid var(--oc-red);
  color: #fff;
}

.oc-schedule-card__more {
  background: #fff;
  border: 1px solid var(--oc-red);
  color: var(--oc-red);
  cursor: pointer;
}

.oc-schedule-card__apply:hover {
  background: var(--oc-red-dark);
  border-color: var(--oc-red-dark);
  color: #fff;
}

.oc-schedule-card__apply.is-disabled {
  background: #e8e8e8;
  border-color: #ccc;
  color: #999;
  cursor: not-allowed;
  pointer-events: none;
}

.oc-schedule-card__more:hover {
  background: var(--oc-red);
  color: #fff;
}

/* ----- Schedule SP（375px基準 vw） ----- */
@media (max-width: 767px) {
  .oc-schedule {
    padding: 12vw 4.2667vw 18.6667vw;
  }

  .oc-schedule__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-schedule__title {
    font-size: 2rem;
    margin-bottom: 6.4vw;
  }

  .oc-schedule__grid {
    gap: 2.0267vw;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .oc-schedule-card {
    min-height: 33.752vw;
    padding: 2.7vw 2.7vw 2.4vw;
  }

  .oc-schedule-card__badge {
    font-size: 1.1rem;
    min-width: 9.9566vw;
    padding: 0.5vw 1.2vw;
  }

  .oc-schedule-card__year {
    font-size: 1.3rem;
    margin-bottom: 0.8vw;
  }

  .oc-schedule-card__date {
    margin-bottom: 4vw;
  }

  .oc-schedule-card__date-main {
    font-size: 2.6rem;
  }

  .oc-schedule-card__dow {
    font-size: 1.3rem;
    margin-bottom: 0.2rem;
  }

  .oc-schedule-card__theme {
    font-size: 1.2rem;
    margin-bottom: 2.1333vw;
    padding-top: 1.8667vw;
  }

  .oc-schedule-card__actions {
    gap: 1.8667vw;
  }

  .oc-schedule-card__apply,
  .oc-schedule-card__more {
    font-size: 1.1rem;
    min-height: 6.0749vw;
    padding: 0.8vw 0.4vw;
  }
}

/* ----- Schedule PC（rem/px） ----- */
@media (min-width: 768px) {
  .oc-schedule {
    padding: 7.2rem 13.5rem 8rem;
  }

  .oc-schedule__label {
    font-size: 2rem;
    margin-bottom: 1.2rem;
  }

  .oc-schedule__title {
    font-size: 3.6rem;
    margin-bottom: 4.1rem;
  }

  .oc-schedule__grid {
    gap: 1.2rem;
    grid-template-columns: repeat(4, 26.4rem);
    justify-content: center;
  }

  .oc-schedule-card {
    min-height: 20rem;
    padding: 1.6rem 1.6rem 1.4rem;
  }

  .oc-schedule-card__badge {
    font-size: 1.4rem;
    min-width: 5.9rem;
    padding: 0.35rem 0.8rem;
  }

  .oc-schedule-card__year {
    font-size: 1.4rem;
    margin-bottom: 0.5rem;
  }

  .oc-schedule-card__date {
    margin-bottom: 2.3rem;
  }

  .oc-schedule-card__date-main {
    font-size: 4rem;
  }

  .oc-schedule-card__dow {
    font-size: 1.4rem;
    margin-bottom: 0.2rem;
  }

  .oc-schedule-card__theme {
    font-size: 1.2rem;
    margin-bottom: 1.2rem;
    padding-top: 1.1rem;
  }

  .oc-schedule-card__apply,
  .oc-schedule-card__more {
    font-size: 1.4rem;
    min-height: 3.6rem;
    padding: 0.8rem 0.4rem;
  }
}

/* ========== Special Lectures（Figma PC 1440 / SP 375） ========== */
.oc-special {
  background: #fff;
}

.oc-special__inner {
  margin-inline: auto;
  max-width: 1440px;
}

.oc-special__head {
  text-align: center;
}

.oc-special__label {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-special__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-special__lead {
  color: var(--oc-gray);
  font-weight: 400;
  line-height: 1.5;
  margin: 0;
}

.oc-special__list {
  display: grid;
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-special-card {
  align-items: flex-start;
  background: #fff;
  border: 1px solid var(--oc-border);
  box-sizing: border-box;
  display: flex;
  height: 100%;
}

.oc-special-card__media {
  flex-shrink: 0;
  overflow: hidden;
}

.oc-special-card__img {
  border-radius: 50%;
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.oc-special-card__img--placeholder {
  background: #d9d9d9;
}

.oc-special-card__body {
  min-width: 0;
}

.oc-special-card__date {
  color: var(--oc-red);
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-special-card__cat {
  background: var(--oc-red);
  color: #fff;
  display: inline-block;
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-special-card__name {
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-special-card__text {
  color: var(--oc-gray);
  line-height: 1.5;
  margin: 0;
}

/* ----- Special SP（375px基準 vw） ----- */
@media (max-width: 767px) {
  .oc-special {
    padding: 14.4vw 4.2667vw 10.6667vw;
  }

  .oc-special__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-special__title {
    font-size: 2rem;
    margin-bottom: 5.3333vw;
  }

  .oc-special__list {
    gap: 5.3333vw;
    grid-template-columns: minmax(0, 1fr);
  }

  .oc-special-card {
    gap: 5.6vw;
    padding: 6.9333vw 5.6vw;
  }

  .oc-special-card__media {
    border-radius: 50%;
    height: 17.2vw;
    width: 17.2vw;
  }

  .oc-special-card__date {
    font-size: 1.3rem;
    margin-bottom: 1.6vw;
  }

  .oc-special-card__cat {
    font-size: 1.1rem;
    margin-bottom: 2.1333vw;
    padding: 0.8vw 2.4vw;
  }

  .oc-special-card__name {
    font-size: 1.6rem;
    margin-bottom: 1.6vw;
  }

  .oc-special-card__text {
    font-size: 1.2rem;
  }
}

/* ----- Special PC（rem/px） ----- */
@media (min-width: 768px) {
  .oc-special {
    padding: 6.6rem 13.5rem 7.3rem;
  }

  .oc-special__label {
    font-size: 2rem;
    margin-bottom: 1rem;
  }

  .oc-special__title {
    font-size: 3.6rem;
    margin-bottom: 1rem;
  }

  .oc-special__lead {
    font-size: 1.6rem;
    margin-bottom: 3rem;
  }

  .oc-special__list {
    gap: 1.7rem 2rem;
    grid-template-columns: repeat(2, 53.5rem);
    justify-content: center;
  }

  .oc-special-card {
    gap: 2.3rem;
    min-height: 20.4rem;
    padding: 2.9rem 2.3rem;
  }

  .oc-special-card__media {
    border-radius: 50%;
    height: 7rem;
    width: 7rem;
  }

  .oc-special-card__date {
    font-size: 1.4rem;
    margin-bottom: 0.9rem;
  }

  .oc-special-card__cat {
    font-size: 1.2rem;
    margin-bottom: 1rem;
    padding: 0.4rem 1rem;
  }

  .oc-special-card__name {
    font-size: 1.8rem;
    margin-bottom: 0.7rem;
  }

  .oc-special-card__text {
    font-size: 1.4rem;
  }
}

/* Modal（Figma node 4132-4896） */
.oc-modal[hidden] {
  display: none !important;
}

.oc-modal.is-open {
  display: block;
}

.oc-modal {
  inset: 0;
  position: fixed;
  z-index: 200;
}

.oc-modal__overlay {
  background: rgba(0, 0, 0, 0.55);
  inset: 0;
  position: absolute;
}

.oc-modal__frame {
  left: 50%;
  max-height: 90vh;
  max-width: 90rem;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 3.2rem);
  z-index: 1;
}

.oc-modal__dialog {
  background: #fff;
  border-radius: 0;
  max-height: 90vh;
  overflow: hidden;
  padding: 0;
  position: relative;
  width: 100%;
}

.oc-modal__dialog--schedule {
  max-width: none;
}

.oc-modal__scroll {
  max-height: 90vh;
  overflow: auto;
}

.oc-modal__inner {
  box-sizing: border-box;
  margin-inline: auto;
  max-width: 73rem;
  padding: 3.2rem 4rem 4rem;
}

.oc-modal__close {
  background: transparent;
  border: 0;
  color: #fff;
  cursor: pointer;
  font-size: 3.2rem;
  font-weight: 300;
  line-height: 1;
  padding: 0;
  position: absolute;
  right: 0;
  top: 0;
  transform: translateY(calc(-100% - 1.6rem));
  z-index: 2;
}

.oc-modal__head {
  padding: 0;
  text-align: left;
}

.oc-modal__date {
  align-items: baseline;
  display: flex;
  flex-wrap: wrap;
  gap: 0 1.2rem;
  line-height: 1.1;
  margin: 0 0 2rem;
}

.oc-modal__date-year {
  color: var(--oc-black);
  font-size: 1.6rem;
  font-weight: 700;
}

.oc-modal__date-group {
  align-items: baseline;
  display: inline-flex;
  gap: 0.2rem;
}

.oc-modal__date-main {
  color: var(--oc-black);
  font-size: 4.8rem;
  font-weight: 700;
  line-height: 1;
}

.oc-modal__date-dow {
  color: var(--oc-black);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
}

.oc-modal__title {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-modal__time {
  color: var(--oc-gray);
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  margin: 0;
}

.oc-modal__body {
  margin-top: 3.2rem;
  padding: 0;
}

.oc-modal__entry {
  color: var(--oc-black);
  font-size: 1.4rem;
  line-height: 1.8;
}

.oc-modal__entry > :first-child {
  margin-top: 0;
}

.oc-modal__entry > :last-child {
  margin-bottom: 0;
}

.oc-modal__entry img {
  display: block;
  height: auto;
  margin: 2rem 0 0;
  max-width: 100%;
  width: 100%;
}

.oc-modal__entry p {
  margin: 0 0 1.6rem;
}

.oc-modal__apply-wrap,
.oc-modal__footer {
  margin: 0;
}

.oc-modal__apply-wrap {
  margin-top: 2.4rem;
}

.oc-modal__footer {
  margin-top: 4rem;
}

.oc-modal__apply {
  align-items: center;
  background: var(--oc-red);
  border: 0;
  box-sizing: border-box;
  color: #fff;
  display: flex;
  font-size: 1.6rem;
  font-weight: 700;
  justify-content: center;
  letter-spacing: 0.06em;
  line-height: 1.4;
  min-height: 5.6rem;
  overflow: hidden;
  padding: 1.6rem 3.2rem 1.6rem 2.4rem;
  position: relative;
  text-align: center;
  text-decoration: none;
  transition: background-color 0.25s ease;
  width: 100%;
}

.oc-modal__apply::before {
  content: none;
  display: none;
}

.oc-modal__apply::after {
  border-color: transparent transparent #fff transparent;
  border-style: solid;
  border-width: 0 0 12px 12px;
  bottom: 4px;
  content: "";
  height: 0;
  position: absolute;
  right: 4px;
  width: 0;
  z-index: 1;
}

.oc-modal__apply:hover {
  background: var(--oc-red-dark);
  color: #fff;
  text-decoration: none;
}

.oc-modal__apply.is-disabled {
  background: #e8e8e8;
  border: 0;
  color: #999;
  cursor: not-allowed;
  pointer-events: none;
}

.oc-modal__apply.is-disabled::after {
  display: none;
}

.oc-modal__apply-label {
  display: block;
}

.oc-modal__apply-wrap + .oc-modal__section,
.oc-modal__section + .oc-modal__section {
  margin-top: 4rem;
}

.oc-modal__section-title {
  border-bottom: 1px solid var(--oc-red);
  color: var(--oc-red);
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4;
  margin: 0 0 2rem;
  padding-bottom: 1rem;
}

.oc-modal__lesson-list,
.oc-modal__special-list {
  display: grid;
  gap: 1.6rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-modal-lesson-card,
.oc-modal-special-card {
  align-items: flex-start;
  background: #fff;
  border: 1px solid var(--oc-border);
  box-sizing: border-box;
  display: flex;
  gap: 1.6rem;
  height: 100%;
  padding: 1.6rem;
}

.oc-modal-lesson-card__media,
.oc-modal-special-card__media {
  flex-shrink: 0;
  height: 7rem;
  overflow: hidden;
  width: 7rem;
}

.oc-modal-lesson-card__img,
.oc-modal-special-card__img {
  border-radius: 50%;
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.oc-modal-lesson-card__img--placeholder,
.oc-modal-special-card__img--placeholder {
  background: #d9d9d9;
  border-radius: 50%;
  display: block;
  height: 100%;
  width: 100%;
}

.oc-modal-lesson-card__body,
.oc-modal-special-card__body {
  min-width: 0;
}

.oc-modal-special-card__cat {
  background: var(--oc-red);
  color: #fff;
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.4;
  margin: 0 0 0.6rem;
  padding: 0.2rem 0.8rem;
}

.oc-modal-lesson-card__name,
.oc-modal-special-card__name {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.4;
  margin: 0 0 0.4rem;
}

.oc-modal-lesson-card__subject,
.oc-modal-lesson-card__text,
.oc-modal-special-card__text {
  color: var(--oc-gray);
  font-size: 1.4rem;
  line-height: 1.5;
  margin: 0;
}

@media (max-width: 767px) {
  .oc-modal__frame {
    left: 50%;
    max-height: calc(100vh - 8.5333vw);
    max-width: none;
    top: 50%;
    transform: translate(-50%, -50%);
    width: calc(100% - 8.5333vw);
  }

  .oc-modal__dialog {
    max-height: calc(100vh - 8.5333vw);
    width: 100%;
  }

  .oc-modal__dialog--schedule {
    max-width: none;
    width: 100%;
  }

  .oc-modal__scroll {
    max-height: calc(100vh - 8.5333vw);
  }

  .oc-modal__inner {
    max-width: none;
    padding: 10.6667vw 4.2667vw 8.5333vw;
  }

  .oc-modal__close {
    color: var(--oc-black);
    font-size: 2.8rem;
    right: 2.1333vw;
    top: 2.1333vw;
    transform: none;
    z-index: 2;
  }

  .oc-modal__date {
    gap: 0 2.1333vw;
    margin-bottom: 5.3333vw;
  }

  .oc-modal__date-group {
    gap: 0.5333vw;
  }

  .oc-modal__date-year {
    font-size: 1.3rem;
  }

  .oc-modal__date-main {
    font-size: 3.2rem;
  }

  .oc-modal__date-dow {
    font-size: 1.8rem;
  }

  .oc-modal__title {
    font-size: 1.8rem;
  }

  .oc-modal__time {
    font-size: 1.3rem;
    margin: 0;
  }

  .oc-modal__body {
    margin-top: 6.4vw;
  }

  .oc-modal__entry {
    font-size: 1.3rem;
    line-height: 1.75;
  }

  .oc-modal__entry img {
    margin-top: 4.2667vw;
  }

  .oc-modal__entry p {
    margin-bottom: 4.2667vw;
  }

  .oc-modal__apply-wrap {
    margin-top: 6.4vw;
  }

  .oc-modal__footer {
    margin-top: 8.5333vw;
  }

  .oc-modal__apply {
    font-size: 1.4rem;
    min-height: 12.8vw;
    padding: 3.2vw 8vw 3.2vw 4.2667vw;
  }

  .oc-modal__apply-wrap + .oc-modal__section,
  .oc-modal__section + .oc-modal__section {
    margin-top: 8.5333vw;
  }

  .oc-modal__section-title {
    font-size: 1.6rem;
    margin-bottom: 4.2667vw;
    padding-bottom: 2.1333vw;
  }

  .oc-modal__lesson-list,
  .oc-modal__special-list {
    gap: 4.2667vw;
    grid-template-columns: minmax(0, 1fr);
  }

  .oc-modal-lesson-card,
  .oc-modal-special-card {
    gap: 3.2vw;
    padding: 4.2667vw;
  }

  .oc-modal-lesson-card__media,
  .oc-modal-special-card__media {
    height: 18.6667vw;
    width: 18.6667vw;
  }

  .oc-modal-special-card__cat {
    font-size: 1.1rem;
    margin-bottom: 1.0667vw;
    padding: 0.5333vw 2.1333vw;
  }

  .oc-modal-lesson-card__name,
  .oc-modal-special-card__name {
    font-size: 1.4rem;
    margin-bottom: 1.0667vw;
  }

  .oc-modal-lesson-card__subject,
  .oc-modal-lesson-card__text,
  .oc-modal-special-card__text {
    font-size: 1.2rem;
  }
}

@media (min-width: 768px) {
  .oc-modal__apply-wrap,
  .oc-modal__footer {
    display: flex;
    justify-content: center;
  }

  .oc-modal__apply {
    max-width: 100%;
    min-width: 36rem;
    width: auto;
  }

  .oc-modal__close {
    color: #fff;
  }
}

/* ========== Guest ========== */
.oc-guest__grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-guest-card__thumb {
  aspect-ratio: 1;
  background: var(--oc-gray-light);
  border-radius: 50%;
  margin: 0 auto 0.75rem;
  max-width: 96px;
}

.oc-guest-card {
  border: 1px solid var(--oc-border);
  padding: 1.25rem;
  text-align: center;
}

/* ========== Student Voice（Figma PC 1440 / SP 375） ========== */
.oc-voice {
  background: transparent;
  color: var(--oc-black);
}

.oc-voice__inner {
  margin-inline: auto;
  max-width: 1090px;
}

.oc-voice__head {
  text-align: left;
}

.oc-voice__label {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-voice__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-voice__list {
  display: grid;
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-voice-card {
  background: #fff;
  border: 1px solid var(--oc-border);
  box-sizing: border-box;
  color: var(--oc-black);
  height: 100%;
}

.oc-voice-card__head {
  display: flex;
}

.oc-voice-card__media {
  flex-shrink: 0;
  overflow: hidden;
}

.oc-voice-card__img {
  border-radius: 50%;
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.oc-voice-card__course {
  background: var(--oc-red);
  color: #fff;
  display: inline-block;
  font-weight: 700;
  line-height: 1.4;
  margin: 0 0 0.6rem;
}

.oc-voice-card__name {
  align-items: baseline;
  display: flex;
  flex-wrap: wrap;
  gap: 0 0.4rem;
  margin: 0;
}

.oc-voice-card__name-main {
  font-weight: 700;
  line-height: 1.4;
}

.oc-voice-card__meta {
  color: var(--oc-gray);
  font-weight: 400;
  line-height: 1.4;
}

.oc-voice-card__body {
  position: relative;
}

.oc-voice-card__text {
  isolation: isolate;
  line-height: 1.7;
  margin: 0;
  position: relative;
}

.oc-voice-card__text::after {
  background: url("../images/open-campus/index/voice_decoration.svg") no-repeat center / contain;
  top: 0;
  content: "";
  height: 3rem;
  pointer-events: none;
  position: absolute;
  right: 0;
  width: 2.9rem;
  z-index: -1;
}

/* ========== Benefits（Figma PC 1440 / SP 375） ========== */
.oc-benefits {
  background: transparent;
  color: var(--oc-black);
}

.oc-benefits__inner {
  margin-inline: auto;
  max-width: 1090px;
}

.oc-benefits__head {
  text-align: left;
}

.oc-benefits__label {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-benefits__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-benefits__lead {
  color: var(--oc-gray);
  font-weight: 400;
  line-height: 1.5;
  margin: 0;
}

.oc-benefits__panel {
  background: #fff;
  border: 1px solid var(--oc-border);
  box-sizing: border-box;
  color: var(--oc-black);
  overflow: hidden;
  width: 100%;
}

.oc-benefits__list {
  display: grid;
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-benefits__item {
  display: flex;
  min-width: 0;
}

.oc-benefit-card {
  box-sizing: border-box;
  flex: 1 1 auto;
  height: 100%;
  text-align: center;
  width: 100%;
}

.oc-benefit-card__icon-wrap {
  align-items: center;
  border: 1px solid var(--oc-border);
  border-radius: 50%;
  box-sizing: border-box;
  display: inline-flex;
  justify-content: center;
  margin-inline: auto;
}

.oc-benefit-card__icon {
  display: block;
  height: auto;
  max-height: 100%;
  max-width: 100%;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.oc-benefit-card__title {
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-benefit-card__text {
  color: var(--oc-gray);
  line-height: 1.7;
  margin: 0;
}

/* ========== Off-campus Performance（Figma PC 1440 / SP 375） ========== */
.oc-performance {
  background: transparent;
  color: var(--oc-black);
}

.oc-performance__inner {
  margin-inline: auto;
  max-width: 1090px;
}

.oc-performance__head {
  text-align: left;
}

.oc-performance__label {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-performance__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-performance__lead {
  color: var(--oc-gray);
  font-weight: 400;
  line-height: 1.7;
  margin: 0;
}

.oc-performance__events,
.oc-performance__tags-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-performance__events {
  display: grid;
}

.oc-performance-card {
  border: 1px solid var(--oc-border);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.oc-performance-card__month {
  background: var(--oc-red);
  color: #fff;
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-performance-card__body {
  background: #fff;
  color: var(--oc-black);
  flex: 1 1 auto;
}

.oc-performance-card__title {
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-performance-card__text {
  color: var(--oc-gray);
  line-height: 1.6;
  margin: 0;
}

.oc-performance__tags {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem 1rem;
}

.oc-performance__tags-label {
  flex-shrink: 0;
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-performance__tags-list {
  display: flex;
  flex: 1 1 auto;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.oc-performance__tag {
  background: #fff;
  border: 1px solid var(--oc-border);
  border-radius: 999px;
  color: var(--oc-black);
  display: inline-block;
  font-weight: 700;
  line-height: 1.4;
}

/* ----- Voice SP ----- */
@media (max-width: 767px) {
  .oc-voice {
    padding: 10.6667vw 4.2667vw 12.8vw;
  }

  .oc-voice__head {
    text-align: left;
  }

  .oc-voice__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-voice__title {
    font-size: 2rem;
    margin-bottom: 6.4vw;
  }

  .oc-voice__list {
    gap: 2.9333vw;
    grid-template-columns: minmax(0, 1fr);
  }

  .oc-voice-card {
    padding: 6.4vw 5.3333vw;
  }

  .oc-voice-card__head {
    gap: 5.6vw;
    margin-bottom: 4.2667vw;
  }

  .oc-voice-card__media {
    border-radius: 50%;
    height: 20.8vw;
    width: 20.8vw;
  }

  .oc-voice-card__course {
    font-size: 1.1rem;
    padding: 0.8vw 2.4vw;
  }

  .oc-voice-card__name-main {
    font-size: 1.6rem;
  }

  .oc-voice-card__meta {
    font-size: 1.2rem;
  }

  .oc-voice-card__text {
    font-size: 1.3rem;
  }

  .oc-voice-card__text::after {
    height: 7.89vw;
    width: 7.62vw;
  }
}

/* ----- Voice PC ----- */
@media (min-width: 768px) {
  .oc-voice {
    padding: 6.3rem 13.5rem 5rem;
  }

  .oc-voice__label {
    font-size: 2rem;
    margin-bottom: 1rem;
  }

  .oc-voice__title {
    font-size: 3.6rem;
    margin-bottom: 4rem;
  }

  .oc-voice__list {
    gap: 2.2rem;
    grid-template-columns: repeat(3, 34.8rem);
    justify-content: center;
  }

  .oc-voice-card {
    padding: 2.4rem 2rem 2rem;
  }

  .oc-voice-card__head {
    gap: 2rem;
    margin-bottom: 1.6rem;
  }

  .oc-voice-card__media {
    border-radius: 50%;
    height: 7.9rem;
    width: 7.9rem;
  }

  .oc-voice-card__course {
    font-size: 1.2rem;
    padding: 0.3rem 1rem;
  }

  .oc-voice-card__name-main {
    font-size: 1.8rem;
  }

  .oc-voice-card__meta {
    font-size: 1.4rem;
  }

  .oc-voice-card__text {
    font-size: 1.4rem;
  }
}

/* ----- Benefits SP ----- */
@media (max-width: 767px) {
  .oc-benefits {
    padding: 10.6667vw 0 12.8vw;
  }

  .oc-benefits__inner {
    box-sizing: border-box;
    padding-inline: 4.2667vw;
  }

  .oc-benefits__head {
    text-align: left;
  }

  .oc-benefits__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-benefits__title {
    font-size: 2rem;
    margin-bottom: 2.1333vw;
  }

  .oc-benefits__lead {
    font-size: 1.3rem;
    margin-bottom: 6.4vw;
  }

  .oc-benefits__panel {
    margin-inline: 0;
  }

  .oc-benefits__list {
    grid-template-columns: minmax(0, 1fr);
  }

  .oc-benefits__item + .oc-benefits__item {
    border-top: 1px solid var(--oc-border);
  }

  .oc-benefit-card {
    padding: 8.5333vw 6.4vw;
  }

  .oc-benefit-card__icon-wrap {
    height: 16vw;
    margin-bottom: 4.2667vw;
    width: 16vw;
  }

  .oc-benefit-card__title {
    font-size: 1.6rem;
    margin-bottom: 2.1333vw;
  }

  .oc-benefit-card__text {
    font-size: 1.3rem;
  }
}

/* ----- Benefits PC ----- */
@media (min-width: 768px) {
  .oc-benefits {
    padding: 5rem 13.5rem 6rem;
  }

  .oc-benefits__label {
    font-size: 2rem;
    margin-bottom: 1rem;
  }

  .oc-benefits__title {
    font-size: 3.6rem;
    margin-bottom: 1rem;
  }

  .oc-benefits__lead {
    font-size: 1.6rem;
    margin-bottom: 3.2rem;
  }

  .oc-benefits__panel--count-1 {
    width: calc(100% / 3);
  }

  .oc-benefits__panel--count-2 {
    width: calc(100% * 2 / 3);
  }

  .oc-benefits__list {
    align-items: stretch;
    gap: 0;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .oc-benefits__panel--count-1 .oc-benefits__list {
    grid-template-columns: minmax(0, 1fr);
  }

  .oc-benefits__panel--count-2 .oc-benefits__list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .oc-benefits__item:not(:last-child) {
    border-right: 1px solid var(--oc-border);
  }

  .oc-benefit-card {
    padding: 4rem 2.8rem 3.2rem;
  }

  .oc-benefit-card__icon-wrap {
    height: 6.4rem;
    margin-bottom: 2.4rem;
    width: 6.4rem;
  }

  .oc-benefit-card__title {
    font-size: 1.8rem;
    margin-bottom: 1.2rem;
  }

  .oc-benefit-card__text {
    font-size: 1.4rem;
  }
}

/* ----- Performance SP ----- */
@media (max-width: 767px) {
  .oc-performance {
    padding: 10.6667vw 4.2667vw 14.9333vw;
  }

  .oc-performance__head {
    text-align: left;
  }

  .oc-performance__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-performance__title {
    font-size: 2rem;
    margin-bottom: 3.2vw;
  }

  .oc-performance__lead {
    font-size: 1.3rem;
    margin-bottom: 6.4vw;
    text-align: left;
  }

  .oc-performance__events {
    gap: 3.2vw;
    grid-template-columns: minmax(0, 1fr);
    margin-bottom: 8.5333vw;
  }

  .oc-performance-card__month {
    font-size: 1.3rem;
    padding: 2.6667vw 3.7333vw;
  }

  .oc-performance-card__body {
    padding: 3.7333vw;
  }

  .oc-performance-card__title {
    font-size: 1.6rem;
    margin-bottom: 1.6vw;
  }

  .oc-performance-card__text {
    font-size: 1.3rem;
  }

  .oc-performance__tags {
    align-items: center;
    gap: 1.0667vw 2.1333vw;
  }

  .oc-performance__tags-label {
    font-size: 1.3rem;
  }

  .oc-performance__tag {
    font-size: 1.2rem;
    padding: 1.3333vw 3.4667vw;
  }
}

/* ----- Performance PC ----- */
@media (min-width: 768px) {
  .oc-performance {
    padding: 5.3rem 13.5rem 6rem;
  }

  .oc-performance__label {
    font-size: 2rem;
    margin-bottom: 1rem;
  }

  .oc-performance__title {
    font-size: 3.6rem;
    margin-bottom: 1.2rem;
  }

  .oc-performance__lead {
    font-size: 1.6rem;
    margin-bottom: 3.2rem;
  }

  .oc-performance__events {
    gap: 1.6rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 4rem;
  }

  .oc-performance-card__month {
    font-size: 1.4rem;
    padding: 1rem 1.4rem;
  }

  .oc-performance-card__body {
    padding: 1.3rem 1.4rem 1.6rem;
  }

  .oc-performance-card__title {
    font-size: 1.6rem;
    margin-bottom: 0.8rem;
  }

  .oc-performance-card__text {
    font-size: 1.4rem;
  }

  .oc-performance__tags-label {
    font-size: 1.4rem;
    padding-top: 6px;
  }

  .oc-performance__tag {
    font-size: 1.2rem;
    padding: 0.5rem 1.3rem;
  }
}

/* ========== Course Experience（Figma PC 1440 / SP 375） ========== */
.oc-course {
  background: var(--oc-red);
  color: #fff;
}

.oc-course__inner {
  margin-inline: auto;
  max-width: 1440px;
}

.oc-course__head {
  text-align: center;
}

.oc-course__label {
  color: #fff;
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-course__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-course__lead {
  font-weight: 400;
  line-height: 1.5;
  margin: 0;
}

.oc-course__block + .oc-course__block {
  margin-top: 0;
}

.oc-course__subhead {
  border-bottom: 1px solid rgba(255, 255, 255, 0.45);
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  padding-bottom: 1.6rem;
}

.oc-course__teachers,
.oc-course__lessons {
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-course-teacher-card {
  align-items: center;
  background: #fff;
  box-sizing: border-box;
  color: var(--oc-black);
  display: flex;
  height: 100%;
}

.oc-course-teacher-card__media {
  flex-shrink: 0;
  overflow: hidden;
}

.oc-course-teacher-card__img {
  border-radius: 50%;
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.oc-course-teacher-card__body {
  min-width: 0;
}

.oc-course-teacher-card__date {
  color: var(--oc-red);
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-course-teacher-card__name {
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-course-teacher-card__subject {
  color: var(--oc-gray);
  line-height: 1.5;
  margin: 0;
}

.oc-course-lesson-card {
  background: #fff;
  box-sizing: border-box;
  color: var(--oc-black);
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  text-decoration: none;
}

.oc-course-lesson-card:hover {
  opacity: 0.85;
}

.oc-course-lesson-card__thumb {
  background: #d9d9d9;
  display: block;
  overflow: hidden;
  width: 100%;
}

.oc-course-lesson-card__img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.oc-course-lesson-card__body {
  text-align: center;
}

.oc-course-lesson-card__name {
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-course-lesson-card__name-en {
  color: var(--oc-gray);
  font-family: var(--oc-font-en);
  font-weight: 500;
  line-height: 1.4;
  margin: 0;
  text-transform: uppercase;
}

/* ----- Course SP（375px基準 vw） ----- */
@media (max-width: 767px) {
  .oc-course {
    padding: 12.8vw 4.2667vw 14.9333vw;
  }

  .oc-course__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-course__title {
    font-size: 2rem;
    margin-bottom: 8vw;
  }

  .oc-course__block + .oc-course__block {
    margin-top: 10.6667vw;
  }

  .oc-course__subhead {
    font-size: 1.4rem;
    margin-bottom: 4.2667vw;
    padding-bottom: 2.1333vw;
  }

  .oc-course__teachers {
    display: grid;
    gap: 4.2667vw;
    grid-template-columns: minmax(0, 1fr);
  }

  .oc-course-teacher-card {
    gap: 5.6vw;
    min-height: 38.7vw;
    padding: 6.4vw 5.6vw;
  }

  .oc-course-teacher-card__media {
    border-radius: 50%;
    height: 17.6vw;
    width: 17.6vw;
  }

  .oc-course-teacher-card__date {
    font-size: 1.3rem;
    margin-bottom: 1.6vw;
  }

  .oc-course-teacher-card__name {
    font-size: 1.6rem;
    margin-bottom: 1.0667vw;
  }

  .oc-course-teacher-card__subject {
    font-size: 1.4rem;
  }

  .oc-course__lessons {
    display: grid;
    gap: 1.8667vw;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .oc-course-lesson-card__thumb {
    aspect-ratio: 166.85 / 79.96;
  }

  .oc-course-lesson-card__body {
    padding: 2.1333vw 1.6vw 2.6667vw;
  }

  .oc-course-lesson-card__name {
    font-size: 1.3rem;
  }

  .oc-course-lesson-card__name-en {
    font-size: 1.1rem;
    margin-top: 0.5333vw;
  }
}

/* ----- Course PC（rem/px） ----- */
@media (min-width: 768px) {
  .oc-course {
    padding: 6.3rem 13.5rem 8rem;
  }

  .oc-course__label {
    font-size: 2rem;
    margin-bottom: 1rem;
  }

  .oc-course__title {
    font-size: 3.6rem;
    margin-bottom: 1rem;
  }

  .oc-course__lead {
    font-size: 1.6rem;
    margin-bottom: 4.6rem;
  }

  .oc-course__block + .oc-course__block {
    margin-top: 4.6rem;
  }

  /* AUN #13 #14: 小見出し・下線をカード／画像グリッド幅に合わせる */
  .oc-course__block {
    width: fit-content;
    max-width: 100%;
    margin-inline: auto;
  }

  .oc-course__subhead {
    font-size: 1.8rem;
    margin-bottom: 2.4rem;
    padding-bottom: 1.6rem;
  }

  .oc-course__teachers {
    display: grid;
    gap: 1.6rem 2rem;
    grid-template-columns: repeat(2, 53.5rem);
    justify-content: center;
  }

  .oc-course-teacher-card {
    gap: 2rem;
    min-height: 15.4rem;
    padding: 2.9rem 2.3rem;
  }

  .oc-course-teacher-card__media {
    border-radius: 50%;
    height: 7rem;
    width: 7rem;
  }

  .oc-course-teacher-card__date {
    font-size: 1.4rem;
    margin-bottom: 0.8rem;
  }

  .oc-course-teacher-card__name {
    font-size: 1.8rem;
    margin-bottom: 0.6rem;
  }

  .oc-course-teacher-card__subject {
    font-size: 1.4rem;
  }

  .oc-course__lessons {
    display: grid;
    gap: 0.8rem 1rem;
    grid-template-columns: repeat(4, 26.5rem);
    justify-content: center;
  }

  .oc-course-lesson-card__thumb {
    aspect-ratio: 265 / 127;
  }

  .oc-course-lesson-card__body {
    padding: 1.4rem 1rem 1.6rem;
  }

  .oc-course-lesson-card__name {
    font-size: 1.6rem;
  }

  .oc-course-lesson-card__name-en {
    font-size: 1.2rem;
    margin-top: 0.4rem;
  }
}

/* ========== Access & Shuttle（Figma PC 1440 / SP 375） ========== */
.oc-access {
  background: var(--oc-gray-light);
}

.oc-access__inner {
  margin-inline: auto;
  max-width: 1090px;
}

.oc-access__head {
  text-align: left;
}

.oc-access__label {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-access__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-access__main {
  display: grid;
}

.oc-access__map-wrap {
  border: 1px solid var(--oc-border);
  box-sizing: border-box;
  overflow: hidden;
}

.oc-access__map-wrap iframe,
.oc-access__map {
  border: 0;
  display: block;
  height: 100%;
  width: 100%;
}

.oc-access__detail-title {
  border-bottom: 3px solid var(--oc-red);
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
  padding-bottom: 0.8rem;
}

.oc-access__rows {
  margin: 0;
}

.oc-access__row {
  border-bottom: 1px solid var(--oc-border);
  display: grid;
  gap: 0.4rem 0;
  padding-block: 1.2rem;
}

.oc-access__term {
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.oc-access__desc {
  line-height: 1.6;
  margin: 0;
}

.oc-access__more {
  margin: 0;
}

.oc-access__more-link {
  align-items: center;
  color: var(--oc-black);
  display: inline-flex;
  font-weight: 700;
  gap: 0.6rem;
  line-height: 1.4;
  text-decoration: underline;
}

.oc-access__more-link:hover {
  color: var(--oc-black);
  text-decoration: underline;
}

.oc-access__more-link::after {
  border-right: 2px solid var(--oc-black);
  border-top: 2px solid var(--oc-black);
  content: "";
  display: inline-block;
  flex-shrink: 0;
  height: 0.55rem;
  transform: rotate(45deg);
  width: 0.55rem;
}

.oc-access__photos {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-access__photo {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.oc-access__shuttle {
  background: var(--oc-red);
  color: #fff;
}

.oc-access__shuttle-body {
  display: grid;
}

.oc-access__shuttle-title {
  align-items: center;
  display: flex;
  font-weight: 700;
  gap: 1rem;
  line-height: 1.4;
  margin: 0;
}

.oc-access__shuttle-title-bar {
  align-self: stretch;
  border-left: 3px solid #fff;
  flex-shrink: 0;
  width: 0;
}

.oc-access__shuttle-lead,
.oc-access__shuttle-note {
  line-height: 1.7;
  margin: 0;
}

.oc-access__shuttle-stops {
  display: grid;
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-access__shuttle-map {
  display: block;
  height: auto;
  width: 100%;
}

.oc-access__shuttle-link {
  color: #fff;
  display: block;
  text-decoration: none;
}

.oc-access__shuttle-link:hover {
  opacity: 0.85;
}

.oc-access__shuttle-row {
  align-items: flex-start;
  display: flex;
  gap: 0.4em;
  line-height: 1.5;
  margin: 0.8rem 0 0;
}

.oc-access__shuttle-time {
  flex-shrink: 0;
  font-weight: 700;
}

.oc-access__shuttle-place {
  display: flex;
  flex-direction: column;
}

/* ----- Access SP ----- */
@media (max-width: 767px) {
  .oc-access {
    padding: 10.6667vw 4.2667vw 12.8vw;
  }

  .oc-access__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-access__title {
    font-size: 2rem;
    margin-bottom: 6.4vw;
  }

  .oc-access__main {
    gap: 6.4vw;
    grid-template-columns: minmax(0, 1fr);
    margin-bottom: 8.5333vw;
  }

  .oc-access__map-wrap {
    aspect-ratio: 341 / 320;
    min-height: 85.3333vw;
  }

  .oc-access__detail-title {
    font-size: 1.6rem;
    margin-bottom: 4.2667vw;
  }

  .oc-access__term {
    font-size: 1.4rem;
  }

  .oc-access__desc {
    font-size: 1.3rem;
  }

  .oc-access__more {
    margin-top: 4.2667vw;
  }

  .oc-access__more-link {
    font-size: 1.4rem;
  }

  .oc-access__photos {
    gap: 2.1333vw;
    margin-top: 6.4vw;
  }

  .oc-access__photo-item {
    aspect-ratio: 170.5 / 105.74;
  }

  .oc-access__shuttle {
    margin-inline: -4.2667vw;
    padding: 8.5333vw 4.2667vw;
  }

  .oc-access__shuttle-body {
    gap: 6.4vw;
    grid-template-columns: minmax(0, 1fr);
  }

  .oc-access__shuttle-title {
    font-size: 1.6rem;
    margin-bottom: 4.2667vw;
  }

  .oc-access__shuttle-lead {
    font-size: 1.3rem;
    margin-bottom: 4.2667vw;
  }

  .oc-access__shuttle-note {
    font-size: 1.2rem;
    margin-bottom: 6.4vw;
  }

  .oc-access__shuttle-stops {
    gap: 6.4vw;
    grid-template-columns: minmax(0, 1fr);
  }

  .oc-access__shuttle-row {
    font-size: 1.3rem;
    margin-inline: auto;
    margin-top: 2.1333vw;
    width: fit-content;
  }
}

/* ----- Access PC ----- */
@media (min-width: 768px) {
  .oc-access {
    padding: 5.3rem 13.5rem 6rem;
  }

  .oc-access__label {
    font-size: 2rem;
    margin-bottom: 1rem;
  }

  .oc-access__title {
    font-size: 3.6rem;
    margin-bottom: 3.2rem;
  }

  .oc-access__main {
    gap: 3.5rem;
    grid-template-columns: 51.7rem minmax(0, 1fr);
    margin-bottom: 4rem;
  }

  .oc-access__map-wrap {
    height: 38.8rem;
  }

  .oc-access__detail-title {
    font-size: 1.8rem;
    margin-bottom: 1.6rem;
  }

  .oc-access__term {
    font-size: 1.6rem;
  }

  .oc-access__desc {
    font-size: 1.4rem;
  }

  .oc-access__more {
    margin-top: 1.2rem;
  }

  .oc-access__more-link {
    font-size: 1.4rem;
  }

  .oc-access__photos {
    gap: 1.6rem;
    margin-top: 2rem;
  }

  .oc-access__photo-item {
    aspect-ratio: 258 / 160;
  }

  .oc-access__row {
    gap: 0 1rem;
    grid-template-columns: 7.5rem minmax(0, 1fr);
  }

  .oc-access__shuttle {
    padding: 2.4rem 2.8rem 2.8rem;
  }

  .oc-access__shuttle-body {
    gap: 2.4rem;
    grid-template-columns: minmax(0, 42.6rem) minmax(0, 1fr);
  }

  .oc-access__shuttle-title {
    font-size: 1.8rem;
    margin-bottom: 1.6rem;
  }

  .oc-access__shuttle-lead {
    font-size: 1.4rem;
    margin-bottom: 1.2rem;
  }

  .oc-access__shuttle-note {
    font-size: 1.4rem;
  }

  .oc-access__shuttle-stops {
    gap: 1.6rem;
    grid-template-columns: repeat(2, minmax(0, 27rem));
    justify-content: end;
  }

  .oc-access__shuttle-row {
    font-size: 1.4rem;
    margin-top: 1rem;
  }
}

/* ========== FAQ（Figma PC 1440 / SP 375） ========== */
.oc-faq {
  background: #fff;
  color: var(--oc-black);
}

.oc-faq__inner {
  margin-inline: auto;
  max-width: 1090px;
}

.oc-faq__head {
  text-align: center;
}

.oc-faq__label {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-faq__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-faq__groups {
  display: grid;
  gap: 0;
}

.oc-faq__group + .oc-faq__group {
  margin-top: 3.2rem;
}

.oc-faq__category {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4;
  margin: 0 0 1.2rem;
  padding: 0;
}

.oc-faq__list {
  border-top: 1px solid var(--oc-border);
}

.oc-faq__item {
  border-bottom: 1px solid var(--oc-border);
}

.oc-faq__summary {
  align-items: flex-start;
  cursor: pointer;
  display: grid;
  gap: 0 1.6rem;
  grid-template-columns: auto minmax(0, 1fr) auto;
  list-style: none;
}

.oc-faq__summary::-webkit-details-marker {
  display: none;
}

.oc-faq__badge {
  align-items: center;
  border-radius: 50%;
  box-sizing: border-box;
  display: inline-flex;
  flex-shrink: 0;
  font-family: var(--oc-font-en);
  font-weight: 700;
  justify-content: center;
  line-height: 1;
}

.oc-faq__badge--q {
  background: var(--oc-red);
  color: #fff;
}

.oc-faq__badge--a {
  background: #fff;
  border: 1px solid var(--oc-red);
  color: var(--oc-red);
}

.oc-faq__question {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-faq__toggle {
  flex-shrink: 0;
  height: 2.45rem;
  position: relative;
  width: 2.45rem;
}

.oc-faq__toggle-bar {
  background: var(--oc-red);
  display: block;
  left: 50%;
  position: absolute;
  top: 50%;
}

.oc-faq__toggle-bar--h {
  height: 2px;
  transform: translate(-50%, -50%);
  width: 2.45rem;
}

.oc-faq__toggle-bar--v {
  height: 2.45rem;
  transform: translate(-50%, -50%) rotate(0deg);
  transform-origin: center;
  transition: transform 0.3s ease, opacity 0.3s ease;
  width: 2px;
}

.oc-faq__item.is-open .oc-faq__toggle-bar--v {
  opacity: 0;
  transform: translate(-50%, -50%) rotate(360deg);
}

.oc-faq__item > .oc-faq__body {
  display: block !important;
  height: 0;
  overflow: hidden;
  transition: height 0.3s ease;
}

.oc-faq__body-inner {
  overflow: hidden;
}

.oc-faq__answer-row {
  align-items: flex-start;
  display: grid;
  gap: 0 1.6rem;
  grid-template-columns: auto minmax(0, 1fr);
}

.oc-faq__answer {
  line-height: 1.6;
  margin: 0;
}

.oc-faq__answer strong {
  font-weight: 700;
}

/* ----- FAQ SP ----- */
@media (max-width: 767px) {
  .oc-faq {
    padding: 10.6667vw 4.2667vw 12.8vw;
  }

  .oc-faq__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-faq__title {
    font-size: 2rem;
    margin-bottom: 4.2667vw;
  }

  .oc-faq__group + .oc-faq__group {
    margin-top: 8.5333vw;
  }

  .oc-faq__category {
    font-size: 1.6rem;
    margin-bottom: 2.1333vw;
  }

  .oc-faq__summary {
    gap: 0 3.2vw;
    padding-block: 4.2667vw;
  }

  .oc-faq__badge {
    font-size: 1.1rem;
    height: 9.2vw;
    width: 9.2vw;
  }

  .oc-faq__question {
    font-size: 1.4rem;
    padding-top: 1.6vw;
  }

  .oc-faq__toggle {
    height: 3.9893vw;
    margin-top: 2.1333vw;
    width: 3.9893vw;
  }

  .oc-faq__toggle-bar--h {
    width: 3.9893vw;
  }

  .oc-faq__toggle-bar--v {
    height: 3.9893vw;
  }

  .oc-faq__body-inner {
    padding-bottom: 4.2667vw;
  }

  .oc-faq__answer-row {
    gap: 0 3.2vw;
  }

  .oc-faq__answer {
    font-size: 1.3rem;
    padding-top: 1.6vw;
  }
}

/* ----- FAQ PC ----- */
@media (min-width: 768px) {
  .oc-faq {
    padding: 5.3rem 13.5rem 6rem;
  }

  .oc-faq__label {
    font-size: 2rem;
    margin-bottom: 1rem;
  }

  .oc-faq__title {
    font-size: 3.6rem;
    margin-bottom: 4rem;
  }

  .oc-faq__group + .oc-faq__group {
    margin-top: 4rem;
  }

  .oc-faq__category {
    font-size: 2rem;
    margin-bottom: 1.6rem;
  }

  .oc-faq__summary {
    gap: 0 1.6rem;
    padding-block: 2rem;
  }

  .oc-faq__badge {
    font-size: 1.4rem;
    height: 4.2rem;
    width: 4.2rem;
  }

  .oc-faq__question {
    font-size: 1.6rem;
    padding-top: 0.9rem;
  }

  .oc-faq__toggle {
    margin-top: 0.9rem;
  }

  .oc-faq__body-inner {
    padding-bottom: 2rem;
  }

  .oc-faq__answer {
    font-size: 1.6rem;
    padding-top: 0.9rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .oc-faq__item > .oc-faq__body,
  .oc-faq__toggle-bar--v {
    transition: none;
  }
}

/* ========== Other Options（Figma PC 1440 / SP 375） ========== */
.oc-options {
  background: var(--oc-gray-light);
  color: var(--oc-black);
}

.oc-options__inner {
  margin-inline: auto;
  max-width: 1090px;
}

.oc-options__head {
  text-align: center;
}

.oc-options__label {
  color: var(--oc-red);
  font-family: var(--oc-font-en);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin: 0;
  text-transform: uppercase;
}

.oc-options__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-options__lead {
  color: var(--oc-gray);
  font-weight: 400;
  line-height: 1.5;
  margin: 0;
}

.oc-options__list {
  display: grid;
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-options__item {
  min-width: 0;
}

.oc-options-card {
  align-items: center;
  background: #fff;
  border: 1px solid var(--oc-border);
  box-sizing: border-box;
  color: inherit;
  display: flex;
  flex-direction: column;
  height: 100%;
  text-align: center;
  text-decoration: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}

.oc-options-card:hover {
  border-color: rgba(255, 0, 0, 0.35);
  box-shadow: 0 0.8rem 2.4rem rgba(0, 0, 0, 0.08);
  text-decoration: none;
  transform: translateY(-0.4rem);
}

.oc-options-card:hover .oc-options-card__title,
.oc-options-card:hover .oc-options-card__text,
.oc-options-card:hover .oc-options-card__action {
  text-decoration: none;
}

.oc-options-card__icon-wrap {
  align-items: center;
  display: flex;
  justify-content: center;
}

.oc-options-card__icon {
  display: block;
  height: auto;
  max-width: 100%;
  width: auto;
}

.oc-options-card__title {
  font-weight: 700;
  line-height: 1.4;
  text-decoration: none;
}

.oc-options-card__text {
  color: var(--oc-gray);
  line-height: 1.5;
  margin: 0;
  text-decoration: none;
}

.oc-options-card__action {
  color: var(--oc-red);
  font-weight: 700;
  line-height: 1.4;
  margin-top: auto;
  text-decoration: none;
  transition: color 0.25s ease;
}

.oc-options-card:hover .oc-options-card__action {
  color: var(--oc-red-dark);
}

/* ----- Other Options SP ----- */
@media (max-width: 767px) {
  .oc-options {
    padding: 10.6667vw 4.2667vw 12.8vw;
  }

  .oc-options__label {
    font-size: 1.2rem;
    letter-spacing: 0.16em;
    margin-bottom: 2.1333vw;
  }

  .oc-options__title {
    font-size: 2rem;
    margin-bottom: 2.1333vw;
  }

  .oc-options__lead {
    font-size: 1.3rem;
    margin-bottom: 6.4vw;
  }

  .oc-options__list {
    gap: 8vw;
  }

  .oc-options-card {
    min-height: 61.8357vw;
    padding: 7.4667vw 6.1333vw 6.9333vw;
  }

  .oc-options-card__icon-wrap {
    height: 13.7573vw;
    margin-bottom: 2.6667vw;
  }

  .oc-options-card__title {
    font-size: 1.6rem;
    margin-bottom: 2.1333vw;
  }

  .oc-options-card__text {
    font-size: 1.3rem;
    margin-bottom: 4.2667vw;
  }

  .oc-options-card__action {
    font-size: 1.3rem;
  }
}

/* ----- Other Options PC ----- */
@media (min-width: 768px) {
  .oc-options {
    padding: 5.3rem 13.5rem 6rem;
  }

  .oc-options__label {
    font-size: 2rem;
    margin-bottom: 1rem;
  }

  .oc-options__title {
    font-size: 3.6rem;
    margin-bottom: 1rem;
  }

  .oc-options__lead {
    font-size: 1.6rem;
    margin-bottom: 3.2rem;
  }

  .oc-options__list {
    gap: 1.6rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .oc-options-card {
    min-height: 23.2rem;
    padding: 2.8rem 2.3rem 2.4rem;
  }

  .oc-options-card__icon-wrap {
    height: 5.1rem;
    margin-bottom: 0.8rem;
  }

  .oc-options-card__title {
    font-size: 1.8rem;
    margin-bottom: 0.8rem;
  }

  .oc-options-card__text {
    font-size: 1.4rem;
    margin-bottom: 1.2rem;
  }

  .oc-options-card__action {
    font-size: 1.4rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .oc-options-card,
  .oc-options-card__action {
    transition: none;
  }

  .oc-options-card:hover {
    transform: none;
  }
}

/* ========== CTA（Figma PC 1440 / SP 375） ========== */
.oc-cta {
  color: #fff;
  overflow: hidden;
  position: relative;
}

.oc-cta__bg {
  background: linear-gradient(180deg, #ff0000 0%, #cf0000 100%);
  inset: 0;
  position: absolute;
  z-index: 0;
}

.oc-cta__bg::before,
.oc-cta__bg::after {
  content: "";
  pointer-events: none;
  position: absolute;
}

.oc-cta__bg::before {
  background: repeating-linear-gradient(
    -45deg,
    rgba(0, 0, 0, 0.08) 0,
    rgba(0, 0, 0, 0.08) 2px,
    transparent 2px,
    transparent 10px
  );
  height: 100%;
  left: 0;
  opacity: 0.35;
  top: 0;
  width: 28%;
}

.oc-cta__bg::after {
  background-image: radial-gradient(rgba(255, 255, 255, 0.18) 1px, transparent 1px);
  background-size: 8px 8px;
  height: 100%;
  opacity: 0.45;
  right: 0;
  top: 0;
  width: 32%;
}

.oc-cta__inner {
  margin-inline: auto;
  max-width: 1090px;
  position: relative;
  text-align: center;
  z-index: 1;
}

.oc-cta__title {
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.oc-cta__lead {
  font-weight: 400;
  line-height: 1.5;
  margin: 0;
}

.oc-cta__actions {
  display: grid;
}

.oc-cta__btn {
  letter-spacing: 0.06em;
  max-width: none;
  min-width: 0;
  text-decoration: none;
  width: 100%;
}

.oc-cta__btn--fill {
  background: #fff;
  border-color: #fff;
  color: var(--oc-red);
}

.oc-cta__btn--fill::before {
  background-color: var(--oc-red);
}

.oc-cta__btn--fill::after {
  border-color: transparent transparent var(--oc-red) transparent;
}

.oc-cta__btn--fill:hover,
.oc-cta__btn--fill:hover .p-btn__label {
  color: #fff;
  text-decoration: none;
}

.oc-cta__btn--outline {
  background: transparent;
  border-color: #fff;
  color: #fff;
}

.oc-cta__btn--outline::before {
  background-color: #fff;
}

.oc-cta__btn--outline::after {
  border-color: transparent transparent #fff transparent;
}

.oc-cta__btn--outline:hover,
.oc-cta__btn--outline:hover .p-btn__label {
  color: var(--oc-red);
  text-decoration: none;
}

.oc-cta__sns {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.oc-cta__sns-link {
  display: block;
  line-height: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.oc-cta__sns-link:hover {
  opacity: 0.85;
  transform: translateY(-2px);
}

.oc-cta__sns-icon {
  display: block;
  height: auto;
  width: 100%;
}

.oc-sticky-cta {
  background: #1a1a1a;
  bottom: 0;
  box-sizing: border-box;
  color: #fff;
  left: 0;
  position: fixed;
  right: 0;
  z-index: 90;
}

.oc-sticky-cta__inner {
  align-items: center;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  margin-inline: auto;
  max-width: 1440px;
}

.oc-sticky-cta__text {
  font-weight: 400;
  line-height: 1.5;
  margin: 0;
}

.oc-sticky-cta__btn {
  align-items: center;
  background: var(--oc-red);
  box-sizing: border-box;
  color: #fff;
  display: inline-flex;
  font-weight: 700;
  justify-content: center;
  line-height: 1.4;
  text-decoration: none;
  transition: background-color 0.25s ease;
  white-space: nowrap;
}

.oc-sticky-cta__btn:hover {
  background: var(--oc-red-dark);
  color: #fff;
  text-decoration: none;
}

.oc-sticky-cta__btn.is-disabled {
  background: #666;
  color: #ccc;
  cursor: not-allowed;
  pointer-events: none;
}

/* ----- CTA SP ----- */
@media (max-width: 767px) {
  .oc-sticky-cta {
    bottom: calc(-1 * var(--oc-sticky-cta-height-sp));
    transform: none;
    transition: bottom 0.3s ease;
    z-index: 89;
  }

  .oc-sticky-cta.is-visible {
    bottom: var(--oc-footer-group-height-sp);
    transform: none;
  }

  .oc-cta {
    padding: 10.6667vw 4.2667vw 12.8vw;
  }

  .oc-cta__title {
    font-size: 2rem;
    margin-bottom: 2.1333vw;
  }

  .oc-cta__lead {
    font-size: 1.3rem;
    margin-bottom: 6.4vw;
  }

  .oc-cta__actions {
    gap: 4vw;
    margin-bottom: 8vw;
  }

  .oc-cta__btn {
    font-size: 1.4rem;
    min-height: 19.3096vw;
    padding: 1.2rem 1.6rem;
  }

  .oc-cta__sns {
    gap: 3.7333vw;
  }

  .oc-cta__sns-item {
    width: 10.5689vw;
  }

  .oc-sticky-cta__inner {
    flex-direction: column;
    gap: 2.1333vw;
    padding: 3.2vw 4.2667vw 4.2667vw;
  }

  .oc-sticky-cta__text {
    font-size: 1.3rem;
    text-align: center;
  }

  .oc-sticky-cta__btn {
    font-size: 1.3rem;
    min-height: 11.5707vw;
    padding: 2.4vw 4.2667vw;
    width: 100%;
  }
}

/* ----- CTA PC ----- */
@media (min-width: 768px) {
  .oc-cta {
    padding: 5.3rem 13.5rem 5rem;
  }

  .oc-cta__title {
    font-size: 4rem;
    margin-bottom: 1rem;
  }

  .oc-cta__lead {
    font-size: 1.6rem;
    margin-bottom: 3.2rem;
  }

  .oc-cta__actions {
    gap: 1.9rem;
    grid-template-columns: 36rem 27.6rem;
    justify-content: center;
    margin-bottom: 3.2rem;
  }

  .oc-cta__btn {
    font-size: 1.6rem;
    min-height: 7.6rem;
    padding: 1.6rem 2rem;
  }

  .oc-cta__sns {
    gap: 1.4rem;
  }

  .oc-cta__sns-item {
    width: 4rem;
  }

  .oc-sticky-cta__inner {
    gap: 2rem;
    justify-content: center;
    min-height: 6.74rem;
    padding: 1.2rem 13.5rem;
  }

  .oc-sticky-cta__text {
    font-size: 1.6rem;
  }

  .oc-sticky-cta__btn {
    font-size: 1.6rem;
    min-height: 4.34rem;
    padding: 0.95rem 2.8rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .oc-cta__sns-link,
  .oc-sticky-cta__btn {
    transition: none;
  }

  .oc-cta__sns-link:hover {
    transform: none;
  }
}

/* ========== Responsive ========== */
@media (min-width: 768px) {
  .oc-u-sp {
    display: none;
  }

  .oc-u-pc-only {
    display: inline-flex;
  }

  .oc-hero {
    min-height: 0;
  }

  .oc-hero__bg {
    bottom: 0;
    height: auto;
    inset: 0;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
  }

  .oc-hero__bg-img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: left center;
    width: 100%;
  }

  .oc-hero__inner {
    align-items: center;
    display: grid;
    grid-template-columns: minmax(0, 46%) minmax(0, 54%);
    grid-template-rows: auto;
    min-height: clamp(520px, 41.666vw, 640px);
    padding: calc(100px + 1.5rem) 0 4.7rem 10%;
    position: relative;
  }

  .oc-hero__content {
    align-self: center;
    display: flex;
    flex-direction: column;
    gap: 2rem;
    grid-column: 1;
    grid-row: 1;
    max-width: 48.7rem;
    padding: 0;
    padding-bottom: 2.5rem;
    position: relative;
    width: auto;
    z-index: 2;
  }

  .oc-hero__title {
    margin: 0;
    margin-bottom: -4rem;
  }

  .oc-hero__title-img {
    max-width: min(100%, 48.7rem);
    width: 100%;
  }

  .oc-hero__visual {
    align-items: stretch;
    bottom: 0;
    display: block;
    grid-column: 2;
    grid-row: 1;
    height: 100%;
    justify-self: auto;
    line-height: 0;
    margin: 0;
    max-width: 54vw;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    width: auto;
    z-index: 1;
  }

  .oc-hero__photo {
    height: 100%;
    object-fit: contain;
    object-position: right bottom;
    width: auto;
  }

  .oc-hero__lead {
    color: #e50012;
    font-feature-settings: "palt" 1;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    line-height: 1.75;
    margin: 0;
    max-width: none;
    white-space: nowrap;
  }

  .oc-hero__meta {
    align-items: center;
    background: #fff;
    border: 1px solid #E50012;
    border-radius: 0.4rem;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    max-width: 35.2rem;
    min-height: 6.6rem;
    width: fit-content;
  }

  .oc-hero__next {
    align-self: stretch;
    font-size: 1.1rem;
    min-height: auto;
    min-width: 6.6rem;
    margin-bottom: -1px;
    padding: 0 1rem;
  }

  .oc-hero__date {
    font-size: 2rem;
    line-height: 1.2;
    padding: 0 0 0 1.5rem;
    text-align: left;
    white-space: nowrap;
  }

  .oc-hero__time {
    color: #666;
    font-family: var(--oc-font-en);
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1.2;
    margin-left: 0.4em;
    padding: 0 1.5rem 0 0;
    text-align: left;
    white-space: nowrap;
  }

  .oc-hero__actions--sp {
    display: none;
  }

  .oc-hero__actions--pc {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 1.2rem;
    max-width: 64.8rem;
    width: 100%;
  }

  .oc-hero__actions--pc .oc-hero__p-btn {
    flex: 0 0 auto;
    font-size: 1.6rem;
    letter-spacing: 0.06em;
    max-width: none;
    min-height: 7.2rem;
    padding: 1.6rem 2rem;
  }

  .oc-hero__actions--pc .oc-hero__p-btn--fill {
    width: 36rem;
  }

  .oc-hero__actions--pc .oc-hero__p-btn--outline {
    width: 27.6rem;
  }

  .oc-hero::after {
    background: rgba(0, 0, 0, 0.5);
    bottom: 0;
    content: "";
    display: block;
    height: 47px;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    z-index: 3;
  }

  .oc-hero__breadcrumb {
    align-items: center;
    background: transparent;
    bottom: 0;
    display: flex;
    justify-content: center;
    left: 0;
    margin-top: 0;
    min-height: 47px;
    padding: 0;
    position: absolute;
    right: 0;
    z-index: 4;
  }

  .oc-hero__breadcrumb .l-breadcrumb {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    margin: 0 auto;
    max-width: 1360px;
    min-height: 47px;
    padding: 0 0 0 10%;
    width: 100%;
    font-size: 1.3rem;
  }

  .oc-hero__breadcrumb .l-breadcrumb__list {
    align-items: center;
    height: 47px;
    min-height: 47px;
  }

  .oc-topics__list {
    grid-template-columns: repeat(3, 1fr);
  }

  .oc-guest__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}


@media (min-width: 1000px) {
  .oc-hero__inner {
    padding-left: 13.5rem;
    padding-right: 0;
  }

  .oc-hero__breadcrumb .l-breadcrumb {
    padding-left: 13.5rem;
  }
}