/* ==========================================
   Design Tokens
   ========================================== */
:root {
  --color-navy:        #1c2b6b;
  --color-navy-light:  #2e4494;
  --color-blue-mid:    #5b8cbf;
  --color-blue-muted:  #6c9bd2;
  --color-blue-dark:   #365981;
  --color-blue-light:  #eef8fe;
  --color-cyan:        #29b6f6;
  --color-orange:      #f47920;
  --color-yellow:      #f5eda0;
  --color-white:       #ffffff;
  --color-text:        #333333;
  --color-text2:       #191f61;
  --color-bg:          #ffffff;
  --header-h-sp:       6.0rem;
  --header-h-pc:       7.0rem;
  --max-width:         100rem;
  --side-pad-sp:       1.6rem;
  --side-pad-pc:       4.0rem;
}

/* ==========================================
   Base Reset
   ========================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  font-size: 1.6rem;
  font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
  color: var(--color-text);
  background-color: var(--color-blue-light);
  line-height: 1.7;
  overflow-x: hidden;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

ul, ol {
  list-style: none;
}

/* ==========================================
   Utility
   ========================================== */
.u-br-sp { display: inline; }
.u-addr-sep { display: none; }
@media (min-width: 768px) {
  .u-br-sp { display: none; }
  .u-addr-sep { display: inline; margin-right: 1.5em; }
}

/* ==========================================
   Layout
   ========================================== */
.l-main {
  padding-top: var(--header-h-sp);
}

@media (min-width: 768px) {
  .l-main {
    padding-top: var(--header-h-pc);
  }
}

/* ==========================================
   p-header
   ========================================== */
.p-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--header-h-sp);
  background: var(--color-blue-light);
  box-shadow: 0 0.2rem 1rem rgba(0, 0, 0, 0.12);
  z-index: 100;
}

.p-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  padding: 0 var(--side-pad-sp);
}

.p-header__logo-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.p-header__logo-img {
  width: 3.6rem;
  height: auto;
  flex-shrink: 0;
}

.p-header__logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.p-header__logo-name {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--color-navy);
}

/* ハンバーガー */
.p-header__hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.65rem;
  width: 5.2rem;
  height: 5.2rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  flex-shrink: 0;
}

.p-header__hamburger-bar {
  display: block;
  width: 3.2rem;
  height: 0.25rem;
  background: var(--color-navy);
  border-radius: 0.2rem;
  transition: transform 0.3s, opacity 0.3s;
  transform-origin: center;
}

.p-header__hamburger--open .p-header__hamburger-bar:nth-child(1) {
  transform: translateY(0.9rem) rotate(45deg);
}
.p-header__hamburger--open .p-header__hamburger-bar:nth-child(2) {
  opacity: 0;
}
.p-header__hamburger--open .p-header__hamburger-bar:nth-child(3) {
  transform: translateY(-0.9rem) rotate(-45deg);
}

/* SP ナビ（ドロワー） */
.p-header__nav {
  position: fixed;
  top: var(--header-h-sp);
  right: 0;
  width: 80%;
  max-width: 32rem;
  height: calc(100dvh - var(--header-h-sp));
  background: rgba(28, 43, 107, 0.9);
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.35s ease;
  z-index: 99;
}

.p-header__nav--open {
  transform: translateX(0);
}

.p-header__nav-list {
  display: flex;
  flex-direction: column;
  padding: 2.4rem 0;
}

.p-header__nav-link {
  display: block;
  padding: 1.4rem 2.4rem;
  color: var(--color-white);
  font-size: 1.5rem;
  font-weight: 600;
  border-bottom: 0.1rem solid rgba(255, 255, 255, 0.12);
  transition: background 0.2s;
}

.p-header__nav-link:hover {
  background: rgba(255, 255, 255, 0.1);
}

@media (min-width: 768px) {
  .p-header {
    height: var(--header-h-pc);
  }

  .p-header__inner {
    padding: 0 var(--side-pad-pc);
    max-width: 130rem;
    margin: 0 auto;
  }

  .p-header__logo-img {
    width: 5.0rem;
    height: auto;
  }

  .p-header__logo-name {
    font-size: clamp(1.8rem, 2vw, 2.4rem);
  }

  .p-header__hamburger {
    display: none;
  }

  .p-header__nav {
    position: static;
    width: auto;
    max-width: none;
    height: auto;
    background: none;
    transform: none;
    transition: none;
    overflow: visible;
  }

  .p-header__nav-list {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    padding: 0;
  }

  .p-header__nav-link {
    color: var(--color-navy);
    font-size: clamp(1.1rem, 1.0vw, 1.4rem);
    padding: 0.6rem 1.0rem;
    border-bottom: none;
    border-radius: 0.3rem;
  }

  .p-header__nav-link:hover {
    background: var(--color-blue-light);
  }
}

/* サブメニュー共通 */
.p-header__nav-item--has-sub {
  position: relative;
}

.p-header__nav-sub-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  width: 100%;
  background: none;
  border: none;
  border-bottom: 0.1rem solid rgba(255, 255, 255, 0.12);
  cursor: pointer;
  padding: 1.4rem 2.4rem;
  color: var(--color-white);
  font-size: 1.5rem;
  font-weight: 600;
  font-family: inherit;
  line-height: inherit;
  text-align: left;
  transition: background 0.2s;
}

.p-header__nav-sub-toggle:hover {
  background: rgba(255, 255, 255, 0.1);
}

.p-header__nav-arrow {
  display: inline-block;
  border: solid currentColor;
  border-width: 0 0.13em 0.13em 0;
  width: 0.45em;
  height: 0.45em;
  transform: rotate(45deg);
  transition: transform 0.2s;
  flex-shrink: 0;
  margin-top: -0.15em;
}

