/* ==========================================================
   MVP高等学園 — 共有スタイルシート v2
   Lunar Futurism — White Base × Cyan/Pink Accents
   ========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;700;900&family=Noto+Serif+JP:wght@400;700;900&family=Noto+Sans+JP:wght@300;400;500;700&family=Space+Mono:ital,wght@0,400;0,700;1,400&display=swap');

/* ── デザイントークン ── */
:root {
  /* ライトベース */
  --bg:       #FFFFFF;
  --bg-2:     #F6F8FF;
  --bg-3:     #EEF1FB;
  --bg-dark:  #0A1628;   /* 唯一の濃い背景（CTAのみ） */
  --surface:  #FFFFFF;
  --line:     rgba(10,22,60,0.08);
  --line-lg:  rgba(10,22,60,0.14);
  --text:     #0A1628;
  --muted:    #5E6E92;
  --faint:    rgba(10,22,60,0.04);

  /* アクセント */
  --cyan:    #00C8FF;
  --pink:    #FF1055;
  --gold:    #FF8C00;
  --green:   #00D4A8;
  --purple:  #7B5CF0;
  --amber:   #F59E0B;
  --navy:    #0A1628;

  /* ページごとに上書き */
  --accent:      var(--cyan);
  --accent-glow: rgba(0,200,255,0.18);
  --accent-tint: rgba(0,200,255,0.06);

  --font-d:  'Orbitron', sans-serif;
  --font-s:  'Noto Serif JP', serif;
  --font-b:  'Noto Sans JP', sans-serif;
  --font-m:  'Space Mono', monospace;

  --nav-h:   72px;
  --ease:    cubic-bezier(0.16,1,0.3,1);
  --ease-in: cubic-bezier(0.7,0,1,1);
  --max-w:   1360px;
  --r:       6px;
}

/* ── リセット ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-b);
  font-weight:400;
  line-height:1.7;
  overflow-x:hidden;
  line-break:strict;
}
a { color:inherit; text-decoration:none; }
img,video { display:block; max-width:100%; }

h1,h2,h3,h4,
.section-h2,
.page-hero-h1,
.info-value,
.pillar-card h3,
.teacher-card h3,
.record-card h3,
.real-program-card h3,
.admission-step h3,
.mvp-card h3,
.day-card h3,
.calendar-card h3,
.worry-card h3,
.entry-card h3,
.promise-card h3,
.image-card h3,
.news-body h3 {
  text-wrap:balance;
  overflow-wrap:anywhere;
}

p,
.section-lead,
.page-hero-sub,
.card p,
.info-card p,
.pillar-card p,
.teacher-card p,
.record-card p,
.real-program-card p,
.admission-step p,
.mvp-card p,
.day-card p,
.calendar-card p,
.worry-card p,
.entry-card p,
.promise-card p,
.image-card p,
.news-body p {
  text-wrap:pretty;
  overflow-wrap:anywhere;
}

/* ── カスタムカーソル ── */
#cursor {
  position:fixed; width:8px; height:8px;
  background:var(--accent); border-radius:50%;
  pointer-events:none; z-index:99999;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease);
}
#cursor-ring {
  position:fixed; width:32px; height:32px;
  border:1px solid var(--accent); border-radius:50%;
  pointer-events:none; z-index:99998;
  transform:translate(-50%,-50%);
  transition:width .4s var(--ease),height .4s var(--ease),opacity .3s;
  opacity:.4;
}
body.hovering #cursor  { width:4px; height:4px; }
body.hovering #cursor-ring { width:52px; height:52px; opacity:.15; }

/* ── ローディング画面 ── */
#loader {
  position:fixed; inset:0; z-index:10000;
  background:var(--bg);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  opacity:1; visibility:visible;
  transition:opacity 1.9s var(--ease), visibility 1.9s var(--ease);
}
#loader.done {
  pointer-events:none;
  opacity:0;
  visibility:hidden;
}
#loader.done .ldr-top { transform:translateY(-100%); }
#loader.done .ldr-bot { transform:translateY(100%); }

.ldr-top,.ldr-bot {
  position:absolute; left:0; right:0; height:50%;
  background:var(--bg); z-index:1;
  transition:transform .7s var(--ease);
}
.ldr-top { top:0; }
.ldr-bot { bottom:0; }

.ldr-center {
  position:relative; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:28px;
}

