/* =========================================================
   School Oak — style.css v2 (8-page edition)
   深緑 × 白 × ゴールド / Noto Serif JP + Arial(数字)
========================================================= */

/* ----- Variables ----- */
:root {
  --navy-900: #0e2a18;
  --navy-800: #163d25;
  --navy-700: #1d5232;
  --navy-600: #266840;
  --navy-100: #e4f0e9;
  --gold-700: #8b6f30;
  --gold-600: #a98841;
  --gold-500: #c5a35a;
  --gold-400: #d6b876;
  --ivory: #faf7f0;
  --paper: #f5f1e8;
  --white: #ffffff;
  --ink: #1a2820;
  --ink-2: #3f5247;
  --line: #d8d2c2;
  --red: #b3411f;
  --shadow-sm: 0 2px 8px rgba(14,42,24,.06);
  --shadow-md: 0 8px 28px rgba(14,42,24,.10);
  --shadow-lg: 0 16px 48px rgba(14,42,24,.14);
  --serif: "Noto Serif JP","Hiragino Mincho ProN","Yu Mincho",serif;
  --sans:  "Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  --en-serif: "Cormorant Garamond","Noto Serif JP",serif;
  --num-font: Arial,"Helvetica Neue",Helvetica,sans-serif;
  --header-h: 132px;
  --peek: 72px;
  --carousel-gap: 16px;
}

/* ----- Reset ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
body{font-family:var(--serif);color:var(--ink);background:var(--ivory);line-height:1.85;font-feature-settings:"palt" 1;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s,opacity .25s}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

.container{width:min(1000px,80%);margin-inline:auto}
.sp-only{display:none}

/* 数字フォント一括適用 */
.num,.ach-num b,.ach-rate b,.cumu-list b,
.contact-tel,.header-tel,.footer-tel a,
.hero-badge b,.reason-num,.step-num,
.results-big-num,.result-num,
.results-big-digit,.cumulative-num .big {
  font-family:var(--num-font);letter-spacing:.01em
}
/* --- 全体の文字サイズを1.2倍にする (PC表示時) --- */
@media (min-width: 721px) {
    html {
        font-size: 120%; /* 全体の基準を1.2倍に */
    }
}

/* =========================================================
   HEADER
========================================================= */
.site-header{position:fixed;top:0;left:0;right:0;background:#fff;z-index:200;box-shadow:var(--shadow-sm);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:var(--shadow-md)}

.header-top{border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fdfbf6,#fff)}
.header-inner{
  width:min(1280px,96%);margin-inline:auto;
  display:grid;grid-template-columns:auto 1fr auto auto;
  align-items:center;gap:28px;padding:14px 0
}
.brand{display:flex;flex-direction:column;line-height:1.1}
.brand-en{font-family:var(--en-serif);font-size:28px;font-weight:600;letter-spacing:.14em;color:var(--navy-900)}
.brand-jp{font-size:14px;font-weight:600;color:var(--navy-700);letter-spacing:.18em;margin-top:4px}
.brand-tagline{font-size:11px;color:var(--gold-600);letter-spacing:.14em;margin-top:4px;font-family:var(--sans)}

.header-contact{text-align:right;line-height:1.3;padding-right:14px;border-right:1px solid var(--line)}
.header-contact-label{font-size:11px;color:var(--ink-2);letter-spacing:.08em}
.header-tel{display:inline-flex;align-items:center;gap:6px;font-size:28px;font-weight:700;color:var(--navy-900)}
.tel-icon{color:var(--gold-600);font-size:22px}
.header-hours{font-size:11px;color:var(--ink-2)}

.header-cta{display:flex;gap:10px}
.cta-btn{
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  width:92px;min-height:64px;font-family:var(--sans);font-size:12px;font-weight:700;
  color:#fff;letter-spacing:.08em;border-radius:4px;
  transition:transform .25s,box-shadow .25s,opacity .25s;text-align:center
}
.cta-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);opacity:.94}
.cta-icon{font-size:18px;margin-bottom:4px}
.cta-svg{width:22px;height:22px;fill:#fff;margin-bottom:4px}
.cta-blue{background:linear-gradient(180deg,var(--navy-700),var(--navy-900))}
.cta-gold{background:linear-gradient(180deg,var(--gold-500),var(--gold-700))}

.hamburger{display:none}

/* ---- NAV ---- */
.site-nav{background:var(--navy-900)}
.nav-list{
  width:min(1280px,96%);margin-inline:auto;
  display:grid;grid-template-columns:repeat(8,1fr)
}
.nav-list li{border-right:1px solid rgba(255,255,255,.08)}
.nav-list li:first-child{border-left:1px solid rgba(255,255,255,.08)}
.nav-list a{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:5px 6px;color:#fff;position:relative;transition:background .3s
}
.nav-list a::after{
  content:"";position:absolute;left:50%;bottom:6px;
  width:0;height:2px;background:var(--gold-500);
  transition:width .35s,left .35s
}
.nav-list a:hover{background:var(--navy-700)}
.nav-list a:hover::after,.nav-list a.active::after{width:32px;left:calc(50% - 16px)}
.nav-list a.active{background:linear-gradient(180deg,var(--navy-700),var(--navy-900))}
.nav-en{font-family:var(--en-serif);font-size:15px;font-weight:500;letter-spacing:.14em;color:var(--gold-400)}
.nav-jp{font-size:11px;letter-spacing:.08em;margin-top:4px}

/* =========================================================
   HERO & PEEKING CAROUSEL (index.html)
========================================================= */
/* 1. ヒーローエリアの大枠 */
.hero {
    margin-top: var(--header-h);
    position: relative;
    width: 100%;
    height: 470px; /* ★ ここで希望の縦幅を指定します（数字は自由に変えてください） */
    background: var(--navy-900);
    overflow: hidden;
}

/* 2. 途中の箱たちに「高さ」を伝える */
.slider-container,
.slider-wrapper,
.slide,
.slide-link {
    display: block;
    width: 100%;
    height: 100%; 
}

/* 3. ★ココが解決の鍵！画像を「縦幅基準」に変える */
.slide-link img {
    display: block;
    height: 100% !important; /* ★ 優先順位1位：高さをヒーローエリア（450px）にピッタリ合わせる */
    width: auto !important;  /* ★ 優先順位2位：縦幅に合わせて、横幅を自動で縮小させる */
    margin: 0 auto;          /* 左右にできた余白の中央に画像を配置する */
    object-fit: contain; 
}

/* Carousel wrapper */
.hero-carousel-wrap{
  position:absolute;inset:0;
  overflow:hidden;
}

.carousel-track{
  display:flex;
  height:100%;
  gap:var(--carousel-gap);
  /* width & transform set by JS */
}

.carousel-slide{
  flex-shrink:0;
  height:100%;
  position:relative;
  overflow:hidden;
  transition:opacity .45s ease;
  opacity:.72;
}
.carousel-slide.is-active{opacity:1}

/* ★ 画像は素の状態で表示（フィルター・暗転なし） */
.slide-bg{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  /* overlay なし・filter なし */
}

/* テキスト可読のため、アクティブスライドの左側にのみ軽いグラデを施す */
.slide-overlay{
  position:absolute;inset:0;
  opacity:0;
  background:linear-gradient(105deg,
    rgba(14,42,24,.58) 0%,
    rgba(14,42,24,.28) 52%,
    rgba(14,42,24,.04) 100%);
  transition:opacity .45s ease;
  pointer-events:none;
}
.carousel-slide.is-active .slide-overlay{opacity:1}

/* 中央の画像の幅を80%から75%にして少し小さくする */
.slide {
    flex: 0 0 75%; 
    margin: 0 10px; 
    box-sizing: border-box;
    position: relative; /* ホワイトアウトの幕を乗せるための基準 */
}

/* 画像の高さを500pxから300pxに縮小 */
.slide img {
    width: 100%;
    height: 300px; /* ここでお好みの高さに調整できます */
    object-fit: cover; 
    border-radius: 8px;
    filter: none !important;
    opacity: 1 !important;
}

/* 中央の画像の幅を80%から60%にして少し小さくする */
.slide {
    flex: 0 0 60%; 
    margin: 0 10px; 
    box-sizing: border-box;
    position: relative; /* ★これが非常に重要です */
}

/* ▼ 左右の画像（非アクティブ）を白く飛ばす ▼ */
.slide::after {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background-color: rgba(255, 255, 255, 0.65); /* 白の濃さ */
    border-radius: 8px;
    /* 色ではなく、透明度（opacity）を操作して切り替えるように修正 */
    transition: opacity 0.5s ease-in-out;
    pointer-events: none;
    opacity: 1; /* 基本は「白い幕を表示する（1）」 */
    z-index: 10;
}

/* ▼ 中央（アクティブ）の画像は、上の白い幕を透明にする ▼ */
.slide.is-active::after {
    opacity: 0 !important; /* 透明度を0にして、画像をくっきり見せる */
}

/* スマホ用のサイズ */
@media (max-width: 768px) {
    .slide { flex: 0 0 85%; } 
    .slide img { height: 260px; } 
}

/* 矢印ボタン */
.carousel-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:20;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.13);
  border:1.5px solid rgba(255,255,255,.40);
  color:#fff;font-size:28px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .25s,transform .25s;
  backdrop-filter:blur(4px);
}
.carousel-btn:hover{background:rgba(255,255,255,.28);transform:translateY(-50%) scale(1.08)}
.carousel-prev{left:22px}
.carousel-next{right:22px}