.p-header__nav-item--has-sub--open .p-header__nav-arrow {
  transform: rotate(-135deg);
  margin-top: 0.15em;
}

/* SP: アコーディオン */
.p-header__subnav {
  list-style: none;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  background: rgba(0, 0, 0, 0.15);
}

.p-header__nav-item--has-sub--open .p-header__subnav {
  max-height: 20rem;
}

.p-header__subnav-link {
  display: block;
  padding: 1.0rem 2.4rem 1.0rem 3.6rem;
  color: rgba(255, 255, 255, 0.82);
  font-size: 1.4rem;
  font-weight: 500;
  border-bottom: 0.1rem solid rgba(255, 255, 255, 0.08);
  transition: background 0.2s;
}

.p-header__subnav-link:hover {
  background: rgba(255, 255, 255, 0.1);
}

/* PC: ホバードロップダウン */
@media (min-width: 768px) {
  .p-header__nav-sub-toggle {
    width: auto;
    border-bottom: none;
    border-radius: 0.3rem;
    padding: 0.6rem 1.0rem;
    color: var(--color-navy);
    font-size: clamp(1.1rem, 1.0vw, 1.4rem);
    justify-content: flex-start;
  }

  .p-header__nav-sub-toggle:hover {
    background: var(--color-blue-light);
  }

  .p-header__subnav {
    position: absolute;
    top: 100%;
    left: 1rem;
    width: 90%;
    background: var(--color-white);
    box-shadow: 0.2rem 0.4rem 0.8rem -0.2rem rgba(0, 0, 0, 0.18);
    border-radius: 0 0 0.3rem 0.3rem;
    max-height: 0;
    transition: max-height 0.2s ease;
    z-index: 100;
  }

  .p-header__nav-item--has-sub:hover .p-header__subnav,
  .p-header__nav-item--has-sub--open .p-header__subnav {
    max-height: 20rem;
  }

  .p-header__nav-item--has-sub:hover .p-header__nav-arrow {
    transform: rotate(-135deg);
    margin-top: 0.15em;
  }

  .p-header__subnav-link {
    padding: 0.8rem 1.6rem 0.8rem 1.2rem;
    color: var(--color-navy);
    font-size: clamp(1.1rem, 1.0vw, 1.4rem);
    font-weight: 600;
    border-bottom: 0.1rem solid rgba(0, 0, 0, 0.06);
  }

  .p-header__subnav-link:hover {
    background: var(--color-blue-light);
    color: var(--color-navy);
  }
}

/* ==========================================
   p-hero（ヒーロースライダー）
   ========================================== */
.p-hero {
  position: relative;
  overflow: hidden;
  background: var(--color-white);
}

.p-hero__slider {
  position: relative;
  width: 100%;
  padding-bottom: 150.5%; /* SP: 376×567 */
}

.p-hero__slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.8s ease;
}

.p-hero__slide--active {
  opacity: 1;
  z-index: 1;
}

.p-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-hero__dots {
  position: absolute;
  bottom: 1.6rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 0.8rem;
  z-index: 10;
}

.p-hero__dot {
  width: 1.0rem;
  height: 1.0rem;
  border-radius: 50%;
  border: 0.2rem solid rgba(255, 255, 255, 0.8);
  background: transparent;
  cursor: pointer;
  padding: 0;
  transition: background 0.3s;
}

.p-hero__dot--active {
  background: var(--color-white);
}

.p-hero__prev,
.p-hero__next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 3.6rem;
  height: 3.6rem;
  background: rgba(0, 0, 0, 0.35);
  color: var(--color-white);
  border: none;
  border-radius: 50%;
  font-size: 2.4rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.p-hero__prev { left: 1.2rem; }
.p-hero__next { right: 1.2rem; }

@media (max-width: 767px) {
  .p-hero__prev { left: 0.6rem; }
  .p-hero__next { right: 0.6rem; }
}

.p-hero__prev:hover,
.p-hero__next:hover {
  background: rgba(0, 0, 0, 0.6);
}

@media (min-width: 600px) {
  .p-hero__slider {
    padding-bottom: 49.1%; /* PC: 1500×736 */
  }

  .p-hero__dot {
    width: 1.2rem;
    height: 1.2rem;
  }

  .p-hero__prev,
  .p-hero__next {
    width: 4.8rem;
    height: 4.8rem;
    font-size: 3.2rem;
  }

  .p-hero__prev { left: 2.4rem; }
  .p-hero__next { right: 2.4rem; }
}

/* ==========================================
   p-courses-intro（学科・コース紹介イントロ）
   ========================================== */
.p-courses-intro {
  padding: clamp(2.4rem, 5vw, 5.6rem) var(--side-pad-sp);
}

.p-courses-intro__inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

.p-courses-intro__img-wrap {
  margin-bottom: 2.4rem;
  text-align: center;
  position: relative;
  left: 1rem;
}

.p-courses-intro__img {
  width: 100%;
  max-width: 60rem;
  height: auto;
  margin: 0 auto;
  display: block;
}

.p-courses-intro__desc {
  font-size: clamp(1.7rem, 2.5vw, 1.9rem);
  font-weight: 600;
  color: var(--color-text2);
  line-height: 1.9;
  margin-bottom: 2.4rem;
}

.p-courses-intro__sns-img {
  width: 16rem;
  height: auto;
  /* 画像未準備のフォールバック（削除可） */
  min-height: 5.0rem;
  background: var(--color-blue-light);
}

.p-courses-intro__btn-wrap {
  text-align: center;
}