/* ローダーSVGリング */
.ldr-svg { width:min(360px,82vw); height:min(360px,82vw); position:relative; }
.ldr-svg .r-bg   { fill:none; stroke:rgba(10,22,60,.06); stroke-width:1; }
.ldr-svg .r-deco { fill:none; stroke:rgba(10,22,60,.04); stroke-width:1; }
.ldr-svg .r-arc  {
  fill:none; stroke:var(--accent); stroke-width:2;
  stroke-linecap:round;
  stroke-dasharray:565.48; stroke-dashoffset:565.48;
  transform-origin:center;
  transform:rotate(-90deg);
  transition:stroke-dashoffset 2.2s cubic-bezier(.4,0,.2,1);
}
.ldr-svg .r-tick { fill:none; stroke:var(--accent); stroke-width:.5; opacity:.2; }
.ldr-logo-wrap {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
}
.ldr-logo {
  width:min(330px,74vw); height:auto; opacity:0;
  max-height:min(240px,58vw);
  object-fit:contain;
  transform:scale(.88);
  transition:opacity .6s var(--ease),transform .6s var(--ease);
}
.ldr-logo.show { opacity:1; transform:scale(1); }
.ldr-counter {
  font-family:var(--font-m); font-size:.72rem;
  letter-spacing:.3em; color:var(--accent);
  min-width:56px; text-align:center;
}
.ldr-label {
  font-family:var(--font-m); font-size:.65rem;
  letter-spacing:.5em; color:var(--muted);
  text-transform:uppercase;
}
.ldr-label span { display:inline-block; animation:ldot 1s step-end infinite; }
.ldr-label span:nth-child(2) { animation-delay:.33s; }
.ldr-label span:nth-child(3) { animation-delay:.66s; }
@keyframes ldot { 0%,100%{opacity:1} 50%{opacity:0} }

/* ページ遷移バー */
#page-bar {
  position:fixed; top:0; left:0; right:0; height:2px;
  background:var(--accent); z-index:9999;
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease);
  box-shadow:0 0 8px var(--accent-glow);
}
#page-bar.loading { transform:scaleX(.7); }
#page-bar.done { transform:scaleX(1); transition:transform .2s,opacity .3s .2s; opacity:0; }

/* ── ナビゲーション ── */
#nav {
  position:fixed; top:0; left:0; right:0; height:var(--nav-h);
  z-index:1000;
  display:flex; align-items:center;
  padding:0 48px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s;
}
#nav.scrolled {
  box-shadow:0 2px 24px rgba(10,22,60,.06);
}
.nav-logo {
  display:flex; align-items:center;
}
.nav-logo img { height:34px; width:auto; }