/* ドット */
.carousel-dots{
  position:absolute;bottom:22px;left:50%;transform:translateX(-50%);
  display:flex;gap:10px;z-index:20;
}
.carousel-dot{
  width:10px;height:10px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.6);
  background:transparent;cursor:pointer;
  transition:background .25s,border-color .25s;
}
.carousel-dot.is-active{background:var(--gold-400);border-color:var(--gold-400)}

/* ヒーローテキスト */
.hero-copy{
  position:absolute;inset:0;z-index:10;
  width:min(1180px,92%);margin-inline:auto;
  display:flex;flex-direction:column;justify-content:center;
  color:#fff;pointer-events:none;
}
.hero-copy a,.hero-copy button{pointer-events:auto}

.hero-eyebrow{font-family:var(--en-serif);letter-spacing:.35em;font-size:13px;color:var(--gold-400);margin-bottom:24px}
.hero-title{font-family:var(--serif);font-weight:600;font-size:clamp(34px,5.6vw,68px);line-height:1.35;letter-spacing:.04em;text-shadow:0 2px 14px rgba(0,0,0,.3)}
.hero-title span{display:block}
.hero-lead{margin-top:26px;font-size:clamp(14px,1.3vw,17px);line-height:2;letter-spacing:.04em;color:#f1ecdf;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.hero-badges{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero-badge{
  font-family:var(--sans);
  background:rgba(255,255,255,.10);border:1px solid var(--gold-500);
  color:#fff;padding:12px 22px;font-size:13px;letter-spacing:.12em;
  backdrop-filter:blur(6px);border-radius:2px;
}
.hero-badge b{font-size:22px;color:var(--gold-400);margin-right:6px;font-weight:700}