.p-courses-intro__btn {
  display: inline-flex;
  align-items: center;
  gap: 1.3rem;
  background: var(--color-navy);
  color: var(--color-white);
  font-size: 2.0rem;
  font-weight: 600;
  padding: 0.6rem 2.8rem;
  border-radius: 1.2rem;
  transition: opacity 0.2s, transform 0.15s;
}

.p-courses-intro__btn-icon {
  width: 4.8rem;
  height: auto;
}

.p-courses-intro__btn:hover {
  opacity: 0.85;
  transform: translateY(-0.1rem);
}

@media (min-width: 768px) {
  .p-courses-intro {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-courses-intro__img-wrap {
    left: 0;
  }

}

/* ==========================================
   p-topics（トピックス）
   ========================================== */
.p-topics {
  background-color: var(--color-blue-light);
}

/* 背景画像をmax-width内に収めるラッパー */
.p-topics__bg-wrap {
  max-width: var(--max-width);
  margin: 0 auto;
  background-image: url('../images/topics-bg-sp.png');
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: top center;
  padding-top: 29%;
  padding-bottom: 20%;
  padding-left: 17%;
  padding-right: 17%;
  min-height: calc(100vw * (437 / 425));
}

.p-topics__body {
  width: 100%;
  margin: 0 auto;
  max-height: 16rem;
  overflow-x: hidden;
  padding-top: 1rem;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: var(--color-navy-light) rgba(0, 0, 0, 0.08);
  padding-right: 0.4rem;
}

.p-topics__body::-webkit-scrollbar {
  width: 0.4rem;
}

.p-topics__body::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.06);
  border-radius: 10rem;
}

.p-topics__body::-webkit-scrollbar-thumb {
  background: var(--color-navy-light);
  border-radius: 10rem;
}

.p-topics__list {
  display: flex;
  flex-direction: column;
}

.p-topics__item {
  border-bottom: 0.1rem solid rgba(28, 43, 107, 0.15);
}

.p-topics__link {
  display: flex;
  align-items: baseline;
  gap: 1.6rem;
  padding: 1.2rem 0.4rem;
  transition: opacity 0.2s;
}

.p-topics__link:hover {
  opacity: 0.7;
}

.p-topics__date {
  font-size: clamp(1.3rem, 2vw, 1.6rem);
  color: var(--color-navy);
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}

.p-topics__text {
  font-size: clamp(1.4rem, 2.2vw, 1.7rem);
  color: var(--color-text);
  line-height: 1.5;
}

.p-topics__more-wrap {
  margin-top: 1.2rem;
  text-align: center;
}

.p-topics__more {
  font-size: 1.4rem;
  color: var(--color-navy);
  text-decoration: underline;
}

.p-topics__more:hover {
  opacity: 0.7;
}

/* トピックス直下 SNS */
.p-topics__sns {
  display: flex;
  justify-content: center;
  gap: 6.0rem;
  flex-wrap: wrap;
  padding: 1.44rem var(--side-pad-sp) 1.92rem;
  background: var(--color-blue-light);
}

.p-topics__sns-link {
  display: block;
  border-radius: 0.8rem;
  overflow: hidden;
  transition: opacity 0.2s;
}

.p-topics__sns-link:hover {
  opacity: 0.8;
}

.p-topics__sns-img {
  width: 8rem;
  height: auto;
  min-height: 5.0rem;
}


@media (max-width: 767px) {
  .p-topics__sns-link--instagram {
    padding-top: 1.2rem;
    padding-bottom: 1.2rem;
  }

  .p-topics__sns-link--instagram .p-topics__sns-img {
    width: 5.8rem;
  }
}

@media (min-width: 768px) {
  .p-topics__sns {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
    gap: 12rem;
  }

  .p-topics__sns-img {
    width: 16rem;
  }

  .p-topics__sns-link--instagram {
    padding-top: 2.0rem;
    padding-bottom: 1.76rem;
  }

  .p-topics__sns-link--instagram .p-topics__sns-img {
    width: 11.7rem;
  }
}

@media (min-width: 768px) {
  .p-topics__bg-wrap {
    /* PC: 1000×448（比率44.8%）、青ヘッダー高さ約28% → 44.8%×28%≈12.5% */
    background-image: url('../images/topics-bg-pc.png');
    padding-top: clamp(12rem, 12%, 15rem);
    padding-bottom: 8%;
    padding-left: 13%;
    padding-right: 13%;
    min-height: min(calc(100vw * (448 / 1000)), 44.8rem);
  }

  .p-topics__body {
    max-height: 16rem;
    width: 90%;
    margin: 0 auto;
  }

  .p-topics__date {
    font-size: 1.4rem;
  }

  .p-topics__text {
    font-size: 1.5rem;
  }
}

/* ==========================================
   p-catchphrase（自由と選択肢を手に入れる!!）
   ========================================== */
.p-catchphrase {
  background: #fceed5;
  padding: clamp(2.0rem, 4vw, 4.8rem) var(--side-pad-sp);
}

.p-catchphrase__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  text-align: center;
}

.p-catchphrase__text {
  font-size: clamp(2.2rem, 5vw, 4.0rem);
  font-weight: 900;
  color: var(--color-white);
  letter-spacing: 0.06em;
  line-height: 1.3;
}

/* ==========================================
   p-oshi（大分高校の推し）
   ========================================== */
.p-oshi {
  background: #fceed5;
  scroll-margin-top: var(--header-h-sp);
}
@media (min-width: 768px) {
  .p-oshi {
    scroll-margin-top: var(--header-h-pc);
  }
}

.p-oshi__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: clamp(2.4rem, 5vw, 5.6rem) var(--side-pad-sp);
}

.p-oshi__img {
  width: 100%;
  height: auto;
}

@media (min-width: 768px) {
  .p-oshi__inner {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }
}