.nav-links {
  display:flex; align-items:center; gap:0;
  margin-left:auto; list-style:none;
}
.nav-links li { position:relative; }
.nav-links a {
  display:flex; align-items:center; height:var(--nav-h);
  padding:0 18px;
  font-family:var(--font-b); font-size:.78rem; font-weight:500;
  letter-spacing:.06em; color:var(--muted);
  white-space:nowrap;
  transition:color .2s;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:18px; right:18px;
  height:2px; background:var(--accent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav-links a:hover,
.nav-links a.active { color:var(--text); }
.nav-links a:hover::after,
.nav-links a.active::after { transform:scaleX(1); }

/* バージョンバッジ (ロゴ横) */
.nav-ver {
  display:inline-block;
  font-family:var(--font-m); font-size:.42rem;
  letter-spacing:.18em; color:var(--cyan);
  padding:2px 6px; border:1px solid rgba(0,200,255,.35);
  border-radius:2px; margin-left:10px;
  vertical-align:middle; opacity:.75;
  white-space:nowrap;
}

/* CTA ボタン in nav — リデザイン */
.nav-cta {
  position:relative;
  display:inline-flex; align-items:center; gap:7px;
  padding:9px 20px; margin-left:18px;
  background:var(--bg-dark); color:#fff!important;
  border:1px solid rgba(0,200,255,.22);
  border-radius:3px;
  font-family:var(--font-m)!important; font-size:.65rem!important;
  font-weight:400!important; letter-spacing:.18em;
  text-transform:uppercase; white-space:nowrap;
  transition:border-color .3s,box-shadow .3s!important;
  overflow:hidden;
}
/* 上端のグロー線（ホバーでスライドイン） */
.nav-cta::after {
  content:''; position:absolute;
  top:0; left:0; width:100%; height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease)!important;
  display:block!important;
}
.nav-cta:hover {
  border-color:rgba(0,200,255,.55)!important;
  box-shadow:0 0 22px rgba(0,200,255,.12),inset 0 0 18px rgba(0,200,255,.04)!important;
  transform:none!important;
  color:#fff!important;
}
.nav-cta:hover::after { transform:scaleX(1); }
/* 小さな矢印アイコン */
.nav-cta-arrow {
  font-size:.65rem; opacity:.6;
  display:inline-block;
  transition:transform .3s var(--ease);
}
.nav-cta:hover .nav-cta-arrow { transform:translateX(3px); opacity:1; }

/* ── 連結型 nav CTAグループ ── */
.nav-cta-group-item { list-style:none; }
.nav-cta-group {
  display:flex;
  margin-left:18px;
  border-radius:5px;
  box-shadow:0 2px 18px rgba(10,22,60,.18);
}
.nav-cta-group .nav-cta { margin:0!important; padding:9px 20px!important; }
.nav-cta-group .nav-consult-wrap { display:flex; align-items:stretch; margin:0; padding:0; }
.nav-cta-group .nav-consult-wrap .nav-cta { height:auto; }

/* 資料請求（スカイブルー単色） */
.nav-cta-cyan {
  background:#1A90CC!important;
  border:none!important;
  border-right:1px solid rgba(255,255,255,.22)!important;
  border-radius:5px 0 0 5px!important;
}
.nav-cta-cyan::after { display:none!important; }
.nav-cta-cyan:hover {
  background:#1680B8!important;
  box-shadow:none!important;
  transform:none!important;
  border-color:rgba(255,255,255,.22)!important;
}

/* 無料相談・見学（ピンク単色） */
.nav-cta-pink {
  background:#D42882!important;
  border:none!important;
  border-radius:0 5px 5px 0!important;
}
.nav-cta-pink::after { display:none!important; }
.nav-cta-pink:hover {
  background:#BC2070!important;
  box-shadow:none!important;
  transform:none!important;
  border-color:transparent!important;
}

/* ドロップダウン */
.nav-consult-wrap { position:relative; }
.nav-dropdown {
  position:absolute; top:100%; right:0; min-width:310px;
  background:#fff; border:1px solid var(--line);
  border-radius:0 0 10px 10px;
  box-shadow:0 16px 40px rgba(10,22,60,.12);
  opacity:0; pointer-events:none;
  transform:translateY(-6px);
  transition:opacity .2s var(--ease), transform .2s var(--ease);
  z-index:1001; overflow:hidden;
}
.nav-consult-wrap:hover .nav-dropdown {
  opacity:1; pointer-events:auto; transform:translateY(0);
}
.nav-dropdown-item {
  display:flex!important; align-items:flex-start!important; gap:14px;
  padding:18px 20px!important; color:var(--text)!important;
  border-bottom:1px solid var(--line)!important; height:auto!important;
  font-family:var(--font-b)!important; font-size:.82rem!important;
  letter-spacing:0!important; text-transform:none!important;
  transition:background .15s!important; text-decoration:none;
}
.nav-dropdown-item:last-child { border-bottom:none!important; }
.nav-dropdown-item:hover { background:var(--bg-2)!important; color:var(--text)!important; }
.nav-dropdown-item::after { display:none!important; }
.nav-dd-icon {
  font-size:.6rem; color:var(--cyan); margin-top:5px;
  flex-shrink:0; font-family:var(--font-m); letter-spacing:.08em;
}
.nav-dd-content strong {
  display:block; font-size:.83rem; font-weight:700;
  color:var(--text); margin-bottom:3px;
}
.nav-dd-content span { font-size:.71rem; color:var(--muted); line-height:1.55; }

/* メガメニュー */
#mega-overlay {
  position:fixed; top:var(--nav-h); left:0; right:0;
  z-index:999; pointer-events:none;
}
.mega-panel {
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(24px);
  border-bottom:1px solid var(--line);
  box-shadow:0 8px 40px rgba(10,22,60,.08);
  overflow:hidden; max-height:0;
  transition:max-height .4s var(--ease);
  pointer-events:none;
}
.mega-panel.open { max-height:340px; pointer-events:all; }
.mega-inner {
  display:grid; grid-template-columns:360px 1fr;
  max-width:var(--max-w); margin:0 auto; padding:0 48px;
}
.mega-visual { padding:32px 40px 32px 0; border-right:1px solid var(--line); overflow:hidden; position:relative; }
.mega-visual-img {
  width:100%; height:200px; object-fit:cover;
  border-radius:var(--r);
  transition:transform 4s ease;
}
.mega-panel.open .mega-visual-img { transform:scale(1.03); }
.mega-visual-label {
  position:absolute; bottom:44px; left:12px;
  font-family:var(--font-m); font-size:.6rem;
  letter-spacing:.3em; color:var(--accent); text-transform:uppercase;
  padding:3px 10px; background:var(--accent-tint);
  border-radius:2px; border:1px solid var(--accent);
}
.mega-content { padding:32px 0 32px 40px; }
.mega-title {
  font-family:var(--font-d); font-size:1.2rem;
  letter-spacing:.04em; color:var(--text); margin-bottom:6px;
}
.mega-desc { font-size:.78rem; color:var(--muted); margin-bottom:20px; line-height:1.7; }
.mega-links { display:flex; flex-wrap:wrap; gap:8px; list-style:none; }
.mega-links a {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 16px; border:1px solid var(--line); border-radius:100px;
  font-size:.75rem; color:var(--muted);
  transition:color .2s,border-color .2s,background .2s;
}
.mega-links a::before { content:'→'; font-size:.65rem; color:var(--accent); transition:transform .2s; }
.mega-links a:hover { color:var(--text); border-color:var(--accent); background:var(--accent-tint); }
.mega-links a:hover::before { transform:translateX(3px); }

/* ハンバーガー */
#hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; margin-left:auto; padding:8px;
  background:none; border:none;
}
#hamburger span { display:block; width:24px; height:1px; background:var(--text); transition:transform .3s var(--ease),opacity .3s; }
#hamburger.open span:nth-child(1) { transform:translateY(6px) rotate(45deg); }
#hamburger.open span:nth-child(2) { opacity:0; }
#hamburger.open span:nth-child(3) { transform:translateY(-6px) rotate(-45deg); }

/* モバイルメニュー */
#mobile-menu {
  position:fixed; inset:0; top:var(--nav-h); z-index:998;
  background:rgba(255,255,255,.97); backdrop-filter:blur(20px);
  padding:40px 24px; transform:translateX(100%);
  transition:transform .5s var(--ease); overflow-y:auto;
}
#mobile-menu.open { transform:translateX(0); }
.mobile-nav-item {
  border-bottom:1px solid var(--line); padding:18px 0;
  display:flex; flex-direction:column; gap:0;
}
.mobile-nav-item>a { font-family:var(--font-d); font-size:1rem; color:var(--text); }
.mobile-subnav { padding:12px 0 0 16px; display:flex; flex-direction:column; gap:8px; }
.mobile-subnav a { font-size:.82rem; color:var(--muted); }

