/* ---------- リセット & 基本 ---------- */
.nyugaku{ -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
.nyugaku{
  margin: 0;
  line-height: 1.75;
  background: #ffffff;
}
.nyugaku a{ /*color: inherit;*/ text-decoration: none; }
.nyugaku a:hover{ text-decoration: none; }
.nyugaku button{  cursor: pointer; }

.nyugaku{
  /* Brand */
  --blue: #1375BA;
  --blue-deep: #0E5E96;
  --blue-soft: #E8F1FB;
  --blue-line: #BFD8EF;
  --orange: #E97433;
  --orange-deep: #CC5F23;
  --line: #06C755;
  --line-deep: #04A547;

  /* Surfaces */
  --bg: #FFFFFF;
  --bg-gray: #F5F7FA;
  --bg-cream: #FFF6E2;
  --bg-cream-strong: #FCEDC9;
  --bg-blue-soft: #EEF5FC;

  /* Text */
  --text: #1F2A37;
  --text-sub: #5A6573;
  --text-mute: #8A93A0;
  --link: #1860A8;

  /* Lines */
  --border: #E1E6EE;
  --border-strong: #C7D0DC;

  /* Layout */
  --container: 1120px;
  --main-w: 760px;
  --aside-w: 280px;
  --gap: 40px;

  --radius: 8px;
  --radius-lg: 14px;
}

/* ============================================================
   HEADER
   ============================================================ */
.nyugaku .site-header{ position: sticky; top: 0; z-index: 100; background: #fff; border-bottom: 1px solid var(--border); }
.nyugaku .header-top{
  background: var(--blue-deep); color: #fff;
}
.nyugaku .header-top__inner{
  max-width: var(--container); margin: 0 auto;
  padding: 6px 24px; display: flex; gap: 18px; justify-content: flex-end; flex-wrap: wrap;
}
.nyugaku .header-top__inner a{ color: #fff; opacity: .9; }
.nyugaku .header-top__inner a:hover{ opacity: 1; text-decoration: underline; }

.nyugaku .header-main{
  max-width: var(--container); margin: 0 auto;
  padding: 12px 24px; display: flex; align-items: center; gap: 16px;
}
.nyugaku .header-logo{ display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.nyugaku .header-logo__tag{
  font-size: 0.8rem; color: var(--text-sub); letter-spacing: .04em;
  border: 1px solid var(--border); padding: 2px 8px; border-radius: 999px;
  white-space: nowrap;
}
.nyugaku .header-logo__mark{
  width: 44px; height: 44px; border-radius: 8px;
  background: linear-gradient(135deg, #1A6BB8 0%, #0F4A87 100%);
  color: #fff; display: grid; place-items: center; font-weight: 700; font-size: 18px;
  letter-spacing: .02em;
}
.nyugaku .header-logo__name{ display: flex; flex-direction: column; line-height: 1.2; }
.nyugaku .header-logo__name strong{ font-weight: 700; color: var(--text); font-size: 15px; }
.nyugaku .header-logo__name small{ font-size: 0.8rem; color: var(--text-sub); }

.nyugaku .header-spacer{ flex: 1; }

.nyugaku .header-phone{
  display: flex; align-items: center; gap: 8px;
  font-weight: 700; color: var(--text);
}
.nyugaku .header-phone__num{ font-size: 22px; letter-spacing: .02em; line-height: 1; color: var(--blue-deep); }
.nyugaku .header-phone__hours{ font-size: 0.8rem; color: var(--text-sub); font-weight: 400; }
.nyugaku .header-phone svg{ color: var(--orange); }

.nyugaku .header-ctas{ display: flex; gap: 8px; }
.nyugaku .hcta{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 14px; border-radius: 6px;  font-weight: 700;
  color: #fff; text-decoration: none; line-height: 1.2;
}
.nyugaku .hcta:hover{ text-decoration: none; opacity: .92; }
.nyugaku .hcta--doc{ background: var(--orange); }
.nyugaku .hcta--exp{ background: var(--blue); }
.nyugaku .hcta--line{ background: var(--line); }
.nyugaku .hcta svg{ width: 18px; height: 18px; }

.nyugaku .header-burger{ display: none; }

@media (max-width: 1023px) {
  .nyugaku .header-top{ display: none; }
  .nyugaku .header-phone__hours, .nyugaku .hcta span{ display: none; }
  .nyugaku .hcta{ padding: 10px; }
}
@media (max-width: 767px) {
  .nyugaku .header-main{ padding: 10px 14px; gap: 10px; }
  .nyugaku .header-phone{ display: none; }
  .nyugaku .header-ctas{ display: none; }
  .nyugaku .header-burger{
    display: inline-flex; align-items: center; justify-content: center;
    width: 42px; height: 42px; border: 1px solid var(--border); border-radius: 6px;
    background: #fff; color: var(--text);
  }
  .nyugaku .header-logo__tag{ display: none; }
  .nyugaku .header-logo__name strong{  }
}

/* ============================================================
   BREADCRUMB
   ============================================================ */
.nyugaku .breadcrumb{
  background: var(--bg-gray); border-bottom: 1px solid var(--border);
}
.nyugaku .breadcrumb__inner{
  max-width: var(--container); margin: 0 auto;
  padding: 10px 24px;  color: var(--text-sub);
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.nyugaku .breadcrumb a{ color: var(--text-sub); }
.nyugaku .breadcrumb a:hover{ color: var(--blue); }
.nyugaku .breadcrumb__sep{ color: var(--text-mute); }
.nyugaku .breadcrumb__current{ color: var(--text); font-weight: 500; }

@media (max-width: 767px) {
  .nyugaku .breadcrumb__inner{ padding: 8px 14px; font-size: 0.8rem; }
}

/* ============================================================
   LAYOUT (page title + 2-column)
   ============================================================ */
.nyugaku .page-title-bar{
  background: var(--bg-blue-soft);
  border-bottom: 1px solid var(--border);
}
.nyugaku .page-title-bar__inner{
  max-width: var(--container); margin: 0 auto;
  padding: 28px 24px; display: flex; align-items: center; gap: 18px;
}
.nyugaku .page-title-bar__icon{
  width: 56px; height: 56px; flex-shrink: 0; border-radius: 50%;
  background: #fff; display: grid; place-items: center; color: var(--blue);
  box-shadow: 0 2px 8px rgba(24, 96, 168, .12);
}
.nyugaku .page-title-bar__text{ display: flex; flex-direction: column; gap: 2px; }
.nyugaku .page-title-bar__kicker{  color: var(--blue); font-weight: 700; letter-spacing: .08em; }
.nyugaku .page-title-bar__title{ margin: 0; font-size: 26px; font-weight: 700; color: var(--text); letter-spacing: .02em; }

.nyugaku .layout{
  max-width: var(--container); margin: 0 auto;
  padding: 40px 24px 80px;
  display: grid; grid-template-columns: minmax(0, 1fr) var(--aside-w);
  gap: var(--gap);
  align-items: start;
}

/* Content-only wrapper (本番組み込み用) -- host page provides its own container/padding */
.nyugaku .gakuhi-content{
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 40px 20px;
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .nyugaku .gakuhi-content{ padding: 24px 14px; }
}
.nyugaku .main-col{ min-width: 0; }
.nyugaku .aside-col{ position: sticky; top: 84px; }

@media (max-width: 1023px) {
  .nyugaku .layout{ grid-template-columns: 1fr; padding-bottom: 100px; }
  .nyugaku .aside-col{ position: static; }
}
@media (max-width: 767px) {
  .nyugaku .page-title-bar__inner{ padding: 18px 14px; gap: 12px; }
  .nyugaku .page-title-bar__icon{ width: 44px; height: 44px; }
  .nyugaku .page-title-bar__title{ font-size: 19px; }
  .nyugaku .layout{ padding: 24px 14px 120px; }
}

/* ============================================================
   ASIDE (right sidebar)
   ============================================================ */
.nyugaku .aside-block{ border: 1px solid var(--border); border-radius: var(--radius-lg); background: #fff; overflow: hidden; }
.nyugaku .aside-block + .aside-block{ margin-top: 20px; }

.nyugaku .aside-block__head{
  padding: 14px 16px; background: var(--blue);
  color: #fff; font-weight: 700; font-size: 14px;
  display: flex; align-items: center; gap: 8px;
}
.nyugaku .aside-nav{ list-style: none; margin: 0; padding: 6px 0; }
.nyugaku .aside-nav li{ border-bottom: 1px solid var(--border); }
.nyugaku .aside-nav li:last-child{ border-bottom: 0; }
.nyugaku .aside-nav a{
  display: flex; align-items: center; gap: 8px;
  padding: 11px 16px; color: var(--text);  line-height: 1.5;
  text-decoration: none;
}
.nyugaku .aside-nav a:hover{ background: var(--bg-blue-soft); color: var(--blue); text-decoration: none; }
.nyugaku .aside-nav .is-current{
  background: var(--blue-soft); color: var(--blue-deep); font-weight: 700;
  position: relative;
}
.nyugaku .aside-nav .is-current::before{
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--blue);
}
.nyugaku .aside-nav__arrow{ margin-left: auto; color: var(--text-mute); flex-shrink: 0; }
.nyugaku .is-current .aside-nav__arrow{ color: var(--blue); }

.nyugaku .aside-cta{ padding: 16px; display: flex; flex-direction: column; gap: 10px; background: var(--bg-cream); }
.nyugaku .aside-cta__head{
   font-weight: 700; color: var(--text); text-align: center; margin-bottom: 4px;
}
.nyugaku .aside-cta__btn{
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px; border-radius: 6px; font-weight: 700; color: #fff; font-size: 14px;
  text-decoration: none;
}
.nyugaku .aside-cta__btn:hover{ text-decoration: none; opacity: .92; }
.nyugaku .aside-cta__btn--doc{ background: var(--orange); }
.nyugaku .aside-cta__btn--exp{ background: var(--blue); }
.nyugaku .aside-cta__btn--line{ background: var(--line); }
.nyugaku .aside-cta__phone{
  background: #fff; border: 1px solid var(--border); border-radius: 6px;
  padding: 10px; text-align: center;
}
.nyugaku .aside-cta__phone strong{ display: block; font-size: 19px; color: var(--blue-deep); line-height: 1.2; }
.nyugaku .aside-cta__phone small{ font-size: 0.8rem; color: var(--text-sub); }

@media (max-width: 1023px) {
  .nyugaku .aside-col{ margin-top: 40px; }
}

/* ============================================================
   SECTION GENERAL
   ============================================================ */
.nyugaku .section{ margin-bottom: 56px; }
.nyugaku .section:last-child{ margin-bottom: 0; }

.nyugaku .section-head{
  display: flex; align-items: center; gap: 12px;
  padding-bottom: 14px; margin-bottom: 22px;
  border-bottom: 2px solid var(--blue);
}
.nyugaku .section-head__num{
  width: 36px; height: 36px; flex-shrink: 0; border-radius: 50%;
  background: var(--blue); color: #fff; font-weight: 700; font-size: 15px;
  display: grid; place-items: center;
}
.nyugaku .section-head__title{
  margin: 0; font-size: 22px; font-weight: 700; line-height: 1.4; color: var(--text);
  letter-spacing: .01em;
}
.nyugaku .section-head__title em{
  font-style: normal; color: var(--orange); font-weight: 700;
}
.nyugaku .section-head__tag{
  margin-left: auto; font-size: 0.8rem; padding: 4px 8px; border-radius: 4px;
  background: var(--bg-cream-strong); color: #8B6B1A; font-weight: 700; white-space: nowrap;
}

.nyugaku .section-lead{ /*color: var(--text-sub);font-size: 14px; */ margin: 0 0 18px; }

@media (max-width: 767px) {
  .nyugaku .section{ margin-bottom: 44px; }
  .nyugaku .section-head__title{ font-size: 17px; }
  .nyugaku .section-head__num{ width: 30px; height: 30px;  }
  .nyugaku .section-head{ gap: 10px; padding-bottom: 10px; margin-bottom: 18px; }
}

/* ============================================================
   SECTION 1: FV
   ============================================================ */


/*.nyugaku .fv__visual{
  aspect-ratio: 4 / 3; border-radius: var(--radius); overflow: hidden;
  background: linear-gradient(135deg, #B8D4ED 0%, #DDEAF5 60%, #F0E5D2 100%);
  display: grid; place-items: center; color: rgba(15, 74, 135, .5);
  position: relative;
}
.nyugaku .fv__visual::after{
  content: "イメージ写真 / 親子で笑顔の生徒"; position: absolute; bottom: 12px; left: 12px;
  font-size: 0.8rem; background: rgba(255,255,255,.8); color: var(--text-sub);
  padding: 3px 8px; border-radius: 4px;
}
.nyugaku .fv__visual-icon{ width: 64px; height: 64px; opacity: .5; }


.nyugaku .fv{
  display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: center;
  background: var(--bg-blue-soft); border-radius: var(--radius-lg);
  padding: 32px;
}
.nyugaku .fv__visual{
  aspect-ratio: 4 / 3; border-radius: var(--radius); overflow: hidden;
  background: #EEF5FC;
  position: relative;
}
*/

.nyugaku .fv{
  display: grid; grid-template-columns: 1.2fr 0.6fr; 
  gap: 30px;            /* 28px から 40px に広げてゆとりを持たせる */
  align-items: center;
  background: none;     /* 背景の薄いブルーを無くす */
  border-radius: 0;     /* 外枠の角丸を無くす */
  
}

/* ▼ 2. ここを書き換える：画像が持っている背景色を消す ▼ */
.nyugaku .fv__visual{
  aspect-ratio: 4 / 3; border-radius: var(--radius); overflow: hidden;
  background: none;     /* 万が一画像読み込み前に一瞬見える背景色も消しておく */
  position: relative;
  order: 2;
}

c

.nyugaku .fv__text{ padding: 6px 0;order: 1; }
.nyugaku .fv__kicker{
  display: inline-block;  font-weight: 700; color: var(--blue);
  background: #fff; padding: 4px 12px; border-radius: 999px; margin-bottom: 16px;
  border: 1px solid var(--blue-line);
}
.nyugaku .fv__title{
  margin: 0 0 18px; font-size: 30px; font-weight: 700; line-height: 1.4;
  color: var(--text); letter-spacing: .01em; text-wrap: pretty;
}
.nyugaku .fv__title strong{ color: var(--blue-deep); }
.nyugaku .fv__copy{
  /*color: var(--text-sub);*/ 
}
.nyugaku .fv__ctas{ display: flex; gap: 12px; flex-wrap: wrap; }

@media (max-width: 767px) {
  .nyugaku .fv{ grid-template-columns: 1fr; /*padding: 18px;*/ gap: 18px; }
  .nyugaku .fv__title{ font-size: 22px; }
  .nyugaku .fv__visual img{padding:0 30px;}
}

/* ============================================================
   SECTION 2: 個別相談 (callout)
   ============================================================ */
.nyugaku .advice-callout{
  border: 1px solid var(--blue-line); border-radius: var(--radius-lg);
  background: #fff; padding: 24px;
  display: grid; grid-template-columns: auto 1fr auto; gap: 20px; align-items: center;
}
.nyugaku .advice-callout__icon{
  width: 56px; height: 56px; border-radius: 50%; background: var(--blue-soft);
  color: var(--blue); display: grid; place-items: center;
}
.nyugaku .advice-callout__body strong{
  display: block; font-size: 17px; font-weight: 700; color: var(--text); margin-bottom: 4px;
}
.nyugaku .advice-callout__body p{ margin: 0;  /*color: var(--text-sub);*/ }
.nyugaku .advice-callout__actions{ display: flex; gap: 10px; flex-wrap: wrap; }

@media (max-width: 767px) {
  .nyugaku .advice-callout{ grid-template-columns: 1fr; padding: 18px; gap: 14px; text-align: center; }
  .nyugaku .advice-callout__icon{ margin: 0 auto; }
  .nyugaku .advice-callout__actions{ width: 100%; }
}

/* ============================================================
   SECTION 3: 学費イメージ
   ============================================================ */
.nyugaku .fee-base{
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  background: #fff; overflow: hidden;max-width: 850px; margin: 0 auto;
}
.nyugaku .fee-base__head{
  background: var(--blue); color: #fff; padding: 10px 18px;
   font-weight: 700; letter-spacing: .04em;
}
.nyugaku .fee-base__body{ padding: 22px; display: flex; align-items: center; gap: 18px; }
.nyugaku .fee-base__icon{
  width: 64px; height: 64px; flex-shrink: 0; border-radius: 14px;
  background: var(--blue-soft); color: var(--blue); display: grid; place-items: center;
}
.nyugaku .fee-base__name{ flex: 1; }
.nyugaku .fee-base__name strong{ display: block; font-size: 18px; font-weight: 700; color: var(--text); }
.nyugaku .fee-base__name small{ display: block; font-size: 0.8rem; margin-top: 4px; }
.nyugaku .fee-base__price{ text-align: right; flex-shrink: 0; }
.nyugaku .fee-base__price strong{
  display: block; font-size: 14px; color: var(--text-sub); font-weight: 500;
}
.nyugaku .fee-base__price big{
  font-size: 32px; font-weight: 700; color: var(--orange); letter-spacing: .01em;
}
.nyugaku .fee-base__price big sub{ font-size: 14px; vertical-align: baseline; margin-left: 2px; color: var(--orange-deep); }
.nyugaku .fee-base__price small{ font-size: 0.8rem; color: var(--text-mute); display: block; }

/* school-by-school price list */
.nyugaku .fee-schools{
  border-top: 1px solid var(--border);
  background: var(--bg-gray);
  padding: 18px 22px 20px;
}
.nyugaku .fee-schools__head{
  display: flex; align-items: center; gap: 6px;
  font-weight: 700; 
  letter-spacing: .06em; margin-bottom: 10px;
}
.nyugaku .fee-schools__head svg{ color: var(--blue); }
.nyugaku .fee-schools__list{
  list-style: none; margin: 0 0 12px; padding: 0;
  border: 1px solid var(--border); border-radius: 8px; overflow: hidden; background: #fff;
}
.nyugaku .fee-schools__row{
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; gap: 16px;
}
.nyugaku .fee-schools__row + .fee-schools__row{ border-top: 1px solid var(--border); }
.nyugaku .fee-schools__name{
  font-size: 21px; font-weight: 700; color: var(--text); line-height: 1.5;
  display: flex; flex-direction: column; gap: 4px;
}
@media (max-width: 767px) {
  .nyugaku .fee-schools__name{
  font-size: 1rem; 
}
}

.nyugaku .fee-schools__sub{
  font-weight: 400; color: var(--text-sub);
}
.nyugaku .fee-schools__sub strong{ color: var(--orange-deep); font-weight: 700; }
.nyugaku .fee-schools__price{
  flex-shrink: 0; display: inline-flex; align-items: baseline; gap: 2px;
  color: var(--orange);
}
.nyugaku .fee-schools__price big{
  font-size: 24px; font-weight: 700; line-height: 1;  letter-spacing: .01em;
}


/*追加*/
.nyugaku .fee-schools__price-box {
  display: flex;
  flex-direction: column; /* 中身（金額と注釈）を縦に並べる */
  align-items: flex-end;   /* 右寄せにする */
}
/* スマホ版（画面幅767px以下）のときだけの調整 */
@media (max-width: 767px) {
  .nyugaku .fee-schools__price-box {
    width: 100%; /* 箱を横幅いっぱいにする */
  }
}


.nyugaku .fee-schools__price small{  color: var(--orange-deep); font-weight: 700; }
.nyugaku .fee-schools__notes{
  margin: 0; font-size: 0.8rem; line-height: 1.8;
}

@media (max-width: 767px) {
  .nyugaku .fee-schools{ padding: 14px; }
  .nyugaku .fee-schools__row{ padding: 12px 14px; flex-direction: column; align-items: flex-start; gap: 6px; }
  .nyugaku .fee-schools__price{ align-self: flex-end; }
}

.nyugaku .fee-plus{
  position: relative; text-align: center; padding: 18px 0;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.nyugaku .fee-plus::before, .nyugaku .fee-plus::after{
  content: ""; position: absolute; left: 50%; width: 1px;
  background: var(--border-strong);
}
.nyugaku .fee-plus::before{ top: 0; height: 16px; }
.nyugaku .fee-plus::after{ bottom: 0; height: 16px; }
.nyugaku .fee-plus__mark{
  width: 40px; height: 40px; border-radius: 50%; background: var(--orange);
  color: #fff; display: grid; place-items: center; font-size: 22px; font-weight: 700;
  box-shadow: 0 2px 6px rgba(233, 116, 51, .35);
}
.nyugaku .fee-plus__label{  font-weight: 500; }

.nyugaku .option-group{
  border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 22px;
  background: #fff;
}
.nyugaku .option-group__head{
  display: flex; align-items: center; gap: 10px;
  font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 16px;
}
.nyugaku .option-group__head svg{ color: var(--blue); }
.nyugaku .option-grid{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
}
.nyugaku .option-card{
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px 8px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg-gray); text-decoration: none; color: var(--text);
  transition: all .15s;
}
.nyugaku .option-card:hover{ border-color: var(--blue); background: var(--bg-blue-soft); text-decoration: none; }
.nyugaku .option-card__icon{
  width: 44px; height: 44px; border-radius: 50%; background: #fff;
  color: var(--blue); display: grid; place-items: center;
  border: 1px solid var(--border);
}
.nyugaku .option-card__label{  font-weight: 700; text-align: center; line-height: 1.4; }

.nyugaku .option-foot{
   color: /*var(--text-sub);*/ text-align: center;
  margin-top: 14px; line-height: 1.7;
}
.nyugaku .option-foot a{ color: var(--blue); font-weight: 700; text-decoration: underline; }

.nyugaku .contact-quick{
  margin-top: 18px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.nyugaku .contact-quick__btn{
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border-radius: 8px; text-decoration: none;
  border: 1px solid var(--border); background: #fff;
}
.nyugaku .contact-quick__btn:hover{ border-color: var(--blue); text-decoration: none; }
.nyugaku .contact-quick__icon{
  width: 36px; height: 36px; border-radius: 50%; display: grid; place-items: center; flex-shrink: 0;
  color: #fff;
}
.nyugaku .contact-quick__icon--line{ background: var(--line); }
.nyugaku .contact-quick__icon--tel{ background: var(--blue); }
.nyugaku .contact-quick__text{ line-height: 1.4; }
.nyugaku .contact-quick__text strong{ display: block; font-size: 14px; color: var(--text); font-weight: 700; }
.nyugaku .contact-quick__text small{ display: block; font-size: 0.8rem; color: var(--text-sub); }

.nyugaku .notes-list{
  margin: 18px 0 0; padding: 0; list-style: none;
  display: flex; flex-wrap: wrap; gap: 8px 18px;
   /*color: var(--text-sub);*/
  justify-content: center;
}
.nyugaku .notes-list li{ padding-left: 16px; position: relative; }
.nyugaku .notes-list li::before{
  content: "✓"; position: absolute; left: 0; top: 0; color: var(--blue); font-weight: 700;
}

.nyugaku .callout{
  margin-top: 18px;
  background: var(--bg-cream); border-left: 4px solid var(--orange);
  border-radius: 6px; padding: 16px 18px;
   color: var(--text);
}
.nyugaku .callout strong{ color: var(--orange-deep); font-weight: 700; }
.nyugaku .callout p{ margin: 0; }
.nyugaku .callout p + p{ margin-top: 6px; }
.nyugaku .callout-foot{ font-size: 0.8rem; color: var(--text-mute); margin-top: 14px; line-height: 1.7; }

@media (max-width: 767px) {
  .nyugaku .fee-base__body{ flex-direction: column; align-items: stretch; text-align: center; gap: 12px; padding: 18px; }
  .nyugaku .fee-base__icon{ margin: 0 auto; }
  .nyugaku .fee-base__price{ text-align: center; }
  .nyugaku .option-grid{ grid-template-columns: repeat(2, 1fr); }
  .nyugaku .contact-quick{ grid-template-columns: 1fr; }
}

/* ============================================================
   SECTION 4: 就学支援金
   ============================================================ */
.nyugaku .subsidy-hero{
  background: linear-gradient(135deg, #fff9f1 0%, #fff9f1 100%);
  border-radius: var(--radius-lg); padding: 32px 28px; text-align: center;
  position: relative; overflow: hidden;
}
.nyugaku .subsidy-hero::before, .nyugaku .subsidy-hero::after{
  content: ""; position: absolute; border-radius: 50%; pointer-events: none;
}
.nyugaku .subsidy-hero::before{ width: 180px; height: 180px; background: rgba(255,255,255,.3); top: -50px; left: -50px; }
.nyugaku .subsidy-hero::after{ width: 140px; height: 140px; background: rgba(255,255,255,.25); bottom: -40px; right: -40px; }
.nyugaku .subsidy-hero__badge{
  position: relative; display: inline-block; padding: 5px 16px;
  background: var(--orange); color: #fff; border-radius: 999px;
   font-weight: 700; margin-bottom: 14px; letter-spacing: .04em;
}
.nyugaku .subsidy-hero__title{
  position: relative; margin: 0; font-size: 26px; font-weight: 700;
  color: #5C3A0A; line-height: 1.5; letter-spacing: .01em;
}
.nyugaku .subsidy-hero__title strong{
  background: linear-gradient(transparent 65%, rgba(233,116,51,.35) 65%);
  padding: 0 4px;
}
.nyugaku .subsidy-hero__copy{
  position: relative; margin: 16px auto 0; max-width: 580px;
  color: #6B4915;  line-height: 1.85;
}

.nyugaku .subsidy-points{
  margin-top: 20px; display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.nyugaku .subsidy-point{
  display: flex; gap: 12px; padding: 14px;
  border: 1px solid var(--border); border-radius: 8px; background: #fff;
}
.nyugaku .subsidy-point__icon{
  width: 36px; height: 36px; flex-shrink: 0; border-radius: 8px;
  background: var(--blue-soft); color: var(--blue); display: grid; place-items: center;
}
.nyugaku .subsidy-point strong{ display: block; font-size: 16px; font-weight: 700; margin-bottom: 2px; }
.nyugaku .subsidy-point small{ font-size: 0.8rem;  font-size: 15px;/*color: var(--text-sub); */}

.nyugaku .link-block-btn{
  margin-top: 16px;
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; border: 1px solid var(--border); border-radius: 8px;
  background: #fff; color: var(--text); text-decoration: none;
}
.nyugaku .link-block-btn:hover{ border-color: var(--blue); background: var(--bg-blue-soft); text-decoration: none; }
.nyugaku .link-block-btn__icon{
  width: 36px; height: 36px; flex-shrink: 0; border-radius: 8px;
  background: var(--bg-cream); color: var(--orange); display: grid; place-items: center;
}
.nyugaku .link-block-btn__text{ flex: 1; }
.nyugaku .link-block-btn__text strong{ display: block; font-size: 14px; font-weight: 700; }
.nyugaku .link-block-btn__text small{ font-size: 0.8rem; color: var(--text-sub); }
.nyugaku .link-block-btn__arrow{ color: var(--text-mute); }
  .renew.sub h3.reason__title {font-size: 20px;}

@media (max-width: 767px) {
  .nyugaku .subsidy-hero{ padding: 24px 0px; }
  .renew.sub .nyugaku .subsidy-hero p {padding:0 12px;}
  .nyugaku .subsidy-hero__title{ font-size: 19px; }
  .nyugaku .subsidy-points{ grid-template-columns: 1fr; }
  .renew.sub p.reason__copy {padding:0;}
  .renew.sub h3.reason__title {font-size: 4.0vw;}
}



/* ============================================================
   SECTION 5: ルネ高ならではの理由 (3 reasons)
   ============================================================ */
.nyugaku .reasons{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
.nyugaku .reason{
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 22px 18px; background: #fff; text-align: center;
  position: relative;
}
.nyugaku .reason__num{
  width: auto; height: auto;
  border-radius: 999px;
  padding: 5px 16px;
  margin: 0 auto 12px;
  background: #FFE3C2;
  color: #CC5F23;
  
  font-weight: 700;
  letter-spacing: .08em;
  display: inline-block;
}
.nyugaku .reason__num::before{
  content: "POINT ";
}
.nyugaku .reason__icon{
  margin: 0 auto 10px; width: 56px; height: 56px;
  display: grid; place-items: center; color: var(--blue);
}
.nyugaku .reason__title{
  margin: 0 0 8px; font-size: 15px; font-weight: 700; line-height: 1.4;
  text-wrap: pretty;
}
.nyugaku .reason__copy{ margin: 0; /* color: var(--text-sub);*/ line-height: 1.7; }

@media (max-width: 767px) {
  .nyugaku .reasons{ grid-template-columns: 1fr; }
  .nyugaku .reason{ padding: 18px; }
}

/* ============================================================
   SECTION 6: サポート
   ============================================================ */
.nyugaku .support-feature{
  border: 1px solid var(--orange); background: var(--bg-cream); border-radius: var(--radius-lg);
  padding: 18px 22px; margin-bottom: 18px;
  display: flex; align-items: flex-start; gap: 14px;
}
.nyugaku .support-feature__icon{
  width: 44px; height: 44px; flex-shrink: 0; border-radius: 50%;
  background: #fff; color: var(--orange); display: grid; place-items: center;
}
.nyugaku .support-feature__body strong{
  display: block; font-size: 15px; font-weight: 700; margin-bottom: 4px; color: var(--text);
}
.nyugaku .support-feature__body p{ margin: 0; /* color: var(--text-sub); */}

.nyugaku .support-sub-h{
   font-weight: 700; /*color: var(--text-sub);*/
  letter-spacing: .06em; margin: 0 0 12px; padding-left: 10px;
  border-left: 3px solid var(--blue); line-height: 1;
}

.nyugaku .support-grid{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  margin-bottom: 18px;
}
.nyugaku .support-card{
  border: 1px solid var(--border); border-radius: 8px; padding: 16px 0;
  text-align: center; background: #fff;
}
.nyugaku .support-card__icon{
  width: 48px; height: 48px; border-radius: 50%; margin: 0 auto 8px;
  display: grid; place-items: center;
}
.nyugaku .support-card__icon--blue{ background: var(--blue-soft); color: var(--blue); }
.nyugaku .support-card__icon--orange{ background: var(--bg-cream); color: var(--orange); }
.nyugaku .support-card__icon--green{ background: #E8F8EE; color: var(--line-deep); }
.nyugaku .support-card__icon--pink{ background: #FCE9EF; color: #D94673; }
.nyugaku .support-card__title{  font-weight: 700; margin: 0 0 4px; line-height: 1.3; }
.nyugaku .support-card__copy{ margin: 0;  /*color: var(--text-sub);*/ line-height: 1.6; }

.nyugaku .support-link-row{
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg-blue-soft); color: var(--text); text-decoration: none;
  margin-bottom: 22px;
}
.nyugaku .support-link-row:hover{ background: #DCEAF7; text-decoration: none; }
.nyugaku .support-link-row svg{ color: var(--blue); }
.nyugaku .support-link-row span{ flex: 1;  font-weight: 700; }
.nyugaku .support-link-row small{ font-size: 0.8rem; color: var(--text-sub); }

.nyugaku .support-second{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border: 1px solid var(--border); border-radius: 8px; overflow: hidden;
}
.nyugaku .support-second__item{
  padding: 14px 16px;
}
.nyugaku .support-second__item + .support-second__item{ border-left: 1px solid var(--border); }
.nyugaku .support-second__head{
  display: flex; align-items: center; gap: 8px;
  /**/ font-weight: 700; color: var(--text); margin-bottom: 4px;
}
.nyugaku .support-second__head svg{ color: var(--blue); }
.nyugaku .support-second__item p{ margin: 0; /* color: var(--text-sub);*/ line-height: 1.6; }

@media (max-width: 767px) {
  .nyugaku .support-grid{ grid-template-columns: repeat(2, 1fr); }
  .nyugaku .support-second{ grid-template-columns: 1fr; }
  .nyugaku .support-second__item + .support-second__item{ border-left: 0; border-top: 1px solid var(--border); }
}



/* リンク化したsupport-second__itemの装飾 */
.nyugaku .support-second__item {
  color: inherit;
  text-decoration: none;
  transition: background .15s, transform .15s;
}
.nyugaku .support-second__item:hover {
  background: var(--bg-blue-soft);
  text-decoration: none;
  cursor: pointer;
}
.nyugaku .support-second__item:hover .support-second__head {
  color: var(--blue);
}

/* ============================================================
   SECTION 7: 在校生・卒業生の声
   ============================================================ */
.nyugaku .voices{
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.nyugaku .voice{
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 18px; background: #fff;
  display: flex; flex-direction: column; gap: 12px;
}
.nyugaku .voice__head{
  display: flex; gap: 12px; align-items: flex-start;
}
.nyugaku .voice__avatar{
  width: 56px; height: 56px; border-radius: 50%; flex-shrink: 0;
  background: var(--blue-soft); display: grid; place-items: center; color: var(--blue);
  border: 2px solid #fff; box-shadow: 0 0 0 1px var(--border);
}
.nyugaku .voice__avatar svg{ width: 36px; height: 36px; }
.nyugaku .voice__meta{ flex: 1; }
.nyugaku .voice__meta strong{ display: block; font-size: 14px; font-weight: 700; color: var(--text); line-height: 1.4; }
.nyugaku .voice__meta small{ display: block; font-size: 0.8rem; color: var(--text-sub); margin-top: 2px; }
.nyugaku .voice__tag{
  font-size: 10px; padding: 2px 8px; border-radius: 4px;
  background: var(--bg-cream); color: var(--orange-deep); font-weight: 700;
}
/* voice avatar に写真が入った時の表示 */
.nyugaku .voice__avatar {
  overflow: hidden;            /* 円からはみ出さないように */
  background: var(--bg-gray);  /* 読み込み中の控えめな色 */
}
.nyugaku .voice__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;            /* 正方形に切り抜き */
  display: block;
}
.nyugaku .voice__tags{ display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
.nyugaku .voice__title{ margin: 0; font-size: 15px; font-weight: 700; color: var(--text); line-height: 1.5; }
.nyugaku .voice__quote{
  margin: 0; /* color: var(--text);*/ line-height: 1.8;
  position: relative; padding-left: 14px;
}
.nyugaku .voice__quote::before{
  content: """; position: absolute; left: -2px; top: -8px;
  font-size: 28px; color: var(--blue);
  line-height: 1;
}
.nyugaku .voice__more{
  display: inline-flex; align-items: center; gap: 4px;
  background: none; border: 0; padding: 0;
  color: var(--blue);  font-weight: 700; cursor: pointer;
  margin-left: auto;
}
.nyugaku .voice__more:hover{ text-decoration: underline; }
.nyugaku .voice__expand{ display: none;  color: var(--text); line-height: 1.8; }
.nyugaku .voice.is-open .voice__expand{ display: block; }
.nyugaku .voice.is-open .voice__more-icon{ transform: rotate(180deg); }
.nyugaku .voice__source{ font-size: 0.8rem; color: var(--text-mute); display: flex; justify-content: flex-end; align-items: center; gap: 4px; }

@media (max-width: 767px) {
  .nyugaku .voices{ grid-template-columns: 1fr; }
}

/* ============================================================
   SECTION 8: 学校ごとの違い
   ============================================================ */
.nyugaku .school-tabs{ display: flex; gap: 4px; border-bottom: 2px solid var(--blue-line); margin-bottom: 18px; }
.nyugaku .school-tab{
  flex: 1; padding: 14px 12px; background: var(--bg-gray); border: 0; border-radius: 8px 8px 0 0;
   font-weight: 700; color: var(--text-sub); cursor: pointer;
  border-top: 2px solid var(--border); border-left: 1px solid var(--border); border-right: 1px solid var(--border);
  border-bottom: 0; line-height: 1.4; margin-bottom: -2px;
}
.nyugaku .school-tab.is-active{
  background: #fff; color: var(--blue-deep); border-top-color: var(--blue);
  border-left-color: var(--blue-line); border-right-color: var(--blue-line);
}
.nyugaku .school-tab small{ display: block; font-size: 10px; font-weight: 500; color: var(--text-mute); margin-top: 2px; }
.nyugaku .school-tab.is-active small{ color: var(--blue); }

.nyugaku .school-panel{ display: none; padding: 18px; border: 1px solid var(--border); border-top: 0; border-radius: 0 0 8px 8px; }
.nyugaku .school-panel.is-active{ display: block; }
.nyugaku .school-panel h4{ margin: 0 0 8px; font-size: 16px; color: var(--text); }
.nyugaku .school-panel p{ margin: 0 0 12px;  /*color: var(--text-sub);*/ }
.nyugaku .school-panel__link{
  display: inline-flex; align-items: center; gap: 6px;
   font-weight: 700; color: var(--blue);
}

@media (max-width: 767px) {
  .nyugaku .school-tabs{ gap: 2px; }
  .nyugaku .school-tab{ padding: 10px 6px; font-size: 0.8rem; }
}

/* ============================================================
   SECTION 9: FAQ
   ============================================================ */
.nyugaku .faq{ display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--border); }
.nyugaku .faq-item{ border-bottom: 1px solid var(--border); }
.nyugaku .faq-q{
  display: flex; align-items: flex-start; gap: 14px; width: 100%;
  background: none; border: 0; padding: 18px 4px; text-align: left;
  font-size: 14px; font-weight: 700; color: var(--text); line-height: 1.5; cursor: pointer;
}
.nyugaku .faq-q__mark{
  width: 28px; height: 28px; flex-shrink: 0; border-radius: 50%;
  background: var(--blue); color: #fff; display: grid; place-items: center;
  font-weight: 700; font-size: 14px;
}
.nyugaku .faq-q__text{ flex: 1; }
.nyugaku .faq-q__chev{ color: var(--text-sub); transition: transform .2s; flex-shrink: 0; margin-top: 4px; }
.nyugaku .faq-item.is-open .faq-q__chev{ transform: rotate(180deg); }
.nyugaku .faq-a{
  display: grid; grid-template-rows: 0fr; transition: grid-template-rows .25s ease;
}
.nyugaku .faq-item.is-open .faq-a{ grid-template-rows: 1fr; }
.nyugaku .faq-a__inner{ overflow: hidden; }
.nyugaku .faq-a__body{
  display: flex; gap: 14px; padding: 0 4px 18px 4px;
   color: var(--text); line-height: 1.85;
}
.nyugaku .faq-a__mark{
  width: 28px; height: 28px; flex-shrink: 0; border-radius: 50%;
  background: var(--bg-cream); color: var(--orange); display: grid; place-items: center;
  font-weight: 700; font-size: 14px;
}
.nyugaku .faq-a__text{ flex: 1; padding-top: 2px; }
.nyugaku .faq-tag{
  display: inline-block; font-size: 10px; padding: 2px 8px; border-radius: 4px;
  background: var(--bg-cream); color: var(--orange-deep); font-weight: 700; margin-right: 6px;
  vertical-align: middle;
}

/* ============================================================
   SECTION 10: まずは
   ============================================================ */
.nyugaku .cta-grid{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 14px;
}
.nyugaku .cta-card{
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 22px 12px; background: #fff; text-align: center;
  text-decoration: none; color: var(--text); display: flex; flex-direction: column; gap: 8px; align-items: center;
  transition: all .15s; position: relative;
}
.nyugaku .cta-card:hover{ border-color: var(--blue); background: var(--bg-blue-soft); text-decoration: none; transform: translateY(-2px); }
.nyugaku .cta-card.is-feature{ background: var(--line); color: #fff; border-color: var(--line); }
.nyugaku .cta-card.is-feature:hover{ background: var(--line-deep); }
.nyugaku .cta-card__icon{
  width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center;
  background: var(--blue-soft); color: var(--blue);
}
.nyugaku .cta-card.is-feature .cta-card__icon{ background: rgba(255,255,255,.2); color: #fff; }
.nyugaku .cta-card__title{ font-size: 14px; font-weight: 700; margin: 0; line-height: 1.4; }
.nyugaku .cta-card__copy{ font-size: 0.8rem; margin: 0; line-height: 1.5; color: var(--text-sub); }
.nyugaku .cta-card.is-feature .cta-card__copy{ color: rgba(255,255,255,.92); }
.nyugaku .cta-card__badge{
  position: absolute; top: -8px; right: 10px;
  font-size: 10px; padding: 2px 8px; border-radius: 999px;
  background: var(--orange); color: #fff; font-weight: 700;
  border: 2px solid #fff;  /* 白い実線を2pxの太さでつける */
  box-sizing: border-box;  /* 枠線をつけたことでバッジが大きく崩れるのを防ぐ */
}

.nyugaku .cta-doc-block{
  border: 1px solid var(--orange); background: var(--bg-cream); border-radius: var(--radius-lg);
  padding: 18px 22px;
  display: flex; align-items: center; gap: 16px;
}
.nyugaku .cta-doc-block__icon{
  width: 48px; height: 48px; flex-shrink: 0; border-radius: 50%;
  background: #fff; color: var(--orange); display: grid; place-items: center;
}
.nyugaku .cta-doc-block__body{ flex: 1; }
.nyugaku .cta-doc-block__body strong{ display: block; font-size: 15px; font-weight: 700; color: var(--text); }
.nyugaku .cta-doc-block__body small{  color: /*var(--text-sub);*/ }

@media (max-width: 767px) {
  .nyugaku .cta-grid{ grid-template-columns: repeat(2, 1fr); }
  .nyugaku .cta-doc-block{ flex-direction: column; align-items: stretch; text-align: center; padding: 18px; }
  .nyugaku .cta-doc-block__icon{ margin: 0 auto; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.nyugaku .site-footer{
  background: #243447; color: #fff; padding: 40px 0 20px;
}
.nyugaku .site-footer__inner{
  max-width: var(--container); margin: 0 auto; padding: 0 24px;
}
.nyugaku .site-footer__cols{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px;
}
.nyugaku .site-footer h4{  margin: 0 0 12px; color: #fff; }
.nyugaku .site-footer ul{ list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.nyugaku .site-footer a{ color: rgba(255,255,255,.7);  text-decoration: none; }
.nyugaku .site-footer a:hover{ color: #fff; text-decoration: underline; }
.nyugaku .site-footer__bottom{
  margin-top: 32px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.1);
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.8rem; color: rgba(255,255,255,.5);
}

@media (max-width: 767px) {
  .nyugaku .site-footer__cols{ grid-template-columns: 1fr 1fr; gap: 20px; }
  .nyugaku .site-footer__bottom{ flex-direction: column; gap: 8px; text-align: center; }
}

/* ============================================================
   FLOATING + BOTTOM FIXED (mobile)
   ============================================================ */
.nyugaku .floating-cta{
  position: fixed; right: 12px; bottom: 92px; z-index: 90;
  display: flex; flex-direction: column; gap: 8px;
}
.nyugaku .floating-cta a{
  width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center;
  color: #fff; box-shadow: 0 4px 12px rgba(0,0,0,.18);
}
.nyugaku .floating-cta a:hover{ transform: translateY(-2px); transition: transform .15s; }
.nyugaku .floating-cta__line{ background: var(--line); }
.nyugaku .floating-cta__tel{ background: var(--blue); }

@media (min-width: 768px) {
  .nyugaku .floating-cta{ bottom: 24px; }
}

.nyugaku .bottom-bar{
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 95;
  background: #fff; border-top: 1px solid var(--border);
  padding: 8px 10px; display: flex; gap: 8px;
  box-shadow: 0 -2px 8px rgba(0,0,0,.05);
}

@media (min-width: 768px) {
  .nyugaku .bottom-bar{ display: none; }
}

/* ============================================================
   PC NOTE block (wireframe-style annotation, optional)
   ============================================================ */
.nyugaku .pc-note{
  background: var(--bg-blue-soft); border: 1px dashed var(--blue-line);
  padding: 12px 16px; border-radius: 6px;  color: var(--text-sub);
  margin-bottom: 24px;
}
.nyugaku .pc-note strong{ color: var(--blue-deep); font-weight: 700; margin-right: 6px; }

/* ============================================================
   MOBILE NAV DRAWER
   ============================================================ */
.nyugaku .mobile-nav{
  position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 110;
  display: none;
}
.nyugaku .mobile-nav.is-open{ display: block; }
.nyugaku .mobile-nav__panel{
  position: absolute; right: 0; top: 0; bottom: 0; width: 280px; background: #fff;
  padding: 18px; overflow-y: auto;
}
.nyugaku .mobile-nav__close{
  background: none; border: 0; padding: 6px; color: var(--text); margin-bottom: 12px;
}
.nyugaku .mobile-nav ul{ list-style: none; padding: 0; margin: 0; }
.nyugaku .mobile-nav li{ border-bottom: 1px solid var(--border); }
.nyugaku .mobile-nav a{ display: block; padding: 12px 4px; color: var(--text); font-size: 14px; text-decoration: none; }
.nyugaku .mobile-nav__ctas{ display: flex; flex-direction: column; gap: 8px; margin-top: 18px; }

/* ============================================================
   VISIBILITY HELPERS
   ============================================================ */
.nyugaku .pc-only{ display: block; }
.nyugaku .sp-only{ display: none; }
@media (max-width: 767px) {
  .nyugaku .pc-only{ display: none; }
  .nyugaku .sp-only{ display: block; }
  .nyugaku .pc-only-flex{ display: none; }
  .nyugaku .sp-only-flex{ display: flex; }
}
@media (min-width: 768px) {
  .nyugaku .sp-only-flex{ display: none; }
  .nyugaku .pc-only-flex{ display: flex; }
}

/* ============================================================
   voice avatar 写真表示対応
   ============================================================ */
.nyugaku .voice__avatar {
  overflow: hidden;
  background: var(--bg-gray);
}
.nyugaku .voice__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ============================================================
   SP（〜767px）の左右余白＆詰まり感の解消
   ============================================================ */
@media (max-width: 767px) {
  /* ページ全体の左右余白 */
  .nyugaku {
    padding-left: 16px;
    padding-right: 16px;
    box-sizing: border-box;
  }

  /* セクション見出し */
  .nyugaku .section-head {
    gap: 8px;
    align-items: flex-start;
    padding-bottom: 12px;
  }
  .nyugaku .section-head__num {
    width: 26px;
    height: 26px;
    
    margin-top: 2px;
  }

  /* 学費基本コースカード内の余白 */
  .nyugaku .fee-base__head {
    padding: 12px 16px;
    
  }
  .nyugaku .fee-base__body {
    padding: 20px 16px;
    gap: 14px;
  }
  .nyugaku .fee-base__name strong {
    font-size: 16px;
  }


  .nyugaku .section-lead {
    margin-bottom: 20px;
    /**/
  }
}





  .nyugaku h2 { line-height: 1.4 !important; }

  .nyugaku h2.section-head__title {
    font-size: 22px !important;
    line-height: 1 !important;
    margin: 0 !important;
  }
  @media (max-width: 767px) {
    .nyugaku h2.section-head__title {
      font-size: 18px !important;
      line-height: 1.45 !important;
    }
  }

  .nyugaku h2.fv__title {
    font-size: 30px !important;
    line-height: 1.4 !important;
    margin: 0 0 18px !important;
  }
  @media (max-width: 767px) {
    .nyugaku h2.fv__title {
      font-size: 22px !important;
    }
  }