/* ==========================================
   p-courses（学科・コース詳細）
   ========================================== */
.p-courses {
  padding: clamp(2.4rem, 5vw, 5.6rem) var(--side-pad-sp);
  scroll-margin-top: var(--header-h-sp);
}
@media (min-width: 768px) {
  .p-courses {
    scroll-margin-top: var(--header-h-pc);
  }
}

.p-courses__dept-block {
  max-width: var(--max-width);
  margin: 0 auto 4.0rem;
}

.p-courses__naritai-img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto 2.0rem;
}

@media (min-width: 768px) {
  .p-courses__naritai-img {
    max-width: 42rem;
  }
}

.p-courses__dept-label {
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 600;
  color: var(--color-navy);
  text-align: center;
  margin-bottom: 2.4rem;
}

.p-courses__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.6rem;
}

.p-courses__grid--2col {
  grid-template-columns: 1fr;
}

.p-courses__card-link {
  display: block;
  border-radius: 0.8rem;
  overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s;
}

.p-courses__card-link:hover {
  transform: translateY(-0.3rem);
  box-shadow: 0 0.6rem 1.6rem rgba(0, 0, 0, 0.14);
}

.p-courses__card-img {
  width: 100%;
  height: auto;
}

@media (min-width: 768px) {
  .p-courses {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-courses__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 2.4rem;
  }

  .p-courses__grid--2col {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ==========================================
   p-club（部活動）
   ========================================== */
.p-club {
  background: var(--color-white);
  padding-top: clamp(1.9rem, 3.6vw, 3.8rem);
  padding-bottom: clamp(3.2rem, 6vw, 6.4rem);
}

/* タイトル（バナー画像） */
.p-club__title {
  scroll-margin-top: var(--header-h-sp);
  margin-bottom: 3.2rem;
  line-height: 0;
  max-width: var(--max-width);
  margin-left: auto;
  margin-right: auto;
  padding: 0 var(--side-pad-sp);
}

.p-club__title-img {
  width: 100%;
  height: auto;
}

@media (min-width: 768px) {
  .p-club__title {
    scroll-margin-top: var(--header-h-pc);
    padding: 0 var(--side-pad-pc);
  }
}

/* SP：テキストリスト */
.p-club__text-list {
  display: flex;
  flex-direction: column;
  padding: 0 var(--side-pad-sp);
  max-width: var(--max-width);
  margin: 0 auto 3.2rem;
}

.p-club__text-item {
  border-bottom: 0.1rem solid var(--color-blue-light);
}

.p-club__text-link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 85%;
  margin: 0 auto;
  padding: 1.2rem 1.0rem;
  font-size: 1.5rem;
  color: var(--color-navy);
  font-weight: 600;
  transition: background 0.15s;
}

.p-club__text-link::after {
  content: '▶';
  font-size: 0.6em;
  flex-shrink: 0;
  margin-left: 0.8rem;
}

.p-club__text-link:hover {
  background: var(--color-blue-light);
}

/* PC：画像グリッド（SP時は非表示） */
.p-club__grid {
  display: none;
}

.p-club__item-link {
  display: block;
  border-radius: 0.6rem;
  overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s;
}

/* .p-club__item-link:hover {
  transform: translateY(-0.3rem);
  box-shadow: 0 0.6rem 1.6rem rgba(0, 0, 0, 0.16);
} */

.p-club__item-img {
  width: 100%;
  height: auto;
}

/* その他の部活動 */
.p-club__others {
  background: var(--color-white);
  padding: 2.4rem 0 4.0rem;
}

.p-club__others-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--side-pad-sp);
}

.p-club__others-title {
  font-size: clamp(1.6rem, 2.5vw, 2.0rem);
  font-weight: 600;
  color: var(--color-navy);
  text-align: center;
  margin-bottom: 1.2rem;
}

.p-club__others-box {
  border-top: 0.2rem solid var(--color-navy);
  border-bottom: 0.2rem solid var(--color-navy);
  border-left: 0.8rem solid #3abde8;
  border-right: 0.8rem solid #3abde8;
  border-radius: 0.4rem;
  padding: 1.6rem 2.0rem 1.6rem 3.0rem;
}

.p-club__others-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1.6rem;
  font-size: clamp(1.4rem, 2.5vw, 1.8rem);
  font-weight: 600;
  color: var(--color-navy);
  line-height: 1.9;
}

.p-club__others-item::before {
  content: '●';
  margin-right: 0.3rem;
}

@media (min-width: 600px) {
  .p-club__title {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-club__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2.0rem;
    padding: 0 var(--side-pad-pc);
    max-width: var(--max-width);
    margin: 0 auto 3.2rem;
  }

  .p-club__text-list {
    display: none;
  }

  .p-club__others-inner {
    padding: 0 var(--side-pad-pc);
  }

  .p-club__others-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.4rem 1.6rem;
    font-size: 1.5rem;
  }
}

/* ==========================================
   p-school-life（学校生活）
   ライトブルー背景 + 合成画像 + ボタン
   ========================================== */
.p-school-life {
  background: var(--color-blue-light);
  padding: clamp(3.2rem, 6vw, 6.4rem) var(--side-pad-sp);
}

.p-school-life__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4.8rem;
}

.p-school-life__img {
  width: 100%;
  height: auto;
}

.p-school-life__btn {
  display: inline-flex;
  align-items: center;
  gap: 1.3rem;
  background: var(--color-navy);
  color: var(--color-white);
  font-size: 2.0rem;
  font-weight: 600;
  padding: 0.6rem 3.2rem;
  border-radius: 1.2rem;
  transition: opacity 0.2s, transform 0.15s;
}