/* ── ページヒーロー（各ページの最上部全画面） ── */
.page-hero {
  position:relative; height:86vh; min-height:560px;
  display:flex; align-items:flex-end; padding-bottom:80px;
  overflow:hidden;
  background:var(--bg-2);
  padding-top:var(--nav-h);
}

/* サブページ右側メディア */
.page-hero-media {
  position:absolute; right:0; top:0; bottom:0;
  width:54%; pointer-events:none;
  display:flex; align-items:center; justify-content:flex-end;
  -webkit-mask-image:linear-gradient(to left,rgba(0,0,0,.9) 30%,rgba(0,0,0,0) 100%);
  mask-image:linear-gradient(to left,rgba(0,0,0,.9) 30%,rgba(0,0,0,0) 100%);
}
.page-hero-media video,
.page-hero-media img {
  width:100%; height:100%;
  object-fit:cover;
  opacity:.56;
}
.page-hero-media img {
  filter:saturate(1.06) contrast(1.02);
}
.page-hero-bg {
  position:absolute; inset:0;
}
/* 白系ノイズテクスチャ */
.page-hero-noise {
  position:absolute; inset:0; opacity:.025; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:256px; mix-blend-mode:multiply;
}
/* 極細グリッド */
.page-hero-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(10,22,60,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(10,22,60,.04) 1px,transparent 1px);
  background-size:72px 72px;
}
/* サイアンのグロー（右上から） */
.page-hero-accent {
  position:absolute; top:0; right:0;
  width:60vw; height:100%;
  background:radial-gradient(ellipse 60% 80% at 80% 20%,var(--accent-glow),transparent);
  pointer-events:none;
}
.page-hero-content {
  position:relative; z-index:2;
  max-width:var(--max-w); width:100%; margin:0 auto; padding:0 48px;
}
.page-hero-eyebrow {
  font-family:var(--font-m); font-size:.65rem;
  letter-spacing:.45em; color:var(--accent); text-transform:uppercase;
  margin-bottom:20px;
  display:flex; align-items:center; gap:12px;
}
.page-hero-eyebrow::before { content:''; width:28px; height:1px; background:var(--accent); }
.page-hero-h1 {
  font-family:var(--font-d); font-size:clamp(3rem,7vw,6.5rem);
  font-weight:900; line-height:1; letter-spacing:-.01em; color:var(--text);
  margin-bottom:20px;
}
.page-hero-h1 em { font-style:normal; color:var(--accent); display:block; }
.page-hero-sub {
  font-family:var(--font-s); font-size:clamp(.9rem,1.4vw,1.1rem);
  color:var(--muted); max-width:520px; line-height:1.85;
}
.page-hero-scroll {
  position:absolute; bottom:40px; right:48px; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family:var(--font-m); font-size:.58rem;
  letter-spacing:.35em; color:var(--muted); text-transform:uppercase;
}
.scroll-line { width:1px; height:50px; background:var(--line-lg); position:relative; overflow:hidden; }
/* 1回だけ流れる（ループなし） */
.scroll-line::after {
  content:''; position:absolute; top:0; left:0; width:100%; height:50px;
  background:var(--accent);
  animation:scrollDown 1.2s var(--ease) 1.5s 1 forwards;
  transform:translateY(-100%);
}
@keyframes scrollDown { from{transform:translateY(-100%)} to{transform:translateY(100%)} }

/* ── セクション共通 ── */
.section {
  position:relative;
  overflow:hidden;
  padding:104px 0;
}
.section::before {
  content:'';
  position:absolute;
  top:72px;
  right:max(24px,calc((100vw - var(--max-w)) / 2 + 32px));
  width:300px;
  height:300px;
  border:1px solid rgba(10,22,60,.06);
  background:
    linear-gradient(rgba(10,22,60,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(10,22,60,.035) 1px,transparent 1px),
    radial-gradient(circle at 70% 20%,var(--accent-tint),transparent 56%);
  background-size:32px 32px,32px 32px,100% 100%;
  border-radius:var(--r);
  opacity:.72;
  pointer-events:none;
}
.section::after {
  content:'';
  position:absolute;
  left:max(20px,calc((100vw - var(--max-w)) / 2 + 16px));
  bottom:54px;
  width:92px;
  height:1px;
  background:linear-gradient(90deg,var(--accent),transparent);
  opacity:.34;
  pointer-events:none;
}
.section:nth-of-type(even)::before {
  right:auto;
  left:max(24px,calc((100vw - var(--max-w)) / 2 + 32px));
}
.section-inner {
  position:relative;
  z-index:1;
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 48px;
}
.section-eyebrow {
  font-family:var(--font-m); font-size:.65rem;
  letter-spacing:.4em; color:var(--accent); text-transform:uppercase;
  margin-bottom:14px; display:flex; align-items:center; gap:12px;
}
.section-eyebrow::before { content:''; width:22px; height:1px; background:var(--accent); }
.section-h2 {
  font-family:var(--font-d); font-size:clamp(1.8rem,3.5vw,3rem);
  font-weight:900; line-height:1.1; letter-spacing:-.01em;
  color:var(--text); margin-bottom:12px;
}
.section-lead {
  font-family:var(--font-s); font-size:.95rem;
  color:var(--muted); max-width:560px; line-height:1.9; margin-bottom:60px;
}

/* 区切り線 */
.section-rule {
  width:100%; height:1px; background:var(--line);
  margin:0; border:none;
}

/* ── カード ── */
.card {
  background:linear-gradient(180deg,var(--bg),var(--bg-2));
  border:1px solid var(--line);
  border-radius:var(--r); padding:36px;
  transition:border-color .3s,box-shadow .3s,transform .3s var(--ease);
  position:relative; overflow:hidden;
  box-shadow:0 16px 42px rgba(10,22,60,.045);
}
.card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--accent),transparent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease);
}
.card:hover {
  border-color:rgba(10,22,60,.15);
  box-shadow:0 22px 56px rgba(10,22,60,.08);
  transform:translateY(-3px);
}
.card:hover::before { transform:scaleX(1); }