/* =========================================================
   PAGE BANNER (inner pages) — CSS animation slider
========================================================= */
.page-banner{
  margin-top: 150px; /* ★ 変数をやめて、直接数値を入れます（ヘッダーの高さ分押し下げる） */
  position: relative;
  height: 150px; /* ★ ボトムの余白を減らすために高さも短くします */
  overflow: hidden;
  background: var(--navy-900);
}
.page-banner .hero-slider{position:absolute;inset:0;overflow:hidden}
.page-banner .hero-track{
  display:flex;height:100%;width:600%;
  animation:heroSlide 48s linear infinite;
}
.page-banner .hero-slide{
  flex:1 0 calc(100% / 6);
  background-size:cover;background-position:center;
  background-color:#1d5232;
}
/* ★ ページバナーのオーバーレイも明るめに */
.page-banner-overlay{
  position:absolute;inset:0;
  background:linear-gradient(120deg,
    rgba(14,42,24,.60) 0%,
    rgba(14,42,24,.38) 60%,
    rgba(14,42,24,.52) 100%);
}
@keyframes heroSlide{
  0%  {transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.page-banner-inner{
  position:relative;z-index:2;height:100%;
  width:min(1180px,92%);margin-inline:auto;
  display:flex;flex-direction:column;justify-content:center;color:#fff;
}
.page-banner-en{font-family:var(--en-serif);letter-spacing:.35em;color:var(--gold-400);font-size:14px;margin-bottom:5px}
.page-banner-title{font-size:clamp(28px,3.6vw,44px);font-weight:600;letter-spacing:.12em;line-height:1.0;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.breadcrumb{margin-top:20px;font-size:12px;letter-spacing:.12em;color:#d4d8e0}
.breadcrumb a{color:var(--gold-400)}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{margin:0 8px;opacity:.6}

/* =========================================================
   COMMON SECTION
========================================================= */
section{padding:40px 0;position:relative}
.section-eyebrow{font-family:var(--en-serif);text-align:center;letter-spacing:.42em;font-size:14px;color:var(--gold-600);margin-bottom:12px}
.section-title{font-family:var(--serif);text-align:center;font-size:clamp(26px,3vw,38px);font-weight:600;color:var(--navy-900);letter-spacing:.08em}
.section-divider{text-align:center;margin:22px 0 36px}
.section-divider span{display:inline-block;width:64px;height:1px;background:var(--gold-500);position:relative}
.section-divider span::before,.section-divider span::after{
  content:"";position:absolute;top:-3px;width:7px;height:7px;
  border:1px solid var(--gold-500);transform:rotate(45deg);background:var(--ivory)
}
.section-divider span::before{left:-10px}
.section-divider span::after{right:-10px}
.section-lead{text-align:center;color:var(--ink-2);font-size:16px;margin-bottom:50px;letter-spacing:.06em}

/* =========================================================
   ACHIEVEMENT
========================================================= */
.achievement{background:linear-gradient(180deg,var(--ivory) 0%,var(--paper) 100%)}
.achievement-band{
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-md);
  padding:56px 48px;position:relative;
}
.achievement-band::before{content:"";position:absolute;inset:8px;border:1px solid var(--gold-500);pointer-events:none}
.achievement-head{text-align:center;margin-bottom:40px}
.achievement-year{display:inline-block;font-family:var(--en-serif);background:var(--navy-900);color:var(--gold-400);padding:6px 18px;letter-spacing:.2em;font-size:13px;margin-bottom:14px}
.achievement-title{font-size:clamp(26px,3vw,36px);color:var(--navy-900);letter-spacing:.08em}
.achievement-sub{margin-top:8px;color:var(--gold-700);letter-spacing:.14em;font-size:14px}
.achievement-grid{display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin-bottom:40px}
.achievement-card{text-align:center;padding:32px 18px;background:linear-gradient(180deg,#fff,#fbf8f1);border:1px solid var(--line)}
.ach-rank span{display:inline-block;background:var(--navy-900);color:#fff;padding:4px 14px;font-size:11px;letter-spacing:.14em;font-family:var(--sans);margin-bottom:14px}
.ach-school{font-size:19px;font-weight:600;color:var(--navy-900);letter-spacing:.06em;border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:8px}
.ach-num{color:var(--navy-900)}
.ach-num b{font-size:64px;font-weight:700;line-height:1}
.ach-num small{font-size:14px;color:var(--ink-2);margin-left:6px;font-family:var(--serif)}
.ach-rate{color:var(--red);font-size:18px;font-weight:600;margin-top:6px}
.ach-rate b{font-size:26px;font-weight:700}

/* =========================================================
   PHILOSOPHY
========================================================= */
.philosophy{background:#fff}
.philosophy-body{max-width:780px;margin-inline:auto;text-align:center;padding:24px 0}
.philosophy-lead{font-size:clamp(20px,2.4vw,30px);font-weight:500;color:var(--navy-900);line-height:2;letter-spacing:.08em;margin-bottom:32px}
.philosophy-lead em{font-style:normal;color:var(--gold-700);border-bottom:2px solid var(--gold-500);padding-bottom:2px}
.philosophy-text{color:var(--ink-2);font-size:16px;line-height:2.1;letter-spacing:.04em}
.philosophy-sign{margin-top:28px;letter-spacing:.2em;color:var(--navy-700)}

/* =========================================================
   REASON
========================================================= */
.reason{background:var(--paper)}
.reason-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;max-width:980px;margin-inline:auto}
.reason-card{background:#fff;padding:36px 32px;border-top:3px solid var(--gold-500);box-shadow:var(--shadow-sm);transition:transform .35s,box-shadow .35s}
.reason-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.reason-num{font-size:38px;color:var(--gold-500);letter-spacing:.04em;line-height:1;margin-bottom:14px;font-weight:700}
.reason-title{font-size:19px;font-weight:600;color:var(--navy-900);letter-spacing:.04em;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line);line-height:1.6}
.reason-text{font-size:15px;color:var(--ink-2);line-height:1.95}

/* INSTRUCTOR */
.instructors{background:#fff}
.instructor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:36px}
.instructor-card{background:var(--paper);padding:36px 28px;text-align:center;border-top:3px solid var(--navy-900)}
.instructor-icon{width:84px;height:84px;margin:0 auto 18px;border-radius:50%;background:linear-gradient(135deg,var(--navy-700),var(--navy-900));display:flex;align-items:center;justify-content:center;border:2px solid var(--gold-500)}
.instructor-icon svg{width:44px;height:44px;fill:#fff;color:#fff;}
.instructor-tag{font-family:var(--en-serif);letter-spacing:.25em;color:var(--gold-700);font-size:12px;margin-bottom:8px}
.instructor-title{font-size:18px;font-weight:600;color:var(--navy-900);letter-spacing:.06em;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.instructor-text{font-size:14px;color:var(--ink-2);line-height:1.95;text-align:left}

/* =========================================================
   REPRESENTATIVE
========================================================= */
.representative{background:#fff;padding:110px 0}
.rep-flex{display:grid;grid-template-columns:360px 1fr;gap:60px;align-items:center}
.rep-photo{text-align:center}
.rep-photo-frame{
  width:100%;aspect-ratio:4/5;
  background:linear-gradient(135deg,var(--navy-700),var(--navy-900));
  position:relative;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md);
}
/* ★ 代表写真：フィルターなし */
.rep-photo-frame img{width:100%;height:100%;object-fit:cover;object-position:top center}
.rep-photo-frame::before{content:"";position:absolute;inset:12px;border:1px solid var(--gold-500);pointer-events:none;z-index:2}
.rep-photo-placeholder::after{content:"高木 美保";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--gold-400);font-size:28px;letter-spacing:.2em}
.rep-caption{margin-top:16px;letter-spacing:.14em;color:var(--navy-900);font-weight:600}
.rep-eyebrow{font-family:var(--en-serif);letter-spacing:.35em;color:var(--gold-600);font-size:13px}
.rep-title{font-size:clamp(24px,2.6vw,34px);color:var(--navy-900);font-weight:600;margin-top:8px;letter-spacing:.08em}
.rep-divider{margin:18px 0 24px}
.rep-divider span{display:block;width:56px;height:2px;background:var(--gold-500)}
.rep-lead{font-size:clamp(18px,2vw,24px);color:var(--navy-900);line-height:1.85;letter-spacing:.06em;margin-bottom:20px;font-weight:500}
.rep-body{color:var(--ink-2);margin-bottom:14px;font-size:15px}

/* =========================================================
   BOOK
========================================================= */
.book{background:linear-gradient(180deg,var(--paper),#ece4d2)}
.book-flex{display:grid;grid-template-columns:280px 1fr;gap:60px;align-items:center}
.book-cover{position:relative;aspect-ratio:3/4}
.book-cover-inner{
  background:linear-gradient(135deg,var(--navy-800),var(--navy-900) 60%,#040f08);
  width:100%;height:100%;padding:36px 28px;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;border:8px solid #fff;
  box-shadow:var(--shadow-lg),inset 0 0 0 1px var(--gold-500);overflow:hidden;
}
.book-cover-inner::before{content:"";position:absolute;inset:14px;border:1px solid var(--gold-500)}
.book-cover-inner::after{content:"";position:absolute;left:0;top:0;bottom:0;width:8px;background:linear-gradient(90deg,rgba(0,0,0,.35),rgba(255,255,255,.05))}
.book-cover-eyebrow{font-family:var(--en-serif);color:var(--gold-400);letter-spacing:.3em;font-size:12px;position:relative;z-index:2}
.book-cover-title{position:relative;z-index:2;color:#fff;font-size:38px;font-weight:600;line-height:1.3;letter-spacing:.14em;text-align:center;margin:auto 0}
.book-cover-author{position:relative;z-index:2;color:var(--gold-400);letter-spacing:.2em;font-size:13px;text-align:right}
.book-info .section-title,.book-info .section-eyebrow,.book-info .section-divider{text-align:left}
.book-info .section-divider span{margin-left:0}
.book-desc{color:var(--ink-2);margin-bottom:24px;font-size:15px;line-height:2}
.book-message{background:#fff;border:1px solid var(--gold-500);border-left-width:4px;padding:22px 26px;margin-bottom:26px}
.book-message-label{font-family:var(--en-serif);color:var(--gold-700);letter-spacing:.25em;font-size:12px;margin-bottom:6px}
.book-message-text{font-size:17px;color:var(--navy-900);font-weight:600;letter-spacing:.06em;line-height:1.7}

/* =========================================================
   COURSE
========================================================= */
.course{background:#fff}
.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.course-card{background:#fff;border:1px solid var(--line);overflow:hidden;transition:transform .35s,box-shadow .35s}
.course-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}

/* ★ コースサムネイル：aspect-ratio固定、object-fit:cover */
.course-thumb{
  aspect-ratio:16/9;
  position:relative;overflow:hidden;
}
.course-thumb img{width:100%;height:100%;object-fit:cover;display:block}
/* 画像なし時のグラデ背景（プレースホルダー） */
.course-thumb-01{background:linear-gradient(135deg,#1d5232,#0e2a18)}
.course-thumb-02{background:linear-gradient(135deg,#266840,#163d25)}
.course-thumb-03{background:linear-gradient(135deg,#c5a35a,#8b6f30)}
/* ★ ::after のオーバーレイ削除 */

.course-body{padding:28px 24px}
.course-tag {
    display: inline-block;
    background: var(--navy-900);
    color: #bfa15f !important; /* ★ 変数をやめて、直接ゴールドのカラーコードを指定し、強制適用！ */
    padding: 4px 12px;
    font-size: 11px;
    letter-spacing: .14em;
    margin-bottom: 14px;
    font-family: var(--sans);
}
.course-title{font-size:20px;font-weight:600;color:var(--navy-900);letter-spacing:.06em;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--line);line-height:1.5}
.course-text{font-size:14px;color:var(--ink-2);line-height:1.95;margin-bottom:18px}

.course-cta{text-align:center;margin-top:56px;padding:32px;background:var(--paper);border:1px solid var(--line)}
.course-cta p{font-size:17px;color:var(--navy-900);letter-spacing:.06em;margin-bottom:18px}

.course-detail{
  background:#fff;border:1px solid var(--line);padding:40px;margin-bottom:32px;
  display:grid;grid-template-columns:220px 1fr;gap:36px;
}
.course-detail .course-thumb{aspect-ratio:1}
.course-detail-body h3{font-size:24px;color:var(--navy-900);letter-spacing:.08em;font-weight:600;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.course-detail-body p{color:var(--ink-2);font-size:14.5px;margin-bottom:14px;line-height:1.95}
.course-detail-body table{width:100%;margin-top:16px;border-collapse:collapse}
.course-detail-body th,.course-detail-body td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--line);font-size:13.5px}
.course-detail-body th{background:var(--paper);color:var(--gold-700);width:110px;letter-spacing:.12em}

/* LINK BUTTON */
.link-button{
  display:inline-flex;align-items:center;gap:12px;
  padding:14px 36px;background:var(--navy-900);color:#fff;
  font-family:var(--sans);font-weight:700;letter-spacing:.12em;font-size:14px;
  border:1px solid var(--gold-500);transition:background .3s,transform .3s;
}
.link-button:hover{background:var(--navy-700);transform:translateX(4px)}
.link-button span{color:var(--gold-400);transition:transform .3s}
.link-button:hover span{transform:translateX(6px)}
.link-button.outline{background:transparent;color:var(--navy-900);border-color:var(--navy-900)}
.link-button.outline:hover{background:var(--navy-900);color:#fff}

/* =========================================================
   FLOW
========================================================= */
.flow{background:var(--paper)}
.step-list{max-width:900px;margin:0 auto;display:grid;gap:24px}
.step-item{
  background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold-500);
  padding:32px 36px;display:grid;grid-template-columns:100px 1fr;gap:28px;align-items:start;
}
.step-num{font-size:56px;color:var(--gold-500);line-height:1;font-weight:700;text-align:center;border-right:1px solid var(--line);padding-right:20px}
.step-num small{display:block;font-family:var(--en-serif);font-size:11px;letter-spacing:.25em;color:var(--gold-700);margin-top:4px}
.step-body h3{font-size:20px;color:var(--navy-900);letter-spacing:.08em;margin-bottom:10px}
.step-body p{color:var(--ink-2);font-size:14.5px;line-height:1.95}

/* FAQ */
.faq-list{max-width:900px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--line);margin-bottom:14px}
.faq-q{
  width:100%;text-align:left;padding:20px 28px;
  font-family:var(--serif);font-size:16px;color:var(--navy-900);
  font-weight:600;letter-spacing:.06em;
  display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.faq-q::before{content:"Q";flex:0 0 auto;color:var(--gold-500);font-weight:700;font-size:20px;margin-right:12px}
.faq-toggle{width:24px;height:24px;position:relative;flex:0 0 auto;transition:transform .35s}
.faq-toggle::before,.faq-toggle::after{content:"";position:absolute;background:var(--gold-500)}
.faq-toggle::before{top:11px;left:0;width:24px;height:2px}
.faq-toggle::after{left:11px;top:0;width:2px;height:24px;transition:opacity .3s}
.faq-item.open .faq-toggle::after{opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s ease;background:var(--paper);border-top:1px solid var(--line)}
.faq-a-inner{padding:20px 28px 24px 70px;color:var(--ink-2);font-size:14.5px;line-height:1.95;position:relative}
.faq-a-inner::before{content:"A";position:absolute;left:28px;top:20px;color:var(--navy-700);font-weight:700;font-size:20px}
.faq-item.open .faq-a{max-height:500px}

/* =========================================================
   VOICE
========================================================= */
.voice{background:var(--paper)}
.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.voice-card{background:#fff;padding:36px 32px;position:relative;border-left:3px solid var(--gold-500);box-shadow:var(--shadow-sm)}
.voice-card::before{content:"\201C";position:absolute;top:-8px;left:18px;font-family:var(--en-serif);font-size:80px;color:var(--gold-400);line-height:1}
.voice-quote{color:var(--ink);font-size:16px;line-height:2;letter-spacing:.04em;padding-left:36px}
.voice-foot{margin-top:18px;padding-left:36px;font-size:13px;color:var(--gold-700);letter-spacing:.12em}
.voice-tag-label{display:inline-block;background:var(--navy-900);color:var(--gold-400);font-family:var(--sans);font-size:11px;letter-spacing:.14em;padding:4px 12px;margin-bottom:14px}

.score-table{width:100%;max-width:900px;margin:40px auto 0;border-collapse:collapse;background:#fff;box-shadow:var(--shadow-sm)}
.score-table th,.score-table td{padding:14px 16px;border:1px solid var(--line);text-align:center;font-size:14px}
.score-table thead th{background:var(--navy-900);color:var(--gold-400);letter-spacing:.12em;font-weight:600}
.score-table .score-up{color:var(--red);font-weight:700}

/* =========================================================
   ACCESS
========================================================= */
.access{background:#fff}
.access-flex{display:grid;grid-template-columns:1fr 1.1fr;gap:40px}
.access-table{width:100%;border-collapse:collapse}
.access-table th,.access-table td{border-bottom:1px solid var(--line);padding:16px 14px;text-align:left;vertical-align:top;font-size:14px;line-height:1.8}
.access-table th{width:110px;color:var(--gold-700);font-weight:600;letter-spacing:.14em;background:var(--paper)}
.access-table td{color:var(--ink);letter-spacing:.04em}
.access-table a{color:var(--navy-700);text-decoration:underline;text-underline-offset:3px}
.access-map{position:relative;width:100%;aspect-ratio:4/3;border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden}
.access-map.large{aspect-ratio:16/8}
.access-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.access-map-note{margin-top:10px;font-size:12px;color:var(--ink-2);letter-spacing:.04em}
.transit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:36px}
.transit-card{background:var(--paper);padding:28px 30px;border-top:3px solid var(--gold-500)}
.transit-card h3{color:var(--navy-900);font-size:18px;letter-spacing:.08em;margin-bottom:12px}
.transit-card p{color:var(--ink-2);font-size:14px;line-height:1.95}

/* =========================================================
   CONTACT
========================================================= */
.contact{background:linear-gradient(180deg,var(--ivory),var(--paper));padding-bottom:110px}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:32px;margin-top:40px;align-items:start}
.contact-tel-card,.contact-form-card{background:#fff;padding:40px 36px;box-shadow:var(--shadow-md);border-top:3px solid var(--navy-900)}
.contact-card-head{display:flex;align-items:center;gap:18px;margin-bottom:20px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.contact-icon{flex:0 0 64px;width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy-700),var(--navy-900));border:1px solid var(--gold-500);border-radius:50%;box-shadow:0 6px 18px rgba(14,42,24,.18)}
.contact-icon svg{width:36px;height:36px;fill:var(--gold-400);filter:drop-shadow(0 1px 2px rgba(0,0,0,.25))}
.contact-icon-mail svg{width:38px;height:38px}
.contact-card-eyebrow{flex:1;font-size:14px;color:var(--navy-900);letter-spacing:.14em;font-weight:600;line-height:1.5}
.contact-tel{font-size:clamp(32px,4vw,48px);color:var(--navy-900);font-weight:700;display:block;margin-bottom:16px}
.contact-card-note{color:var(--ink-2);font-size:13px;line-height:1.9}
.contact-card-note a{color:var(--navy-700);text-decoration:underline;text-underline-offset:3px}
.contact-tel-divider{height:1px;background:var(--line);margin:24px 0 0}

.contact-form{display:grid;gap:16px}
.form-row{display:flex;flex-direction:column;gap:6px}
.form-row label{font-size:13px;font-weight:600;color:var(--navy-900);letter-spacing:.08em}
.req{display:inline-block;background:var(--red);color:#fff;font-size:10px;padding:2px 6px;margin-left:6px;letter-spacing:.08em;font-family:var(--sans);font-weight:700}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);background:#fbf8f1;
  font-family:var(--serif);font-size:15px;color:var(--ink);transition:border-color .25s,background .25s;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--gold-500);background:#fff}
.contact-form textarea{resize:vertical}
.form-submit{
  margin-top:8px;padding:16px;background:var(--navy-900);color:#fff;
  font-family:var(--sans);font-weight:700;letter-spacing:.14em;font-size:15px;
  border:1px solid var(--gold-500);transition:background .3s,transform .3s;width:100%;
}
.form-submit:hover{background:var(--navy-700);transform:translateY(-2px)}

/* =========================================================
   RESULTS PAGE
========================================================= */
.results-section{background:linear-gradient(180deg,var(--ivory),var(--paper))}
.results-year-band{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-md);padding:48px 40px;position:relative;margin-bottom:40px}
.results-year-band::before{content:"";position:absolute;inset:8px;border:1px solid var(--gold-500);pointer-events:none}
.results-year-label{display:inline-block;background:var(--navy-900);color:var(--gold-400);padding:6px 20px;font-family:var(--en-serif);letter-spacing:.22em;font-size:13px;margin-bottom:32px}
.results-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.results-card{background:linear-gradient(180deg,#fff,#fbf8f1);border:1px solid var(--line);padding:32px 24px;text-align:center}
.results-card-header{margin-bottom:12px}
.results-badge{display:inline-block;background:var(--navy-900);color:#fff;padding:4px 14px;font-size:11px;letter-spacing:.14em;font-family:var(--sans)}
.results-badge-middle{background:var(--gold-700)}
.results-school-name{font-size:20px;font-weight:600;color:var(--navy-900);letter-spacing:.06em;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:16px}
.results-nums-row{display:flex;justify-content:center;gap:28px;align-items:flex-end;margin-bottom:14px}
.results-num-block{text-align:center}
.results-num-label{display:block;font-size:11px;color:var(--ink-2);letter-spacing:.12em;margin-bottom:4px;font-family:var(--sans)}
.results-big-num{font-family:var(--num-font);color:var(--navy-900);line-height:1;display:flex;align-items:baseline;justify-content:center;gap:2px}
.results-big-digit{font-size:68px;font-weight:700;font-family:var(--num-font)}
.results-big-unit{font-size:16px;color:var(--ink-2);font-family:var(--serif)}
.results-rate-block{padding-left:24px;border-left:1px solid var(--line)}
.results-rate-num{font-family:var(--num-font);color:var(--red);font-size:40px;font-weight:700;line-height:1;display:flex;align-items:baseline;gap:2px}
.result-num{font-size:40px;font-weight:700;font-family:var(--num-font)}
.results-rate-pct{font-size:20px}
.results-card-note{font-size:12px;color:var(--ink-2);line-height:1.8;letter-spacing:.04em;margin-top:10px}
.results-policy-box{background:var(--navy-900);color:#fff;padding:32px 40px;text-align:center}
.results-policy-title{font-family:var(--en-serif);color:var(--gold-400);letter-spacing:.3em;font-size:13px;margin-bottom:14px}
.results-policy-text{font-size:15px;line-height:2;color:#e8ecf3;letter-spacing:.04em}

.cumulative-section{padding:96px 0}
.cumulative-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:60px}
.cumulative-card{background:var(--paper);padding:36px 24px;text-align:center;border-top:3px solid var(--gold-500);transition:transform .35s,box-shadow .35s}
.cumulative-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.cumulative-icon{width:56px;height:56px;margin:0 auto 16px;color:var(--gold-600)}
.cumulative-icon svg{width:100%;height:100%}
.cumulative-school{font-size:16px;font-weight:600;color:var(--navy-900);letter-spacing:.06em;margin-bottom:10px}
.cumulative-num{display:flex;align-items:baseline;justify-content:center;gap:4px;color:var(--navy-900);line-height:1;margin-bottom:12px}
.cumulative-unit{font-size:16px;color:var(--ink-2)}
.cumulative-desc{font-size:13px;color:var(--ink-2);line-height:1.8}

.results-bar-section{background:#fff;padding:36px 40px;border:1px solid var(--line);margin-top:40px}
.results-bar-title{font-size:18px;font-weight:600;color:var(--navy-900);letter-spacing:.08em;margin-bottom:28px;text-align:center}
.results-bars{display:grid;gap:16px}
.results-bar-row{display:grid;grid-template-columns:200px 1fr;align-items:center;gap:16px}
.results-bar-label{font-size:14px;font-weight:600;color:var(--navy-900);letter-spacing:.04em;text-align:right}
.results-bar-track{background:var(--paper);height:42px;position:relative;border:1px solid var(--line)}
.results-bar-fill{height:100%;width:var(--bar-w);background:linear-gradient(90deg,var(--navy-700),var(--navy-900));display:flex;align-items:center;justify-content:flex-end;min-width:60px}
.results-bar-val{font-family:var(--num-font);color:var(--gold-400);font-weight:700;font-size:15px;padding-right:14px}

.online-results{background:var(--paper);padding:80px 0}
.online-results-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.online-result-item{background:#fff;padding:20px 16px;text-align:center;font-size:15px;font-weight:600;color:var(--navy-900);border:1px solid var(--line);border-top:3px solid var(--gold-500);letter-spacing:.04em}
.results-online-note{text-align:center;font-size:12px;color:var(--ink-2);margin-top:8px}

/* REASONS PAGE */
.reason-intro{background:#fff;padding:80px 0 0}
.reason-intro-lead{text-align:center;font-size:16px;color:var(--ink-2);line-height:2.1;letter-spacing:.04em;margin-top:8px}
.reason-detail{background:var(--paper)}
.reason-detail-item{background:#fff;border:1px solid var(--line);margin-bottom:28px;overflow:hidden}
.reason-detail-head{display:flex;align-items:center;gap:24px;padding:28px 36px;background:linear-gradient(90deg,var(--navy-900),var(--navy-700))}
.reason-detail-num{font-family:var(--num-font);font-size:52px;font-weight:700;color:var(--gold-500);line-height:1;flex:0 0 auto}
.reason-detail-title{font-size:20px;font-weight:600;color:#fff;letter-spacing:.06em;line-height:1.5}
.reason-detail-body{padding:32px 36px}
.reason-detail-body p{color:var(--ink-2);font-size:15px;line-height:2;margin-bottom:14px}
.reason-detail-point-box{background:var(--paper);padding:20px 24px;border-left:4px solid var(--gold-500);margin-top:18px}
.reason-detail-point{font-size:14px;color:var(--navy-900);font-weight:600;letter-spacing:.04em;padding:4px 0}
.instructor-policy{margin-top:48px;background:var(--navy-900);padding:32px 40px;text-align:center}
.instructor-policy-text{color:#e8ecf3;font-size:15px;line-height:2;letter-spacing:.04em}
.instructor-policy-text strong{color:var(--gold-400)}

/* FLOW PAGE */
.flow-notice{background:#fff;padding:56px 0 0}
.flow-notice-box{background:var(--navy-900);color:#fff;padding:28px 40px;border-left:6px solid var(--gold-500)}
.flow-notice-title{font-size:16px;font-weight:700;color:var(--gold-400);letter-spacing:.14em;margin-bottom:10px}
.flow-notice-text{font-size:14.5px;line-height:2;color:#dde3ef}
.flow-notice-text strong{color:#fff}
.flow-cta-box{text-align:center;margin-top:52px;padding:36px;background:var(--paper);border:1px solid var(--line)}
.flow-cta-box>p{font-size:18px;color:var(--navy-900);font-weight:600;letter-spacing:.08em;margin-bottom:22px}
.flow-cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* CTA STRIP */
.cta-strip{background:linear-gradient(120deg,var(--navy-700),var(--navy-900));color:#fff;padding:56px 0;text-align:center}
.cta-strip h2{font-size:clamp(22px,2.4vw,30px);letter-spacing:.12em;color:#fff;margin-bottom:12px}
.cta-strip p{color:#d4d8e0;margin-bottom:24px;font-size:14px;letter-spacing:.08em}
.cta-strip .link-button{background:var(--gold-600);border-color:var(--gold-400);color:#fff}
.cta-strip .link-button:hover{background:var(--gold-700)}

/* FOOTER */
.site-footer{background:var(--navy-900);color:#bdd4c6;padding:56px 0 20px;position:relative}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold-500),transparent)}
.footer-flex{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-logo{font-family:var(--en-serif);font-size:26px;font-weight:600;color:#fff;letter-spacing:.14em}
.footer-jp{color:var(--gold-400);letter-spacing:.14em;margin:4px 0 16px;font-size:13px}
.footer-addr{font-size:13px;line-height:1.85}
.footer-tel{margin-top:12px;font-size:14px}
.footer-tel a{color:#fff;font-size:22px;font-weight:700}
.footer-nav ul{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 16px}
.footer-nav a{display:block;font-size:13px;color:#bdd4c6;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.08);transition:color .25s,padding-left .25s}
.footer-nav a:hover{color:var(--gold-400);padding-left:6px}
.footer-philosophy{font-size:14px;line-height:2;color:var(--gold-400);letter-spacing:.08em}
.footer-copy{text-align:center;font-family:var(--en-serif);font-size:11px;letter-spacing:.14em;margin-top:20px;color:#6c7c93}

/* TO TOP */
.to-top{position:fixed;right:24px;bottom:24px;width:48px;height:48px;background:var(--navy-900);color:var(--gold-400);display:flex;align-items:center;justify-content:center;font-size:20px;border:1px solid var(--gold-500);opacity:0;pointer-events:none;transition:opacity .35s,transform .35s;z-index:90}
.to-top.show{opacity:1;pointer-events:auto}
.to-top:hover{transform:translateY(-3px);background:var(--navy-700)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s,transform .9s}
.reveal.in-view{opacity:1;transform:translateY(0)}

/* =========================================================
   RESPONSIVE — 1024px
========================================================= */
@media (max-width:1024px){
  :root{--header-h:110px}
  .header-inner{grid-template-columns:1fr auto auto;gap:16px;padding:12px 0}
  .header-contact{display:none}
  .nav-en{font-size:13px;letter-spacing:.1em}
  .reason-grid,.course-grid,.achievement-grid,.instructor-grid{grid-template-columns:repeat(2,1fr)}
  .rep-flex{grid-template-columns:240px 1fr;gap:36px}
  .book-flex{grid-template-columns:220px 1fr;gap:36px}
  .access-flex,.contact-grid{grid-template-columns:1fr}
  .footer-flex{grid-template-columns:1fr 1fr}
  .course-detail{grid-template-columns:180px 1fr;gap:24px;padding:28px}
  .results-cards{grid-template-columns:repeat(2,1fr)}
  .cumulative-grid{grid-template-columns:repeat(2,1fr)}
  .online-results-grid{grid-template-columns:repeat(2,1fr)}
  .results-bar-row{grid-template-columns:140px 1fr}
}

/* =========================================================
   RESPONSIVE — 720px (スマホ)
========================================================= */
@media (max-width:720px){
  :root{--header-h:64px;--peek:40px;--carousel-gap:10px}
  .sp-only{display:inline}

  /* ヘッダー */
  .header-inner{grid-template-columns:1fr auto;padding:10px 0}
  .brand-en{font-size:20px}
  .brand-jp{font-size:11px}
  .brand-tagline{display:none}
  .header-cta{display:none}
  .hamburger{
    display:flex;flex-direction:column;gap:5px;
    width:36px;height:36px;align-items:center;justify-content:center;
  }
  .hamburger span{display:block;width:24px;height:2px;background:var(--navy-900);transition:transform .3s,opacity .3s}
  .hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  /* ナビゲーション：スマホでは縦積みドロワー */
  .site-nav{
    position:fixed;top:64px;left:0;right:0;
    max-height:0;overflow:hidden;transition:max-height .4s ease;z-index:190;
  }
  .site-nav.open{max-height:80vh;overflow-y:auto}
  .nav-list{grid-template-columns:1fr}
  .nav-list li{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .nav-list a{flex-direction:row;justify-content:space-between;padding:16px 24px}
  .nav-list a::after{display:none}

  /* セクション */
  section{padding:56px 0}

  /* ヒーロー */
  .hero{height:56vh;min-height:380px}
  .hero-title{font-size:clamp(26px,7vw,36px)}
  .hero-lead{font-size:13px;line-height:1.85}
  .hero-badges{gap:8px;margin-top:20px}
  .hero-badge{padding:8px 6px;font-size:11px}
  .hero-badge b{font-size:16px}
  .carousel-btn{width:38px;height:38px;font-size:20px}
  .carousel-prev{left:10px}
  .carousel-next{right:10px}

  /* ページバナー */
  .page-banner{height:200px}
  .page-banner-title{font-size:clamp(22px,6vw,32px)}

  /* グリッド系 */
  .achievement-band{padding:24px 16px}
  .achievement-grid,.reason-grid,.course-grid,.instructor-grid,.voice-grid,.transit-grid{grid-template-columns:1fr}
  .results-cards,.cumulative-grid,.online-results-grid{grid-template-columns:1fr}

  /* 代表・書籍 */
  .rep-flex,.book-flex{grid-template-columns:1fr;gap:24px}
  .rep-photo{max-width:220px;margin-inline:auto}
  .book-cover{max-width:180px;margin-inline:auto}
  .book-info .section-title,.book-info .section-eyebrow,.book-info .section-divider{text-align:center}
  .book-info .section-divider span{margin-inline:auto}

  /* コース詳細 */
  .course-detail{grid-template-columns:1fr;padding:20px}

  /* フロー */
  .step-item{grid-template-columns:64px 1fr;padding:20px 16px;gap:14px}
  .step-num{font-size:36px;padding-right:12px}
  .flow-notice-box{padding:20px 16px}
  .flow-cta-btns{flex-direction:column;align-items:center}

  /* 結果 */
  .results-big-digit{font-size:52px}
  .results-nums-row{gap:14px}
  .results-year-band{padding:24px 16px}
  .results-bar-row{grid-template-columns:1fr;gap:6px}
  .results-bar-label{text-align:left}
  .results-bar-section{padding:20px 16px}

  /* アクセス */
  .access-flex{display:block}
  .access-map-col{margin-top:24px}

  /* コンタクト */
  .contact-grid{grid-template-columns:1fr}
  .contact-tel-card,.contact-form-card{padding:24px 16px}

  /* リーズン詳細 */
  .reason-detail-head{flex-direction:column;gap:10px;padding:20px 16px}
  .reason-detail-body{padding:20px 16px}
  .reason-detail-num{font-size:36px}
  .reason-detail-title{font-size:17px}

  /* フッター */
  .footer-flex{grid-template-columns:1fr}

  /* その他 */
  .cumu-list{grid-template-columns:repeat(2,1fr)}
  .contact-icon{flex-basis:52px;width:52px;height:52px}
  .contact-icon svg,.contact-icon-mail svg{width:28px;height:28px}
}

/* style.css に追加・上書き */

/* スライダー全体の枠 */
.hero {
    overflow: hidden;
    padding: 40px 0; /* 上下に少し余白 */
    background: #fff;
}

.slider-container {
    position: relative;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.slider-wrapper {
    display: flex;
    transition: transform 0.5s ease-in-out;
    /* 左右の画像が見えるように調整 */
}

.slide {
    flex: 0 0 80%; /* 中央の画像を80%の幅に設定 */
    margin: 0 10px; /* 画像同士の隙間 */
    box-sizing: border-box;
}

.slide img {
    width: 100%;
    height: 500px; /* 縦幅を固定して揃える */
    object-fit: cover; /* 比率を維持したまま領域を埋める */
    border-radius: 8px;
    /* フィルター（暗くする設定）を完全に排除 */
    filter: none !important;
    opacity: 1 !important;
}

/* 矢印ボタンのデザイン */
.prev-btn, .next-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(26, 42, 68, 0.8); /* 塾カラーのネイビー */
    color: #fff;
    border: none;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 20px;
    z-index: 10;
    transition: 0.3s;
}

.prev-btn { left: 5%; }
.next-btn { right: 5%; }

.prev-btn:hover, .next-btn:hover {
    background: #c5a059; /* アクセントのゴールド */
}

/* スマホ対応 */
@media (max-width: 768px) {
    .slide { flex: 0 0 90%; } /* スマホでは中央を広めに */
    .slide img { height: 300px; } /* スマホ用の高さ */
    .prev-btn, .next-btn { width: 40px; height: 40px; }
}

/* ヒーローセクションの直後に来るコンテナの上の余白を消す */
.hero + section .container,
.hero + .container {
    padding-top: 0 !important;
}

/* --- コースカードのサムネイル（画像）共通設定 --- */
.course-thumb {
    width: 100%;
    height: 240px; /* 画像の縦幅。お好みで200pxなどに変更してください */
    background-size: cover;      /* 枠に合わせて隙間なく画像を敷き詰める */
    background-position: center; /* 画像の中心が見えるようにする */
    background-color: #f0f0f0;   /* 画像が読み込まれるまでの仮の色（薄いグレー） */
}

/* --- 各コース個別の画像設定 --- */
/* 高校受験コースの画像 */
.course-thumb-01 {
    background-image: url('images/course-01.jpg'); 
}

/* 中学受験コースの画像 */
.course-thumb-02 {
    background-image: url('images/course-02.jpg'); 
}

/* 定期テスト対策の画像 */
.course-thumb-03 {
    background-image: url('images/course-03.jpg'); 
}

/* オンライン国語の画像 */
.course-thumb-04 {
    background-image: url('images/course-04.jpg'); 
}

/* スライダーのリンク設定 */
.slide-link {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    cursor: pointer; /* マウスを乗せた時に指マークにする */
}

.slide-link img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover; /* 画像を枠いっぱいに綺麗に収める */
}

/* =========================================================
   スマホ専用 — ヒーローエリア：横幅全体に画像を収める
========================================================= */
@media (max-width: 720px) {

  /* ヒーローエリアの高さを画像に追従させる */
  .hero {
    height: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin-top: 72px !important; /* スマホヘッダーの実高さ分だけ下にずらす */
    margin-bottom: 0 !important;
    overflow: hidden;
  }

  /* スライダー各要素の高さも auto に */
  .slider-container,
  .slider-wrapper {
    height: auto !important;
  }

  /* 各スライドの余白をゼロにする */
  .slide {
    margin: 0 !important;
    border-radius: 0;
  }

  /* 白い幕（::after オーバーレイ）をスマホでは非表示 */
  .slide::after {
    display: none;
  }

  /* 画像を横幅100%・高さ自動で表示（トリミングなし） */
  .slide img {
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    border-radius: 0 !important;
    display: block;
    vertical-align: bottom; /* inline隙間を完全に排除 */
  }

  /* slide-link も高さ auto・余白ゼロ */
  .slide-link {
    height: auto !important;
    display: block;
    line-height: 0; /* 画像下の隙間を排除 */
  }

  /* slider-container の余白もゼロに */
  .slider-container {
    margin: 0 !important;
    padding: 0 !important;
  }

  /* 矢印ボタンを画像に重なる位置に調整 */
  .prev-btn {
    left: 6px;
  }
  .next-btn {
    right: 6px;
  }
}

/* =========================================================
   スマホ専用 — 余白を最小化してコンテンツ幅を広げる
========================================================= */
@media (max-width: 720px) {

  /* コンテナの左右余白を縮小（80% → 90%） */
  .container {
    width: 90%;
  }

  /* ヘッダー内の幅も広げる */
  .header-inner,
  .nav-list {
    width: 92%;
  }

  /* セクション見出し・バナー内の余白も縮小 */
  .page-banner-inner,
  .hero-copy {
    width: 90%;
  }

  /* achievement帯の内側パディング縮小 */
  .achievement-band {
    padding: 20px 12px;
  }

  /* reason/course カードのパディング縮小 */
  .reason-card {
    padding: 24px 16px;
  }

  /* contact カードのパディング縮小 */
  .contact-tel-card,
  .contact-form-card {
    padding: 20px 14px;
  }

  /* voice カードのパディング縮小 */
  .voice-card {
    padding: 24px 16px;
  }

  /* フッターの左右パディング縮小 */
  .footer-flex {
    padding-bottom: 24px;
  }

  /* results-year-bandの内側パディング縮小 */
  .results-year-band {
    padding: 20px 12px;
  }

  /* 結果バーセクションの内側パディング縮小 */
  .results-bar-section {
    padding: 16px 12px;
  }

  /* フロー・ノーティスボックスの内側パディング縮小 */
  .flow-notice-box {
    padding: 18px 14px;
  }

  /* reason詳細ヘッドのパディング縮小 */
  .reason-detail-head {
    padding: 16px 14px;
  }

  /* reason詳細ボディのパディング縮小 */
  .reason-detail-body {
    padding: 16px 14px;
  }

  /* course詳細のパディング縮小 */
  .course-detail {
    padding: 16px 12px;
  }

  /* ステップアイテムのパディング縮小 */
  .step-item {
    padding: 16px 12px;
  }

  /* FAQ のパディング縮小 */
  .faq-q {
    padding: 16px 14px;
  }

  .faq-a-inner {
    padding: 16px 14px 18px 56px;
  }

  .faq-a-inner::before {
    left: 14px;
  }
}

/* -------------------------------------
   ここから下は style.css の一番最後に書く
------------------------------------- */

/* 【順番1】まず基本のルールを書く（PCではスマホ用改行を消す） */
.sp-br {
    display: none !important;
}

/* 【順番2】その「下」に、スマホの時の例外ルールを書く */
@media (max-width: 768px) {
    /* スマホ画面になったら、スマホ用改行を表示する */
    .sp-br {
        display: inline !important;
    }
    /* スマホ画面になったら、PC用改行を消す */
    .pc-br {
        display: none !important;
    }
}