.p-school-life__btn-icon {
  width: 4.8rem;
  height: auto;
  flex-shrink: 0;
}

.p-school-life__btn:hover {
  opacity: 0.85;
  transform: translateY(-0.1rem);
}

@media (min-width: 768px) {
  .p-school-life {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-school-life__img {
    max-width: 60rem;
  }
}

/* ==========================================
   p-documents（各種資料 + 学校連絡先）
   ライトブルー背景
   ========================================== */
.p-documents {
  background: var(--color-blue-light);
  padding: clamp(3.2rem, 6vw, 6.4rem) var(--side-pad-sp);
}

.p-documents__inner {
  max-width: 72rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3.2rem;
}

.p-documents__img-col {
  width: 100%;
}

.p-documents__img-link {
  display: block;
  transition: opacity 0.2s;
}

.p-documents__img-link:hover {
  opacity: 0.85;
}

.p-documents__img {
  width: 100%;
  height: auto;
  max-width: 28.8rem;
  margin: 0 auto;
}

.p-documents__info-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.3rem;
  text-align: center;
  padding-top: 2.4rem;
  padding-bottom: 2.4rem;
}

.p-documents__logo {
  display: flex;
  align-items: center;
  gap: 1.0rem;
}

.p-documents__logo-img {
  width: clamp(5.9rem, 12.6vw, 8.4rem);
  height: auto;
  position: relative;
  top: 0.1rem;
  flex-shrink: 0;
}

.p-documents__school-name {
  font-size: clamp(2.8rem, 4.2vw, 4.4rem);
  font-weight: 600;
  color: var(--color-navy);
  line-height: 1;
}

.p-documents__address {
  font-style: normal;
  font-size: clamp(1.5rem, 2vw, 1.8rem);
  font-weight: 600;
  color: var(--color-navy);
  line-height: 1.4;
}

.p-documents__tel-link {
  display: block;
}

.p-documents__tel-link:hover {
  opacity: 0.7;
}

.p-documents__tel-img {
  width: 100%;
  max-width: 32rem;
  height: auto;
}

.p-documents__mail-link {
  display: block;
}

.p-documents__mail-img {
  width: 100%;
  max-width: 26rem;
  height: auto;
}

.p-documents__mail-link:hover {
  opacity: 0.7;
}

@media (min-width: 768px) {
  .p-documents {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-documents__inner {
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 4.0rem;
  }

  .p-documents__img-col {
    flex: 0 0 28rem;
  }

  .p-documents__img {
    width: 100%;
    max-width: 28rem;
    margin: 0;
  }

  .p-documents__info-col {
    flex: 1 1 0;
    min-width: 0;
    gap: 1.4rem;
  }

  .p-documents__logo-img {
    width: 5.9rem;
  }

  .p-documents__school-name {
    font-size: 3.0rem;
  }
}

/* ==========================================
   p-junior（大分中学校）
   黄色背景、テキスト見出し + 画像左 + テキスト右
   ========================================== */
.p-junior {
  background: var(--color-yellow);
}

/* 見出しバンド */
.p-junior__heading-wrap {
  padding: clamp(2.4rem, 4vw, 4.0rem) var(--side-pad-sp) 0;
}

.p-junior__heading-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.p-junior__heading-line {
  display: inline-block;
  background: var(--color-navy);
  color: var(--color-white);
  font-size: clamp(2.0rem, 4vw, 3.2rem);
  font-weight: 900;
  padding: 0.4rem 1.2rem;
  line-height: 1.3;
  align-self: flex-start;
}

/* コンテンツ */
.p-junior__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: clamp(2.4rem, 4vw, 4.0rem) var(--side-pad-sp) clamp(3.2rem, 6vw, 6.4rem);
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
}

.p-junior__img-col {
  width: 100%;
  max-width: 45rem;
  margin: 0 auto;
}

.p-junior__img {
  width: 100%;
  height: auto;
  border-radius: 0.8rem;
}

.p-junior__text-img {
  width: 100%;
  height: auto;
}

.p-junior__link {
  display: block;
  margin-top: 1.6rem;
}

.p-junior__link-img {
  width: 100%;
  height: auto;
}

.p-junior__link:hover {
  opacity: 0.7;
}

.p-junior__text-col {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
}

.p-junior__body {
  font-size: clamp(1.5rem, 2.5vw, 1.7rem);
  color: var(--color-navy);
  line-height: 2.0;
  font-weight: 600;
}

.p-junior__sub {
  font-size: 1.3rem;
  color: var(--color-navy);
  line-height: 1.8;
  opacity: 0.8;
}

.p-junior__btn {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  font-size: clamp(1.6rem, 3vw, 2.0rem);
  font-weight: 600;
  color: var(--color-navy);
  border-bottom: 0.2rem solid var(--color-navy);
  padding-bottom: 0.2rem;
  transition: opacity 0.2s;
}

.p-junior__btn:hover {
  opacity: 0.7;
}