/* ── ボタン ── */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:13px 30px; border-radius:100px;
  font-family:var(--font-b); font-size:.83rem; font-weight:700;
  letter-spacing:.04em; cursor:pointer;
  transition:all .3s var(--ease); border:none;
}
.btn-primary {
  background:var(--accent); color:#fff;
  box-shadow:0 4px 20px var(--accent-glow);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px var(--accent-glow); }
.btn-outline {
  background:transparent; color:var(--text);
  border:1px solid var(--line-lg);
}
.btn-outline:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-tint); }
.btn svg { width:15px; height:15px; flex-shrink:0; }

/* ── フッター ── */
#footer {
  background:var(--bg-2); border-top:1px solid var(--line);
  padding:80px 0 40px;
}
.footer-inner { max-width:var(--max-w); margin:0 auto; padding:0 48px; }
.footer-top {
  display:grid; grid-template-columns:260px 1fr;
  gap:80px; padding-bottom:56px; border-bottom:1px solid var(--line);
}
.footer-brand img { height:36px; margin-bottom:18px; }
.footer-brand-desc { font-size:.8rem; color:var(--muted); line-height:1.9; }
.footer-nav-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:36px; }
.footer-nav-col h4 {
  font-family:var(--font-m); font-size:.62rem; letter-spacing:.3em;
  color:var(--accent); text-transform:uppercase; margin-bottom:14px;
}
.footer-nav-col ul { list-style:none; display:flex; flex-direction:column; gap:9px; }
.footer-nav-col a { font-size:.8rem; color:var(--muted); transition:color .2s; }
.footer-nav-col a:hover { color:var(--text); }
.footer-bottom {
  display:flex; align-items:center; justify-content:space-between; padding-top:28px;
}
.footer-copy { font-family:var(--font-m); font-size:.65rem; letter-spacing:.15em; color:var(--muted); }
.footer-social { display:flex; gap:12px; }
.footer-social a {
  width:34px; height:34px; border:1px solid var(--line);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  transition:border-color .2s,background .2s;
}
.footer-social a:hover { border-color:var(--accent); background:var(--accent-tint); }
.footer-social img { width:15px; height:15px; }

/* ── スクロールアニメーション ── */
.fu       { opacity:0; transform:translateY(36px); }
.fu-left  { opacity:0; transform:translateX(-36px); }
.fu-right { opacity:0; transform:translateX(36px); }
.fu.visible,.fu-left.visible,.fu-right.visible {
  opacity:1; transform:translate(0);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
}

/* ── 数字カウント ── */
[data-count] { display:inline-block; }

/* ── アコーディオン共通 ── */
.accordion-item { overflow:hidden; }
.accordion-body { max-height:0; overflow:hidden; transition:max-height .55s var(--ease); }

/* ── ビデオラッパー ── */
.video-wrapper {
  position:relative; padding-bottom:56.25%; height:0;
  border:1px solid var(--line); border-radius:var(--r);
  overflow:hidden; background:var(--bg-3);
}
.video-wrapper iframe,.video-wrapper video {
  position:absolute; top:0; left:0; width:100%; height:100%; border:none;
}
.video-wrapper video { object-fit:cover; }

/* ── スクロールバー ── */
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:var(--bg-2); }
::-webkit-scrollbar-thumb { background:var(--accent); border-radius:2px; }

/* ── レスポンシブ ── */
@media(max-width:1024px) {
  .footer-top { grid-template-columns:1fr; gap:36px; }
  .footer-nav-grid { grid-template-columns:repeat(2,1fr); }
  .mega-inner { grid-template-columns:280px 1fr; }
}
@media(max-width:768px) {
  :root { --nav-h:58px; }
  #nav { padding:0 20px; }
  .nav-links { display:none; }
  #hamburger { display:flex; }
  .page-hero-content { padding:0 20px; }
  .section-inner { padding:0 20px; }
  .section { padding:80px 0; }
  .footer-inner { padding:0 20px; }
  .footer-bottom { flex-direction:column; gap:16px; text-align:center; }
  .footer-nav-grid { grid-template-columns:repeat(2,1fr); gap:20px; }
  #mega-overlay { display:none; }
  /* モバイルではビデオオーバーレイを縮小・透過 */
  .page-hero-media { width:65%; opacity:.7; }
  .page-hero-media video,
  .page-hero-media img { opacity:.25; }
  /* モバイル：無料相談ボタン */
  .cf-consult-btns { flex-direction:column; align-items:stretch; }
  .cf-consult-btn { max-width:100%; }
}

/* ── 無料体験・個別相談 黒ボタン（フォームセクション内） ── */
.cf-consult-btns {
  display:flex; gap:16px; justify-content:center;
  margin:0 0 56px; flex-wrap:wrap;
}
.cf-consult-btn {
  display:flex; flex-direction:column; align-items:flex-start;
  gap:6px; padding:28px 36px;
  background:var(--bg-dark); color:#fff;
  border-radius:var(--r); min-width:240px; max-width:320px; flex:1;
  text-decoration:none; position:relative; overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.cf-consult-btn::before {
  content:''; position:absolute; top:0; left:0; width:100%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,200,255,.5),transparent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease);
}
.cf-consult-btn:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(10,22,60,.22); }
.cf-consult-btn:hover::before { transform:scaleX(1); }
.cf-consult-num {
  font-family:var(--font-m); font-size:.5rem; letter-spacing:.35em;
  color:rgba(255,255,255,.3); text-transform:uppercase;
}
.cf-consult-title {
  font-family:var(--font-s); font-size:1.15rem; font-weight:700;
  color:#fff; line-height:1.2;
}
.cf-consult-desc {
  font-family:var(--font-b); font-size:.75rem;
  color:rgba(255,255,255,.52); line-height:1.65; margin-top:2px;
}
.cf-consult-arrow {
  font-size:.8rem; color:rgba(0,200,255,.7); margin-top:8px;
  transition:transform .25s var(--ease);
}
.cf-consult-btn:hover .cf-consult-arrow { transform:translateX(5px); }

/* ── 個人情報同意チェックボックス ── */
.cf-consent-group {
  display:flex; flex-direction:column; gap:14px;
  padding:20px 0 24px;
  border-top:1px solid var(--line);
  margin-bottom:24px;
}
.cf-consent-item {
  display:flex; align-items:flex-start; gap:12px; cursor:pointer;
}
.cf-consent-check {
  width:16px; height:16px; flex-shrink:0; margin-top:3px;
  accent-color:var(--cyan); cursor:pointer;
}
.cf-consent-check.invalid {
  outline:2px solid var(--pink); outline-offset:1px; border-radius:2px;
}
.cf-consent-text {
  font-size:.79rem; color:var(--text); line-height:1.72;
}
.cf-consent-text strong {
  display:block; font-size:.81rem; font-weight:600;
  color:var(--text); margin-bottom:2px;
}
.cf-consent-opt { font-size:.7rem; color:var(--muted); }
@media(max-width:480px) {
  .footer-nav-grid { grid-template-columns:1fr; }
}

/* ── Rebuild refinements: keep Lunar Futurism, improve clarity ── */
.cf-wrap {
  max-width:1120px;
  margin-left:auto;
  margin-right:auto;
}

.plink img { opacity:.68; }
.plink:hover img { opacity:.82; }
.plink-overlay {
  background:linear-gradient(to top,rgba(240,244,255,.86) 0%,rgba(240,244,255,.18) 58%,rgba(240,244,255,.04) 100%);
}

.info-grid,
.pillar-grid,
.teacher-grid,
.record-grid,
.real-program-grid,
.admission-steps,
.mvp-grid,
.day-grid,
.calendar-grid,
.worry-grid {
  display:grid;
  gap:18px;
  margin-top:56px;
}
.info-grid { grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); }
.pillar-grid { grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); }
.teacher-grid { grid-template-columns:repeat(2,1fr); }
.record-grid { grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); }
.real-program-grid { grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.admission-steps { grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); }
.mvp-grid,
.worry-grid { grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); }
.day-grid { grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); }
.calendar-grid { grid-template-columns:repeat(3,1fr); }

.info-card,
.pillar-card,
.teacher-card,
.record-card,
.real-program-card,
.admission-step,
.mvp-card,
.day-card,
.calendar-card,
.worry-card,
.support-note {
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:26px;
}
.info-label,
.step-num,
.teacher-role,
.record-label,
.mvp-label,
.day-time,
.calendar-month,
.worry-label {
  font-family:var(--font-m);
  font-size:.58rem;
  letter-spacing:.22em;
  color:var(--accent);
  text-transform:uppercase;
}
.info-value,
.pillar-card h3,
.teacher-card h3,
.record-card h3,
.real-program-card h3,
.admission-step h3,
.mvp-card h3,
.day-card h3,
.calendar-card h3,
.worry-card h3 {
  font-family:var(--font-s);
  font-size:1.05rem;
  color:var(--text);
  margin-top:10px;
  margin-bottom:8px;
}
.info-card p,
.pillar-card p,
.teacher-card p,
.record-card p,
.real-program-card p,
.admission-step p,
.mvp-card p,
.day-card p,
.calendar-card p,
.worry-card p,
.support-note p {
  font-size:.82rem;
  color:var(--muted);
  line-height:1.85;
}