@media (min-width: 768px) {
  .p-junior__heading-wrap {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-junior__inner {
    flex-direction: row;
    align-items: flex-start;
    gap: 5.6rem;
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-junior__img-col {
    flex: 0 0 auto;
    width: 45rem;
    max-width: 45rem;
    margin: 0;
  }

  .p-junior__text-col {
    flex: 1 1 50%;
    padding-top: 1.6rem;
  }

  .p-junior__body {
    font-size: 1.7rem;
  }
}

/* ==========================================
   p-pagetop
   ========================================== */
.p-pagetop {
  position: fixed;
  right: 1.6rem;
  bottom: 2.4rem;
  z-index: 10;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.p-pagetop--visible {
  opacity: 1;
  pointer-events: auto;
}

.p-pagetop__img {
  width: 5.6rem;
  height: auto;
  display: block;
  opacity: 0.80;
}

@media (min-width: 768px) {
  .p-pagetop {
    right: 2.4rem;
    bottom: 3.2rem;
  }

  .p-pagetop__img {
    width: 6.4rem;
  }
}

/* ==========================================
   p-footer
   ========================================== */
.p-footer {
  background: var(--color-navy);
  color: var(--color-white);
  padding: clamp(3.2rem, 6vw, 6.4rem) var(--side-pad-sp) 2.4rem;
}

.p-footer__inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

.p-footer__logo {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  margin-bottom: 2.4rem;
}

.p-footer__logo-img {
  width: 5.0rem;
  height: auto;
  flex-shrink: 0;
}

.p-footer__school-name {
  font-size: 1.8rem;
  font-weight: 600;
}

.p-footer__school-name-en {
  font-size: 1.0rem;
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.08em;
}

.p-footer__nav {
  margin-bottom: 2.4rem;
}

.p-footer__nav-list {
  display: flex;
  flex-direction: column;
}

.p-footer__nav-link {
  display: block;
  padding: 0.8rem 0;
  font-size: 1.4rem;
  color: rgba(255, 255, 255, 0.8);
  border-bottom: 0.1rem solid rgba(255, 255, 255, 0.1);
  transition: color 0.2s;
}

.p-footer__nav-link:hover {
  color: var(--color-white);
}

.p-footer__address {
  font-style: normal;
  font-size: 1.3rem;
  color: rgba(255, 255, 255, 0.75);
  line-height: 1.9;
  margin-bottom: 2.4rem;
}

.p-footer__mail-link {
  display: inline-block;
  color: var(--color-cyan);
  text-decoration: underline;
  transition: opacity 0.2s;
}

.p-footer__mail-link:hover {
  opacity: 0.8;
}

.p-footer__links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.2rem;
  padding-top: 2.0rem;
  border-top: 0.1rem solid rgba(255, 255, 255, 0.12);
  margin-bottom: 1.2rem;
}

.p-footer__link {
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.7);
  text-decoration: underline;
}

.p-footer__link:hover {
  opacity: 0.8;
}

.p-footer__link-sep {
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.4);
}

.p-footer__copyright {
  text-align: center;
}

.p-footer__copyright small {
  font-size: 1.1rem;
  color: rgba(255, 255, 255, 0.5);
}