.tool-body h4,
.event-card h4,
.club-card h4,
.c-card h3,
.req-item h4,
.faq-q-text,
.contact-card h3,
.cc-form h3,
.cc-section-label {
  text-wrap:balance;
  overflow-wrap:anywhere;
}

.tool-body p,
.event-card p,
.club-card p,
.c-card p,
.req-item p,
.faq-a,
.contact-card p,
.cc-help,
.cc-consent-text,
.cf-consent-text,
.cf-consult-desc,
.mega-desc,
.nav-dd-content span,
.footer-brand-desc {
  text-wrap:pretty;
  overflow-wrap:anywhere;
}
.compact-list {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:16px;
}
.compact-list span {
  border:1px solid var(--line);
  border-radius:100px;
  padding:5px 12px;
  font-size:.72rem;
  color:var(--muted);
  background:var(--bg-2);
}
.floating-cta {
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:950;
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  width:156px;
}
.floating-cta a {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:44px;
  padding:0 14px;
  border:1px solid var(--line-lg);
  border-radius:var(--r);
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(16px);
  color:var(--text);
  font-size:.78rem;
  font-weight:700;
  text-decoration:none;
  box-shadow:0 10px 28px rgba(10,22,60,.08);
}
.floating-cta a:first-child {
  background:#1A90CC;
  border-color:#1A90CC;
  color:#fff;
}
.floating-cta a:hover {
  transform:translateY(-2px);
  border-color:var(--accent);
}
.entry-strip,
.promise-grid {
  display:grid;
  gap:18px;
  margin-top:56px;
}
.entry-strip { grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.entry-card,
.promise-card {
  background:linear-gradient(180deg,var(--bg),var(--bg-2));
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:28px;
  box-shadow:0 18px 48px rgba(10,22,60,.05);
}
.entry-card {
  display:flex;
  flex-direction:column;
  min-height:220px;
  background:linear-gradient(180deg,var(--bg),var(--bg-2));
}
.entry-card.media-entry {
  padding:0;
  overflow:hidden;
}
.entry-card.media-entry img {
  width:100%;
  height:170px;
  object-fit:cover;
  background:var(--bg-3);
}
.entry-body {
  display:flex;
  flex-direction:column;
  flex:1;
  padding:24px;
}
.entry-label,
.promise-label {
  font-family:var(--font-m);
  font-size:.58rem;
  letter-spacing:.24em;
  color:var(--accent);
  text-transform:uppercase;
}
.entry-card h3,
.promise-card h3 {
  font-family:var(--font-s);
  font-size:1.08rem;
  color:var(--text);
  margin:12px 0 10px;
}
.entry-card p,
.promise-card p {
  font-size:.83rem;
  color:var(--muted);
  line-height:1.85;
}
.entry-card a {
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  align-self:flex-start;
  gap:8px;
  color:var(--text);
  font-size:.78rem;
  font-weight:700;
}
.campus-preview {
  position:relative;
  min-height:620px;
  display:grid;
  align-items:end;
  overflow:hidden;
  background:var(--bg-2);
}
.campus-preview-img {
  position:absolute;
  inset:0;
}
.campus-preview-img img {
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.62;
  transform:scale(1.03);
}
.campus-preview::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(255,255,255,.94),rgba(255,255,255,.64) 52%,rgba(255,255,255,.18));
}
.campus-preview-inner {
  position:relative;
  z-index:1;
  max-width:var(--max-w);
  width:100%;
  margin:0 auto;
  padding:120px 48px;
}
.campus-tool-row {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
  gap:12px;
  margin-top:36px;
  max-width:960px;
}
.campus-tool-row article {
  padding:18px;
  border:1px solid var(--line);
  border-radius:var(--r);
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(12px);
}
.campus-tool-row b {
  display:block;
  color:var(--text);
  font-family:var(--font-d);
  font-size:1rem;
  margin-bottom:6px;
}
.campus-tool-row span {
  color:var(--muted);
  font-size:.76rem;
  line-height:1.65;
}
.promise-grid { grid-template-columns:minmax(280px,1.1fr) repeat(2,minmax(230px,1fr)); }
.promise-card.featured {
  background:linear-gradient(135deg,var(--accent-tint),var(--bg));
  border-color:rgba(0,200,255,.2);
  color:var(--text);
}
.promise-card.featured h3,
.promise-card.featured .promise-label { color:var(--accent); }
.promise-card.featured p { color:var(--muted); }
.premium-index {
  display:grid;
  place-items:center;
  width:48px;
  height:48px;
  margin-bottom:18px;
  border:1px solid rgba(10,22,60,.13);
  border-radius:50%;
  font-family:var(--font-d);
  font-size:.76rem;
  font-weight:900;
  letter-spacing:.08em;
  color:var(--accent);
  background:rgba(255,255,255,.72);
}
.image-card-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:18px;
  margin-top:56px;
}
.image-card {
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--r);
  background:var(--bg);
  box-shadow:0 18px 48px rgba(10,22,60,.055);
}
.image-card img {
  width:100%;
  height:210px;
  object-fit:cover;
  background:var(--bg-3);
}
.image-card-body { padding:24px; }
.image-card-label {
  font-family:var(--font-m);
  font-size:.56rem;
  letter-spacing:.22em;
  color:var(--accent);
  text-transform:uppercase;
}
.image-card h3 {
  font-family:var(--font-s);
  font-size:1.08rem;
  color:var(--text);
  margin:10px 0 8px;
}
.image-card p {
  font-size:.82rem;
  color:var(--muted);
  line-height:1.85;
}
.support-note {
  margin-top:56px;
  border-color:rgba(0,200,255,.24);
  background:linear-gradient(135deg,var(--accent-tint),var(--bg));
}
.mvp-card {
  min-height:210px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.mvp-card h3 {
  font-family:var(--font-d);
  font-size:1.2rem;
  letter-spacing:.08em;
}
.day-card,
.calendar-card,
.worry-card {
  background:linear-gradient(180deg,var(--bg),var(--bg-2));
}
.day-time,
.calendar-month {
  display:inline-flex;
  margin-bottom:10px;
}
.media-feature {
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);
  gap:24px;
  align-items:stretch;
  margin-top:56px;
}
.media-embed,
.media-stills {
  border:1px solid var(--line);
  border-radius:var(--r);
  overflow:hidden;
  background:var(--bg-2);
}
.media-embed {
  min-height:420px;
  display:flex;
}
.media-embed iframe,
.media-embed video {
  width:100%;
  height:100%;
  min-height:420px;
  border:0;
  display:block;
}
.media-embed video {
  object-fit:cover;
  background:var(--bg-3);
}
.media-stills {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2px;
}
.media-stills img {
  width:100%;
  height:100%;
  min-height:180px;
  object-fit:cover;
}
.media-stills img:first-child { grid-column:1/-1; }
.news-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:20px;
  margin-top:56px;
}
.news-card {
  border:1px solid var(--line);
  border-radius:var(--r);
  overflow:hidden;
  background:var(--bg);
}
.news-card img {
  width:100%;
  height:190px;
  object-fit:cover;
  background:var(--bg-3);
}
.news-body { padding:24px; }
.news-date {
  font-family:var(--font-m);
  font-size:.55rem;
  letter-spacing:.2em;
  color:var(--accent);
  text-transform:uppercase;
}
.news-body h3 {
  font-family:var(--font-s);
  font-size:1.05rem;
  color:var(--text);
  margin:10px 0 8px;
}
.news-body p {
  font-size:.82rem;
  color:var(--muted);
  line-height:1.8;
  margin-bottom:16px;
}
.news-body a {
  font-size:.78rem;
  color:var(--text);
  font-weight:700;
}
.course-visual {
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  border-radius:var(--r);
  margin-bottom:22px;
  background:var(--bg-3);
}
.real-program-card img {
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  border-radius:var(--r);
  margin-bottom:18px;
}

@media(max-width:768px) {
  .page-hero {
    height:82vh;
    min-height:520px;
    align-items:center;
    padding-bottom:0;
  }
  .page-hero-h1 {
    font-size:clamp(2.55rem,13vw,4rem);
  }
  .hero-eyebrow {
    letter-spacing:.24em;
    line-height:1.8;
  }
  .section-lead br,
  .page-hero-sub br {
    display:none;
  }
  .info-grid,
  .pillar-grid,
  .teacher-grid,
  .record-grid,
  .real-program-grid,
  .admission-steps,
  .mvp-grid,
  .day-grid,
  .calendar-grid,
  .worry-grid {
    grid-template-columns:1fr;
    gap:14px;
    margin-top:36px;
  }
  .info-card,
  .pillar-card,
  .teacher-card,
  .record-card,
  .real-program-card,
  .admission-step,
  .mvp-card,
  .day-card,
  .calendar-card,
  .worry-card,
  .support-note {
    padding:22px;
  }
  .media-feature,
  .news-grid,
  .entry-strip,
  .promise-grid,
  .image-card-grid,
  .campus-tool-row {
    grid-template-columns:1fr;
  }
  .entry-card.media-entry img {
    height:150px;
  }
  .campus-preview {
    min-height:auto;
  }
  .campus-preview-inner {
    padding:84px 20px;
  }
  .media-embed,
  .media-embed iframe,
  .media-embed video {
    min-height:220px;
    aspect-ratio:16/9;
  }
  .media-stills img {
    min-height:130px;
  }
  .floating-cta {
    left:0;
    right:0;
    bottom:0;
    width:auto;
    grid-template-columns:repeat(3,1fr);
    gap:0;
    border-top:1px solid var(--line);
    background:rgba(255,255,255,.96);
    backdrop-filter:blur(16px);
  }
  .floating-cta a {
    min-height:52px;
    border-radius:0;
    border:0;
    border-right:1px solid var(--line);
    box-shadow:none;
    justify-content:center;
    padding:0 8px;
    font-size:.72rem;
  }
  .floating-cta a span { display:none; }
  body { padding-bottom:52px; }
}