@media (min-width: 768px) {
  .p-footer {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-footer__nav-list {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .p-footer__nav-link {
    padding: 0.6rem 1.6rem 0.6rem 0;
    border-bottom: none;
    margin-bottom: 0.6rem;
  }
}

/* ==========================================
   学校案内ページ（school-guide.html）
   ========================================== */

/* ヒーロー */
.p-guide-hero__img {
  width: 100%;
  height: auto;
  display: block;
}

/* パンくず */
.p-guide-breadcrumb {
  background: var(--color-blue-light);
  padding: 0.8rem var(--side-pad-sp);
  font-size: 1.2rem;
}

.p-guide-breadcrumb__inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

.p-guide-breadcrumb__list {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  list-style: none;
}

.p-guide-breadcrumb__item + .p-guide-breadcrumb__item::before {
  content: '>';
  color: var(--color-navy);
  margin-right: 0.4rem;
}

.p-guide-breadcrumb__link {
  color: var(--color-navy);
  text-decoration: underline;
}

.p-guide-breadcrumb__current {
  color: var(--color-text);
}

/* サブナビ */
.p-guide-subnav {
  background: var(--color-blue-light);
  padding: 1.6rem var(--side-pad-sp);
}

.p-guide-subnav__inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

.p-guide-subnav__list {
  display: flex;
  flex-wrap: wrap;
  gap: 1.0rem;
  list-style: none;
}

@media (max-width: 767px) {
  .p-guide-subnav__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}

.p-guide-subnav__link {
  display: block;
  padding: 0.8rem 1.6rem;
  color: var(--color-navy);
  font-size: 1.3rem;
  font-weight: 600;
  border: 0.1rem solid var(--color-navy);
  border-radius: 0.2rem;
  background: #f6fbfe;
  text-align: center;
  transition: background 0.2s, color 0.2s;
}

.p-guide-subnav__link:hover {
  background: var(--color-navy);
  color: var(--color-white);
}

/* セクション共通 */
.p-guide-section {
  background: var(--color-blue-light);
  padding: clamp(3.2rem, 6vw, 6.4rem) var(--side-pad-sp);
}

.p-guide-section--alt {
  background: var(--color-blue-light);
}

.p-guide-section__inner {
  max-width: 80rem;
  margin: 0 auto;
}

.p-guide-section__heading {
  margin-bottom: 3.2rem;
}

@media (max-width: 767px) {
  .p-guide-section__inner {
    width: 95%;
  }

  .p-guide-section__heading {
    width: calc(100vw - var(--side-pad-sp));
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}

.p-guide-section__heading-img {
  width: 100%;
  height: auto;
  display: block;
}

/* 学校長挨拶 */
.p-guide-principal {
  overflow: hidden;
}

.p-guide-principal__float-block {
  display: flex;
  float: none;
  flex-direction: column;
  gap: 1.2rem;
  margin-bottom: 2.0rem;
}

.p-guide-principal__catchphrase {
  display: block;
  width: 100%;
  height: auto;
}

.p-guide-principal__photo-row {
  display: flex;
  gap: 1.6rem;
  align-items: flex-start;
}

.p-guide-principal__photo {
  display: block;
  width: 50%;
  height: auto;
  object-fit: contain;
  border-radius: 0.4rem;
}

.p-guide-principal__profile {
  flex: 1;
}

.p-guide-principal__school {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 0.4rem;
}

.p-guide-principal__gen {
  font-size: 1.3rem;
  color: var(--color-text);
  margin-top: 0.8rem;
  margin-bottom: 0rem;
}

.p-guide-principal__name {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: 0.15em;
  margin-bottom: 1.2rem;
}

.p-guide-principal__career {
  font-size: 1.3rem;
  line-height: 1.9;
  color: var(--color-text);
}

.p-guide-principal__career > p {
  margin-left: -0.4em;
}

.p-guide-principal__career ul {
  list-style: none;
  padding: 0;
  margin: 0.4rem 0 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.p-guide-principal__body {
  font-size: 1.5rem;
  line-height: 1.9;
  color: var(--color-text);
}

.p-guide-principal__body p + p {
  margin-top: 1.2rem;
}

.p-guide-principal__clearfix {
  clear: both;
}

@media (min-width: 768px) {
  .p-guide-breadcrumb {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-guide-subnav {
    /* ボタン高さ ≈ 1.26rem×2 + 1.5rem×1.5 = 4.77rem → ×1.3 ≈ 6.2rem */
    padding: 6.2rem var(--side-pad-pc) 2.0rem;
  }

  .p-guide-subnav__list {
    flex-wrap: nowrap;
    gap: 1.6rem;
  }

  .p-guide-subnav__item {
    flex: 1;
  }

  .p-guide-subnav__link {
    font-size: 1.5rem;
    padding: 1.26rem 1.0rem;
    text-align: center;
    white-space: nowrap;
  }

  .p-guide-section {
    padding-left: var(--side-pad-pc);
    padding-right: var(--side-pad-pc);
  }

  .p-guide-principal__float-block {
    float: left;
    width: 40rem;
    margin-right: 3.2rem;
    margin-bottom: 1.2rem;
  }

  .p-guide-principal__school {
    font-size: 2.0rem;
    font-weight: 700;
  }

  .p-guide-principal__gen {
    font-size: 1.6rem;
    font-weight: 700;
  }

  .p-guide-principal__name {
    font-size: 2.8rem;
    font-weight: 700;
  }
}

@media (max-width: 767px) {
  .p-guide-access__station-label {
    width: 40%;
  }

  .p-guide-principal__name {
    font-size: 1.8rem;
  }

  .p-guide-principal__gen {
    font-size: 1.1rem;
  }

  .p-guide-principal__career {
    font-size: 1.1rem;
  }

  .p-guide-principal__career ul {
    font-size: 1.05rem;
  }

  .p-guide-philosophy__values-list {
    padding-left: 0.8em;
  }

  .p-guide-access__schoolbus {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .p-guide-access__bus-img {
    width: 12rem;
  }

  .p-guide-access__route-stops {
    justify-content: center;
  }

}

/* 教育理念 */
.p-guide-philosophy {
  display: flex;
  flex-direction: column;
  gap: 3.2rem;
}

.p-guide-philosophy__h3 {
  font-size: clamp(1.5rem, 2vw, 1.8rem);
  font-weight: 600;
  color: var(--color-navy);
  margin-bottom: 1.2rem;
}

.p-guide-philosophy__ol,
.p-guide-philosophy__ul {
  padding-left: 2.0rem;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  font-size: 1.5rem;
  line-height: 1.8;
}

.p-guide-philosophy__ol {
  list-style: decimal;
  margin-top: 1.2rem;
  line-height: 1.44;
}

.p-guide-philosophy__ol li {
  font-weight: 700;
}

.p-guide-philosophy__ul {
  list-style: none;
  padding-left: 0;
}

.p-guide-philosophy__ul li {
  padding: 1.2rem 0;
  border-bottom: 0.1rem solid #d0d8e8;
  line-height: 1.8;
}

.p-guide-philosophy__ul li:first-child {
  border-top: 0.1rem solid #d0d8e8;
}

.p-guide-philosophy__plain-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.p-guide-philosophy__plain-list li {
  font-size: 1.5rem;
  line-height: 1.44;
  margin-top: 0.75rem;
  margin-bottom: 0.75rem;
}

.p-guide-philosophy__plain-list--keywords li {
  margin-top: 1.1rem;
  margin-bottom: 1.1rem;
}

.p-guide-philosophy__subtitle2 {
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 0.8rem;
}

.p-guide-philosophy__kunkun {
  font-size: clamp(2.0rem, 3vw, 2.6rem);
  font-weight: 700;
  color: var(--color-text);
  text-align: center;
  margin-bottom: 1.2rem;
}

.p-guide-philosophy__values {
  background: var(--color-white);
  border-radius: 0.4rem;
  padding: 1.6rem;
  margin-top: 1.2rem;
  margin-bottom: 1.6rem;
}

.p-guide-philosophy__values-title {
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 0.8rem;
}

.p-guide-philosophy__values-list {
  list-style: none;
  padding-left: 1.5em;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  font-size: 1.4rem;
  line-height: 1.8;
}

.p-guide-philosophy__keywords {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  margin-bottom: 1.6rem;
}

.p-guide-philosophy__keywords p {
  margin: 0;
  padding: 0.8rem 1.2rem;
  background: var(--color-white);
  border-left: 0.3rem solid var(--color-navy);
  font-size: 1.4rem;
  line-height: 1.6;
  white-space: nowrap;
}

@media (min-width: 768px) {
  .p-guide-philosophy__keywords {
    flex-direction: row;
    gap: 1.2rem;
  }

  .p-guide-philosophy__keywords p {
    flex: 1;
    white-space: normal;
    font-size: 1.35rem;
  }
}

/* 大分高校の歩み */
.p-guide-history__list {
  display: flex;
  flex-direction: column;
}

.p-guide-history__row {
  display: flex;
  gap: 1.6rem;
  padding: 1.0rem 0;
  border-bottom: 0.1rem solid #d0dff0;
  font-size: 1.4rem;
  line-height: 1.7;
}

.p-guide-history__year {
  flex: 0 0 10rem;
  font-weight: 600;
  color: var(--color-text);
  white-space: nowrap;
}

.p-guide-history__event {
  flex: 1 1 0;
  color: var(--color-text);
}

.p-guide-history__event p {
  margin: 0;
  line-height: 1.8;
}

.p-guide-history__event p + p {
  margin-top: 0.6rem;
}

@media (min-width: 768px) {
  .p-guide-history__row {
    font-size: 1.5rem;
    gap: 2.4rem;
  }

  .p-guide-history__year {
    flex: 0 0 12rem;
  }
}

/* キャンパス紹介 */
.p-guide-campus__placeholder {
  text-align: center;
  color: var(--color-text);
  font-size: 1.6rem;
  padding: 4.0rem 0;
}

/* アクセス */
.p-guide-access {
  display: flex;
  flex-direction: column;
  gap: 3.2rem;
  max-width: 60rem;
  margin: 0 auto;
}

/* バス路線エリア */
.p-guide-access__bus-routes {
  display: flex;
  flex-direction: column;
  gap: 2.0rem;
}

.p-guide-access__station-block {
  display: flex;
  align-items: flex-start;
  gap: 1.6rem;
}

@media (max-width: 767px) {
  .p-guide-access__station-block {
    flex-direction: column;
    gap: 1.2rem;
  }
}

.p-guide-access__station-label {
  flex-shrink: 0;
  display: flex;
  flex-direction: row;
  gap: 0.3em;
  align-items: center;
  justify-content: center;
  background: var(--color-cyan);
  color: var(--color-white);
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.5;
  padding: 0.6rem 1.0rem;
  border-radius: 0.3rem;
  min-width: 7.2rem;
  text-align: center;
}

.p-guide-access__station-label--teal {
  background: #26c6da;
}

.p-guide-access__station-label--teal ~ ul .p-guide-access__route-mark {
  color: #26c6da;
}

.p-guide-access__route-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}

.p-guide-access__route-item {
  display: flex;
  gap: 0.4rem;
  align-items: flex-start;
  font-size: 1.4rem;
  line-height: 1.7;
  color: var(--color-text);
}

.p-guide-access__route-mark {
  flex-shrink: 0;
  color: var(--color-cyan);
  font-weight: 600;
}

.p-guide-access__route-text {
  flex: 1;
}

.p-guide-access__route-sub {
  font-size: 1.2rem;
  color: var(--color-text);
  margin-left: 0;
}

.p-guide-access__route-time {
  display: inline;
  margin-left: 0.4rem;
  color: var(--color-text);
  letter-spacing: 0.02em;
}

/* スクールバス */
.p-guide-access__schoolbus {
  display: flex;
  gap: 2.0rem;
  align-items: center;
  background: var(--color-white);
  border: 0.1rem solid #c8d8ec;
  border-radius: 0.4rem;
  padding: 1.6rem;
}

.p-guide-access__bus-img {
  width: 9rem;
  flex-shrink: 0;
  height: auto;
}

.p-guide-access__schoolbus-info {
  flex: 1;
}

.p-guide-access__schoolbus-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-navy);
  margin-bottom: 1.0rem;
}

.p-guide-access__route-stops {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.2rem 0;
  margin-bottom: 0.4rem;
}

.p-guide-access__stop {
  font-size: 1.3rem;
  background: var(--color-blue-light);
  border: 0.1rem solid var(--color-blue-mid);
  border-radius: 0.2rem;
  padding: 0.2rem 0.8rem;
  color: var(--color-navy);
  font-weight: 600;
}

.p-guide-access__stop-suffix {
  font-size: 0.8em;
  margin-left: 0.3em;
}

.p-guide-access__stop--start,
.p-guide-access__stop--end {
  background: var(--color-cyan);
  color: var(--color-white);
  border-color: var(--color-cyan);
}

.p-guide-access__stop-arrow {
  display: inline-block;
  width: 2.4rem;
  height: 0.4rem;
  background: var(--color-cyan);
  font-size: 0;
  vertical-align: middle;
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .p-guide-access__stop {
    font-size: 1.1rem;
    font-weight: 400;
  }

  .p-guide-access__stop-arrow {
    width: 1.68rem;
  }
}

/* マップ */
.p-guide-access__map {
  margin-bottom: 6.4rem;
}

.p-guide-access__map-iframe {
  width: 100%;
  aspect-ratio: 4 / 3;
  height: auto;
  display: block;
}

.p-guide-access__map-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  background: #d0dff0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  color: var(--color-navy);
  border-radius: 0.4rem;
}

@media (min-width: 768px) {
  .p-guide-access__bus-routes {
    gap: 2.4rem;
  }

  .p-guide-access__station-label {
    flex-direction: column;
    gap: 0;
    min-width: 8.0rem;
    font-size: 1.4rem;
    padding: 0.8rem 1.2rem;
  }

  .p-guide-access__route-item {
    font-size: 1.5rem;
  }

  .p-guide-access__schoolbus {
    gap: 3.2rem;
    padding: 2.4rem;
  }

  .p-guide-access__bus-img {
    width: 12rem;
  }

  .p-guide-access__stop {
    font-size: 1.4rem;
    padding: 0.3rem 1.0rem;
  }

  .p-guide-access__map-placeholder {
    aspect-ratio: 16 / 9;
  }

  .p-guide-access__map-iframe {
    aspect-ratio: 16 / 9;
  }
}
