:root {
  --ink: #101828;
  --ink-soft: #344054;
  --muted: #667085;
  --blue: #0000af;
  --blue-2: #257bfd;
  --sky: #69adff;
  --pale: #eef6ff;
  --pale-2: #f7fbff;
  --panel: #132238;
  --panel-2: #0b1524;
  --line: #d9e7f5;
  --orange: #f28c28;
  --orange-dark: #d96f00;
  --yellow: #fff4d6;
  --green: #9bd86f;
  --shadow: 0 24px 64px rgba(16, 34, 56, .14);
  --font-jp: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'Yu Gothic UI', 'Meiryo', sans-serif;
  --font-en: 'Sora', 'Noto Sans JP', sans-serif;
  font-family: var(--font-jp);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 96px; }
@media (max-width: 720px) { html { scroll-padding-top: 72px; } }
:target { scroll-margin-top: 96px; }
[id] { scroll-margin-top: 96px; }
@media (max-width: 720px) { [id] { scroll-margin-top: 72px; } }
body { margin: 0; color: var(--ink); background: #fbfdff; font-family: var(--font-jp); font-weight: 400; line-height: 1.85; letter-spacing: .01em; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
a { color: inherit; }
img { max-width: 100%; }

.skip-link { position: absolute; top: -100px; left: 12px; z-index: 100; padding: 10px 16px; background: var(--blue); color: #fff; font-weight: 800; text-decoration: none; border-radius: 0 0 8px 8px; transition: top .15s ease; }
.skip-link:focus { top: 0; outline: 3px solid #ffbf47; outline-offset: 2px; }

a:focus-visible,
button:focus-visible,
.button:focus-visible,
.nav-toggle:focus-visible,
.header-nav a:focus-visible,
.header-cta:focus-visible { outline: 3px solid #ffbf47; outline-offset: 2px; border-radius: 6px; }
.container { width: min(1160px, calc(100% - 40px)); margin-inline: auto; }
.section { padding: 96px 0; }
.compare-section, .final-cta { padding: 120px 0; }
.access-section, .guarantees-section { padding: 72px 0; }
.center { text-align: center; margin-inline: auto; }
.eyebrow { margin: 0 0 14px; color: var(--blue-2); font-family: var(--font-jp); font-size: .82rem; font-weight: 800; letter-spacing: .12em; }
.hero .eyebrow { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 22px; padding: 6px 14px; border-radius: 999px; background: rgba(37, 123, 253, .08); border: 1px solid rgba(37, 123, 253, .22); color: var(--blue); font-size: .85rem; font-weight: 700; letter-spacing: .06em; }
.hero .eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--orange); box-shadow: 0 0 0 3px rgba(242, 140, 40, .18); }
.marker { background: linear-gradient(transparent 62%, rgba(255, 224, 102, .65) 62%, rgba(255, 224, 102, .65) 92%, transparent 92%); color: inherit; font-weight: 900; padding: 0 2px; }
.marker--accent { background: linear-gradient(transparent 62%, rgba(242, 140, 40, .35) 62%, rgba(242, 140, 40, .35) 92%, transparent 92%); color: var(--blue-deep, #0000AF); }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { font-family: var(--font-jp); font-weight: 900; letter-spacing: .02em; font-feature-settings: 'palt' 1; line-break: strict; word-break: auto-phrase; overflow-wrap: break-word; text-wrap: balance; }
h1 { margin-bottom: 24px; font-size: clamp(2.3rem, 4.8vw, 4.4rem); line-height: 1.22; }
h2 { margin-bottom: 20px; font-size: clamp(1.78rem, 3.2vw, 2.85rem); line-height: 1.38; }
h3 { margin-bottom: 12px; font-size: 1.2rem; line-height: 1.55; }
p { color: var(--ink-soft); line-height: 1.85; line-break: strict; word-break: auto-phrase; overflow-wrap: break-word; }
.section-heading > p, .lead { text-wrap: pretty; }
.nowrap { white-space: nowrap; }
strong, b { font-weight: 900; }
.num { font-family: var(--font-en); font-variant-numeric: tabular-nums; letter-spacing: -.01em; }

.site-header { position: sticky; top: 0; z-index: 30; display: flex; align-items: center; gap: 28px; padding: 14px 32px; background: rgba(251, 253, 255, .9); border-bottom: 1px solid rgba(217, 231, 245, .9); backdrop-filter: blur(14px); }
.brand { display: inline-flex; align-items: center; gap: 14px; text-decoration: none; color: inherit; }
.brand img { display: block; width: 132px; height: auto; }
.brand-title { display: inline-flex; flex-direction: column; gap: 4px; padding-left: 14px; border-left: 1px solid rgba(37, 123, 253, .22); line-height: 1.2; }
.brand-title-kicker { display: inline-flex; align-items: center; align-self: flex-start; padding: 2px 8px; border-radius: 4px; background: var(--blue); color: #fff; font-size: .7rem; font-weight: 700; letter-spacing: .04em; font-feature-settings: 'palt' 1; }
.brand-title-main { font-family: var(--font-jp); font-weight: 800; font-size: 1.08rem; color: var(--blue); letter-spacing: .01em; font-feature-settings: 'palt' 1; }
.brand-title-cohort { display: inline-flex; align-items: center; align-self: flex-start; margin-top: 2px; padding: 1px 6px; border-radius: 4px; background: rgba(242, 140, 40, .14); color: var(--orange-dark); font-size: .72rem; font-weight: 800; letter-spacing: .02em; font-feature-settings: 'palt' 1; }
.brand-title-cohort--next { background: rgba(52, 64, 84, .08); color: var(--ink-soft); }
.header-nav { display: flex; gap: 22px; margin-left: auto; font-size: .9rem; color: var(--ink-soft); }
.header-nav a, .header-cta { text-decoration: none; }
.header-nav a:hover { color: var(--blue-2); }
.nav-mobile-only { display: none; }
.header-cta { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; padding: 10px 18px; border-radius: 10px; background: var(--orange); color: #fff; font-weight: 800; }
.header-drawer { display: contents; }
.nav-toggle { display: none; margin-left: auto; width: 44px; height: 44px; padding: 0; border: 1px solid var(--line); border-radius: 10px; background: #fff; color: var(--ink); cursor: pointer; align-items: center; justify-content: center; }
.nav-toggle-bars, .nav-toggle-bars::before, .nav-toggle-bars::after { display: block; width: 20px; height: 2px; background: currentColor; border-radius: 2px; transition: transform .2s ease, opacity .2s ease, top .2s ease; }
.nav-toggle-bars { position: relative; }
.nav-toggle-bars::before, .nav-toggle-bars::after { content: ""; position: absolute; left: 0; }
.nav-toggle-bars::before { top: -7px; }
.nav-toggle-bars::after { top: 7px; }
.nav-toggle[aria-expanded="true"] .nav-toggle-bars { background: transparent; }
.nav-toggle[aria-expanded="true"] .nav-toggle-bars::before { top: 0; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle-bars::after { top: 0; transform: rotate(-45deg); }

.hero { position: relative; overflow: hidden; padding: 48px 0 92px; background: radial-gradient(circle at 82% 18%, rgba(105, 173, 255, .48), transparent 27%), linear-gradient(135deg, #f9fcff 0%, #eef6ff 48%, #fff 100%); }
.hero-bg-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(37, 123, 253, .12) 1px, transparent 1px), linear-gradient(90deg, rgba(37, 123, 253, .12) 1px, transparent 1px); background-size: 42px 42px; mask-image: linear-gradient(90deg, #000 0%, rgba(0,0,0,.76) 54%, transparent 92%); }
.hero-layout { position: relative; display: grid; grid-template-columns: 1.35fr .65fr; gap: 32px 48px; align-items: center; }
.hero-copy { min-width: 0; }
.hero-visual { position: relative; min-width: 0; }
.lead { max-width: 700px; font-size: 1.12rem; color: var(--ink-soft); line-height: 1.95; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 30px 0 22px; }
.hero-actions.center { justify-content: center; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 54px; padding: 13px 23px; border-radius: 11px; text-decoration: none; font-family: var(--font-jp); font-weight: 800; letter-spacing: .02em; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.button--xl { min-height: 64px; padding: 18px 36px; font-size: 1.08rem; border-radius: 14px; }
.button:hover { transform: translateY(-1px); }
.button.primary { background: var(--orange); color: #fff; box-shadow: 0 14px 30px rgba(242, 140, 40, .28); }
.button.primary:hover { background: var(--orange-dark); }
.button.secondary { background: #fff; color: var(--blue); border: 1px solid var(--blue-2); }
.assurance-row { display: flex; flex-wrap: wrap; gap: 10px; }
.assurance-row span { display: inline-flex; align-items: center; min-height: 36px; padding: 7px 14px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255, 255, 255, .88); color: var(--blue); font-size: .86rem; font-weight: 700; letter-spacing: .02em; font-feature-settings: 'palt' 1; font-variant-numeric: tabular-nums; }

.guarantees-section { background: linear-gradient(180deg, #fff 0%, #f5faff 100%); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.guarantees-section .section-heading { margin-bottom: 30px; }
.guarantees-section .section-heading h2 { font-size: clamp(1.5rem, 2.5vw, 2.1rem); }
.guarantees-section .hero-note { text-align: center; margin-top: 16px; }
.hero-highlights { list-style: none; margin: 0 auto; max-width: 1080px; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; counter-reset: guarantee; }
.highlight-card { position: relative; display: flex; flex-direction: column; padding: 36px 22px 22px; border: 1px solid var(--blue-3, #BBD2FF); border-radius: 18px; background: linear-gradient(180deg, #fff 0%, #f3f8ff 100%); box-shadow: 0 14px 32px rgba(37, 123, 253, .10); counter-increment: guarantee; overflow: hidden; transition: transform .25s ease, box-shadow .25s ease; }
.highlight-card:hover { transform: translateY(-4px); box-shadow: 0 22px 44px rgba(37, 123, 253, .18); }
.highlight-card::before { content: counter(guarantee, decimal-leading-zero); position: absolute; top: 12px; right: 16px; z-index: 2; font-family: var(--font-en); font-weight: 800; font-size: 3.4rem; line-height: 1; color: rgba(0, 0, 175, .08); letter-spacing: -.04em; pointer-events: none; }
.highlight-card > * { position: relative; z-index: 1; }
.highlight-tag { align-self: flex-start; max-width: calc(100% - 64px); margin: 0 0 10px; padding: 4px 12px; border-radius: 999px; background: var(--blue); color: #fff; font-size: .72rem; font-weight: 800; letter-spacing: .04em; }
.highlight-head { display: block; margin: 4px 0 10px; color: var(--blue-deep, #0000AF); font-size: 1.32rem; font-weight: 900; letter-spacing: .01em; font-feature-settings: 'palt' 1; }
.highlight-desc { margin: 0; color: var(--ink-soft); font-size: .86rem; line-height: 1.75; }
.highlight-foot { margin: 16px 0 0; padding-top: 14px; border-top: 1px solid rgba(37, 123, 253, .16); color: var(--muted); font-size: .74rem; line-height: 1.65; }
.highlight-card--accent { background: linear-gradient(135deg, #0000AF 0%, #257BFD 100%); border-color: transparent; color: #fff; box-shadow: 0 18px 40px rgba(0, 0, 175, .30); }
.highlight-card--accent::before { color: rgba(255, 255, 255, .18); }
.highlight-card--accent .highlight-tag { background: var(--orange); color: #fff; }
.highlight-card--accent .highlight-head { color: #fff; }
.highlight-card--accent .highlight-desc { color: rgba(255,255,255,.92); }
.hero-note { margin: 8px 0 0; color: var(--muted); font-size: .8rem; line-height: 1.7; }

.system-section { background: linear-gradient(180deg, #f5f9ff 0%, #ffffff 100%); }
.system-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-bottom: 32px; }
.system-card { padding: 26px; border: 1px solid var(--line); border-radius: 18px; background: #fff; box-shadow: 0 12px 30px rgba(37, 123, 253, .08); }
.system-card h3 { margin: 8px 0 12px; font-size: 1.25rem; font-weight: 900; line-height: 1.55; color: var(--blue-deep, #0000AF); letter-spacing: .01em; font-feature-settings: 'palt' 1; }
.system-card p { margin: 0; color: var(--ink-soft); font-size: .92rem; line-height: 1.85; }
.system-links { padding: 22px 26px; border: 1px dashed var(--blue-2); border-radius: 16px; background: #fff; }
.system-links > p { margin: 0 0 12px; color: var(--ink); font-weight: 700; font-size: .95rem; }
.system-links ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.system-links a { display: inline-flex; align-items: center; gap: 6px; color: var(--blue); font-weight: 700; text-decoration: none; word-break: break-all; }
.system-links a:hover { text-decoration: underline; }
.system-links a span { color: var(--blue-2); font-size: .9em; }
.system-note { margin: 14px 0 0; color: var(--muted); font-size: .82rem; line-height: 1.7; }

.hero-visual { position: relative; min-height: 320px; }
.workspace-card { overflow: hidden; border: 1px solid rgba(255,255,255,.1); border-radius: 22px; background: var(--panel); color: #eaf6ff; box-shadow: 0 32px 80px rgba(16, 34, 56, .28); }
.window-bar { display: flex; align-items: center; gap: 8px; padding: 14px 16px; background: var(--panel-2); color: #9fb7d1; }
.window-bar i { width: 11px; height: 11px; border-radius: 50%; background: var(--orange); }
.window-bar i:nth-child(2) { background: #ffd166; }
.window-bar i:nth-child(3) { background: var(--green); }
.window-bar span { margin-left: 8px; font-size: .82rem; }
pre { margin: 0; padding: 32px; overflow: hidden; font-family: 'JetBrains Mono', 'Sora', 'Consolas', monospace; font-size: .92rem; line-height: 1.7; letter-spacing: 0; min-height: 232px; }
pre code { display: block; white-space: pre; color: #eaf6ff; }
.code-caret { display: inline-block; width: 9px; height: 1.05em; margin-left: 2px; vertical-align: text-bottom; background: var(--orange); animation: caret-blink 1s steps(2) infinite; }
@keyframes caret-blink { 50% { opacity: 0; } }
.workspace-footer { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(255,255,255,.12); }
.workspace-footer span { padding: 15px 12px; background: #172b46; text-align: center; color: #dff0ff; font-size: .88rem; font-weight: 700; }
.floating-metric { position: absolute; padding: 16px 18px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.94); box-shadow: var(--shadow); }
.floating-metric strong, .floating-metric span { display: block; }
.floating-metric strong { color: var(--blue); font-family: var(--font-en); font-size: 1.55rem; line-height: 1.2; font-variant-numeric: tabular-nums; letter-spacing: -.01em; }
.floating-metric span { color: var(--muted); font-size: .82rem; letter-spacing: .04em; }
.metric-one { right: -8px; top: 36px; }
.metric-two { left: -24px; bottom: 34px; }

.hero-stats { list-style: none; margin: 26px 0 30px; padding: 0; display: flex; flex-wrap: wrap; gap: 36px 56px; align-items: flex-start; border: 0; background: transparent; }
.hero-stats li { position: relative; display: flex; flex-direction: column; gap: 6px; }
.hero-stats li + li { padding-left: 56px; border-left: 0; }
.hero-stats li + li::before { content: ""; position: absolute; left: 22px; top: 12%; bottom: 18%; width: 1px; background: linear-gradient(180deg, transparent, rgba(37, 123, 253, .35), transparent); }
.hero-stats strong { display: flex; align-items: baseline; gap: 6px; color: var(--blue); font-family: var(--font-en); font-size: clamp(3.4rem, 6.2vw, 5.4rem); line-height: 1; font-variant-numeric: tabular-nums; letter-spacing: -.04em; font-weight: 800; }
.hero-stat-num { background: linear-gradient(135deg, #0000af 0%, #257bfd 60%, #69adff 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.hero-stat-unit { font-family: var(--font-jp); font-size: 1.05rem; font-weight: 800; color: var(--ink); letter-spacing: .02em; -webkit-text-fill-color: currentColor; background: none; }
.hero-stat-desc { color: var(--ink-soft); font-size: .82rem; letter-spacing: .04em; font-weight: 700; }
.hero-stat-annot { display: block; margin-top: 4px; font-size: .72rem; font-weight: 500; letter-spacing: .02em; color: var(--ink-soft); }
.compare-annot { display: block; margin-top: 3px; font-size: .72rem; font-weight: 500; letter-spacing: .02em; opacity: .85; }

.section-heading { max-width: 820px; margin-bottom: 38px; }
.section-heading p { font-size: 1rem; }
.value-section { background: #fff; }
.value-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.value-card { grid-column: span 2; min-height: 248px; padding: 26px; border: 1px solid var(--line); border-radius: 22px; background: #fff; box-shadow: 0 14px 36px rgba(37, 123, 253, .08); }
.value-card:nth-child(4), .value-card:nth-child(5) { grid-column: span 3; }
.primary-card { background: linear-gradient(135deg, var(--blue), var(--blue-2)); color: #fff; }
.primary-card p, .primary-card .card-kicker { color: #e6f1ff; }
.accent-card { background: linear-gradient(135deg, #fff8ee, #fff); border-color: #ffd9ae; }
.card-kicker { display: inline-flex; margin-bottom: 18px; color: var(--blue-2); font-family: var(--font-jp); font-size: .82rem; font-weight: 800; letter-spacing: .08em; }

.curriculum-section { background: #10294d; color: #fff; }
.curriculum-section p { color: #d7e8fb; }
.curriculum-layout { display: block; }
.curriculum-section .sticky-heading { position: static; max-width: 760px; margin: 0 auto 56px; text-align: center; }
.curriculum-section .sticky-heading .skill-tags { justify-content: center; }
.skill-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.skill-tags span { padding: 8px 12px; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; background: rgba(255,255,255,.08); color: #eaf6ff; font-family: var(--font-en); font-size: .82rem; font-weight: 700; letter-spacing: .04em; }
.roadmap { position: relative; display: grid; gap: 22px; margin: 0 auto; padding: 0 0 0 88px; max-width: 880px; list-style: none; }
.roadmap::before { content: ""; position: absolute; left: 36px; top: 24px; bottom: 24px; width: 2px; background: linear-gradient(180deg, rgba(105,173,255,.65), rgba(105,173,255,.08)); border-radius: 2px; }
.roadmap > li { position: relative; }
.roadmap > li::before { content: ""; position: absolute; left: -59px; top: 36px; width: 18px; height: 18px; border-radius: 50%; background: var(--sky); box-shadow: 0 0 0 6px rgba(105,173,255,.16), 0 0 0 12px rgba(105,173,255,.06); }
.roadmap article { position: relative; display: grid; grid-template-columns: 1fr; gap: 6px; padding: 30px 32px 28px; border: 1px solid rgba(255,255,255,.16); border-radius: 20px; background: linear-gradient(180deg, rgba(255,255,255,.10) 0%, rgba(255,255,255,.05) 100%); overflow: hidden; }
.roadmap b { position: absolute; top: 14px; right: 24px; color: rgba(105,173,255,.22); font-family: var(--font-en); font-size: clamp(3.6rem, 6vw, 5.6rem); line-height: .9; font-variant-numeric: tabular-nums; letter-spacing: -.04em; font-weight: 800; pointer-events: none; user-select: none; }
.roadmap span { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 8px; padding: 4px 12px; border-radius: 999px; background: rgba(105,173,255,.18); color: #d6eaff; font-family: var(--font-jp); font-size: .78rem; font-weight: 800; letter-spacing: .04em; align-self: flex-start; width: fit-content; }
.roadmap span::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--orange); }
.roadmap h3 { font-size: 1.32rem; line-height: 1.5; padding-right: 110px; }
.roadmap h3, .roadmap p { margin-bottom: 0; }
.roadmap p { padding-right: 110px; }
.roadmap-skills { display: flex; flex-wrap: wrap; gap: 6px; margin: 14px 0 0; padding: 0; list-style: none; }
.roadmap-skills li { padding: 4px 12px; border-radius: 999px; background: rgba(105,173,255,.16); color: #cfe6ff; font-size: .78rem; font-weight: 700; letter-spacing: .02em; }
.roadmap-note { max-width: 880px; margin: 22px auto 0; padding-left: 88px; color: rgba(214,234,255,.72); font-size: .82rem; line-height: 1.7; }

.electives { max-width: 1040px; margin: 56px auto 0; padding: 36px 36px 32px; border: 1px solid rgba(105,173,255,.28); border-radius: 22px; background: linear-gradient(180deg, rgba(105,173,255,.14) 0%, rgba(105,173,255,.04) 100%); position: relative; overflow: hidden; }
.electives::before { content: ""; position: absolute; inset: 0; background: radial-gradient(520px 260px at 100% -10%, rgba(105,173,255,.20), transparent 70%); pointer-events: none; }
.electives-head { position: relative; display: grid; grid-template-columns: 1fr 1fr; column-gap: 36px; row-gap: 6px; align-items: center; margin: 0 0 24px; }
.electives-badge { grid-column: 1; grid-row: 1; display: inline-flex; align-items: center; gap: 7px; margin-bottom: 0; padding: 5px 14px; border-radius: 999px; background: var(--orange); color: #fff; font-family: var(--font-jp); font-size: .76rem; font-weight: 800; letter-spacing: .04em; width: fit-content; }
.electives-badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: #fff; }
.electives-head h3 { grid-column: 1; grid-row: 2; font-size: clamp(1.3rem, 2.1vw, 1.7rem); line-height: 1.45; margin-bottom: 0; color: #fff; }
.electives-head p { grid-column: 2; grid-row: 1 / 3; margin: 0; color: #d7e8fb; font-size: .88rem; line-height: 1.85; }
.electives-grid { position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 0; padding: 0; list-style: none; counter-reset: elective; }
.elective-card { position: relative; display: flex; flex-direction: column; gap: 9px; padding: 22px 20px 20px; border: 1px solid rgba(255,255,255,.16); border-radius: 16px; background: linear-gradient(180deg, rgba(255,255,255,.11) 0%, rgba(255,255,255,.04) 100%); counter-increment: elective; overflow: hidden; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.elective-card::before { content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 3px; background: linear-gradient(90deg, var(--sky), var(--orange)); transform: scaleX(0); transform-origin: left; transition: transform .3s ease; }
.elective-card::after { content: counter(elective, decimal-leading-zero); position: absolute; top: 12px; right: 16px; font-family: var(--font-en); font-weight: 800; font-size: 2.1rem; line-height: 1; color: rgba(255,255,255,.10); letter-spacing: -.04em; pointer-events: none; }
.elective-card:hover { transform: translateY(-5px); border-color: rgba(105,173,255,.5); box-shadow: 0 20px 40px rgba(0,0,30,.26); }
.elective-card:hover::before { transform: scaleX(1); }
.elective-label { color: var(--sky); font-family: var(--font-jp); font-size: .74rem; font-weight: 800; line-height: 1.55; letter-spacing: .02em; padding-right: 34px; }
.elective-card h4 { font-size: 1.1rem; line-height: 1.4; color: #fff; }
.elective-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: auto; padding-top: 6px; }
.elective-tags span { padding: 5px 11px; border-radius: 999px; border: 1px solid rgba(105,173,255,.3); background: rgba(105,173,255,.16); color: #d6eaff; font-size: .75rem; font-weight: 700; }
.electives-note { max-width: 1040px; margin: 14px auto 0; color: rgba(214,234,255,.72); font-size: .8rem; line-height: 1.7; text-align: center; }

.demo-section { background: var(--pale-2); }
.demo-layout { display: grid; grid-template-columns: 1.05fr .95fr; gap: 54px; align-items: center; }
.product-mock { display: flex; flex-direction: column; min-height: 380px; overflow: hidden; border: 1px solid var(--line); border-radius: 18px; background: #fff; box-shadow: var(--shadow); font-family: var(--font-jp); }
.mock-browser-bar { display: flex; align-items: center; gap: 14px; padding: 10px 16px; background: #eef2f7; border-bottom: 1px solid var(--line); }
.mock-browser-dots { display: inline-flex; gap: 6px; }
.mock-browser-dots i { width: 11px; height: 11px; border-radius: 50%; background: #d0d7e2; }
.mock-browser-dots i:nth-child(1) { background: #ff6058; }
.mock-browser-dots i:nth-child(2) { background: #ffbd2e; }
.mock-browser-dots i:nth-child(3) { background: #28c93f; }
.mock-browser-url { flex: 1; display: inline-flex; align-items: center; gap: 6px; padding: 5px 12px; border-radius: 999px; background: #fff; border: 1px solid var(--line); color: #5a6677; font-size: .72rem; font-family: var(--font-en); }
.mock-browser-url i { font-style: normal; font-size: .68rem; color: #28a745; }
.mock-app { display: grid; grid-template-columns: 168px 1fr; flex: 1; }
.mock-app-sidebar { display: flex; flex-direction: column; padding: 18px 14px; background: var(--panel); color: #fff; }
.mock-app-logo { display: flex; align-items: center; gap: 8px; padding: 0 6px 16px; font-weight: 800; font-size: .9rem; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 14px; }
.mock-app-logo span { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border-radius: 7px; background: var(--orange); color: #fff; font-family: var(--font-en); font-size: .7rem; font-weight: 800; }
.mock-app-nav { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.mock-app-nav a { display: inline-flex; align-items: center; gap: 8px; padding: 7px 10px; border-radius: 7px; font-size: .76rem; color: rgba(255,255,255,.72); font-weight: 600; cursor: default; }
.mock-app-nav a.active { background: rgba(255,255,255,.10); color: #fff; }
.mock-app-user { display: flex; align-items: center; gap: 8px; margin-top: 14px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.08); font-size: .72rem; color: rgba(255,255,255,.85); }
.mock-avatar { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border-radius: 50%; background: var(--blue-2); color: #fff; font-size: .72rem; font-weight: 800; }
.mock-app-main { padding: 18px 20px; background: #fbfdff; display: flex; flex-direction: column; gap: 14px; }
.mock-app-topbar { display: flex; align-items: center; justify-content: space-between; }
.mock-app-topbar h4 { margin: 0; font-size: .95rem; font-weight: 800; color: var(--ink); }
.mock-app-btn { display: inline-flex; align-items: center; gap: 5px; padding: 6px 12px; border: none; border-radius: 7px; background: var(--orange); color: #fff; font-size: .72rem; font-weight: 700; font-family: inherit; cursor: default; }
.mock-icon { flex-shrink: 0; display: inline-block; vertical-align: middle; }
.mock-browser-url .mock-icon { color: #28a745; }
.mock-app-nav .mock-icon { opacity: .85; }
.mock-app-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.mock-stat { padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; background: #fff; display: flex; flex-direction: column; gap: 2px; }
.mock-stat span { font-size: .66rem; color: var(--ink-soft); font-weight: 600; }
.mock-stat strong { font-family: var(--font-en); font-size: 1.25rem; color: var(--blue); font-weight: 800; }
.mock-app-table { border: 1px solid var(--line); border-radius: 10px; background: #fff; overflow: hidden; }
.mock-row { display: grid; grid-template-columns: 1.6fr .8fr .9fr; align-items: center; gap: 8px; padding: 9px 12px; font-size: .74rem; color: var(--ink); border-top: 1px solid #eef3fa; }
.mock-row:first-child { border-top: 0; }
.mock-row-head { background: #f3f7fc; color: var(--ink-soft); font-size: .66rem; font-weight: 700; letter-spacing: .04em; }
.mock-badge { display: inline-flex; align-items: center; justify-content: center; padding: 2px 8px; border-radius: 999px; font-size: .66rem; font-weight: 700; width: fit-content; }
.mock-badge-doing { background: rgba(37,123,253,.12); color: var(--blue-2); }
.mock-badge-done { background: rgba(40,201,63,.14); color: #1a8f33; }
.mock-badge-todo { background: #eef0f4; color: #6a7280; }
.check-list { display: grid; gap: 10px; padding: 0; margin: 24px 0 0; list-style: none; }
.check-list li { padding: 12px 14px; border-left: 4px solid var(--blue-2); border-radius: 10px; background: #fff; font-weight: 700; }

.compare-section { background: #fff; }
.scroll-hint { display: none; color: var(--muted); font-size: .88rem; }
.table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: 18px; background: #fff; box-shadow: 0 16px 42px rgba(37, 123, 253, .08); }
table { width: 100%; min-width: 900px; border-collapse: collapse; }
th, td { padding: 18px; text-align: left; border-bottom: 1px solid var(--line); vertical-align: top; }
thead th { background: var(--panel); color: #fff; font-family: var(--font-jp); font-weight: 800; letter-spacing: .04em; font-feature-settings: 'palt' 1; }
tbody th { color: var(--ink); font-weight: 700; }
tbody td { font-variant-numeric: tabular-nums; }
.best { color: var(--blue); font-weight: 900; letter-spacing: .01em; }
.compare-table thead th.col-shk { background: linear-gradient(180deg, var(--blue) 0%, var(--blue-2) 100%); box-shadow: inset 0 -3px 0 var(--orange); }
.compare-table tbody td:nth-child(2) { background: linear-gradient(180deg, rgba(37,123,253,.10) 0%, rgba(37,123,253,.04) 100%); border-left: 1px solid rgba(37,123,253,.18); border-right: 1px solid rgba(37,123,253,.18); }
.compare-table tbody tr:last-child td:nth-child(2) { border-bottom: 1px solid rgba(37,123,253,.18); }
.compare-table tbody td.best::before { content: "✓"; display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; margin-right: 8px; vertical-align: 1px; border-radius: 50%; background: var(--orange); color: #fff; font-size: .72rem; font-weight: 900; line-height: 1; }

.movie-section { background: linear-gradient(135deg, #f8fbff, #eef6ff); }
.movie-layout, .access-layout { display: grid; grid-template-columns: .95fr 1.05fr; gap: 52px; align-items: center; }
.guide-layout { display: block; max-width: 880px; margin: 0 auto; }
.video-placeholder { display: grid; place-items: center; min-height: 340px; padding: 32px; border: 1px solid rgba(255,255,255,.12); border-radius: 24px; background: radial-gradient(circle at 72% 24%, rgba(105,173,255,.35), transparent 30%), var(--panel); color: #fff; text-align: center; box-shadow: var(--shadow); }
.video-placeholder span { color: var(--sky); font-weight: 900; letter-spacing: .12em; }
.video-placeholder strong { display: block; font-size: 2rem; }
.video-placeholder p { color: #d7e8fb; }
.video-placeholder a { color: #fff; font-weight: 900; }
.video-placeholder.has-video { display: block; padding: 0; overflow: hidden; aspect-ratio: 16 / 9; min-height: 0; }
.video-placeholder iframe { width: 100%; height: 100%; border: 0; }

.people-section { background: #fff; }
.people-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.teachers-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; max-width: 1080px; margin: 0 auto; }
.voices-section { background: var(--pale, #f5f9ff); }
.voices-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; max-width: 1080px; margin: 0 auto; }
.teacher-card, .voice-card { min-height: 230px; padding: 24px; border: 1px solid var(--line); border-radius: 22px; background: #fff; box-shadow: 0 14px 34px rgba(37, 123, 253, .07); }
.portrait { display: grid; place-items: center; width: 144px; height: 144px; margin-bottom: 18px; border-radius: 50%; background: linear-gradient(135deg, var(--sky), var(--pale)); color: var(--blue); font-weight: 900; overflow: hidden; }
.portrait img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; transform: scale(1.15); transform-origin: center top; }
.voice-card { background: var(--pale-2); }
.voice-card-head { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.voice-avatar { flex-shrink: 0; width: 96px; height: 96px; border-radius: 50%; background: linear-gradient(135deg, #e6efff, #f7fbff); border: 1px solid var(--line); overflow: hidden; display: flex; align-items: center; justify-content: center; position: relative; }
.voice-avatar::before { content: "人物"; font-size: .68rem; color: var(--blue-2); font-weight: 700; letter-spacing: .06em; }
.voice-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center 28%; display: block; }
.voice-avatar:has(img)::before { content: none; }
.voice-meta { display: flex; flex-direction: column; gap: 4px; }
.voice-tag { display: inline-flex; width: fit-content; padding: 3px 10px; border-radius: 999px; background: rgba(37,123,253,.10); color: var(--blue-2); font-size: .72rem; font-weight: 800; letter-spacing: .02em; }
.voice-name { font-size: .78rem; color: var(--ink-soft); font-weight: 700; }
.voice-card span { display: inline-flex; margin-bottom: 14px; color: var(--blue-2); font-weight: 900; }
.voice-card-head span { margin-bottom: 0; }
.teacher-meta { display: inline-flex; margin-bottom: 12px; color: var(--muted); font-size: .84rem; font-weight: 800; }
.detail-list { display: grid; gap: 8px; margin: 16px 0 0; padding-left: 1.1em; color: var(--ink-soft); font-size: .9rem; }
.teacher-bio { margin: 16px 0 0; padding: 12px 14px; border-top: 1px dashed var(--line); background: var(--pale-2); border-radius: 10px; color: var(--ink-soft); font-size: .85rem; line-height: 1.7; }
.teacher-bio strong { color: var(--ink); font-weight: 800; margin-right: 4px; }
.teachers-note { margin: 24px 0 0; text-align: center; color: var(--muted); font-size: .85rem; }

.teachers-roster { max-width: 1080px; margin: 48px auto 0; }
.teachers-roster-head { text-align: center; margin-bottom: 20px; }
.teachers-roster-head h3 { margin: 0 0 6px; font-size: 1.1rem; color: var(--ink); }
.teachers-roster-head p { margin: 0; color: var(--ink-soft); font-size: .92rem; }
.teachers-roster-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; padding: 0; list-style: none; }
.roster-card { display: flex; gap: 14px; padding: 18px; border: 1px solid var(--line); border-radius: 16px; background: #fff; box-shadow: 0 6px 18px rgba(37,123,253,.05); }
.roster-avatar { flex: 0 0 auto; display: grid; place-items: center; width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg, var(--sky), var(--pale)); color: var(--blue); font-family: 'Sora', sans-serif; font-weight: 800; font-size: 1.25rem; overflow: hidden; }
.roster-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.roster-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.roster-name { font-weight: 800; color: var(--ink); font-size: .98rem; }
.roster-role { color: var(--blue-2); font-weight: 700; font-size: .78rem; letter-spacing: .02em; }
.roster-bio { margin: 8px 0 0; color: var(--ink-soft); font-size: .82rem; line-height: 1.65; }
.voice-card h3 { margin: 14px 0 6px; font-size: 1.02rem; color: var(--ink); line-height: 1.55; }
.voice-card p { margin-bottom: 14px; color: var(--ink-soft); font-size: .92rem; }
.story-quote { position: relative; margin: 4px 0 0; padding: 14px 16px 14px 42px; border-left: 4px solid var(--blue-2); border-radius: 0 12px 12px 0; background: #fff; color: var(--ink); font-weight: 700; font-size: .95rem; line-height: 1.8; box-shadow: 0 6px 18px rgba(37,123,253,.06); }
.story-quote::before { content: "“"; position: absolute; left: 12px; top: -6px; font-family: 'Sora', serif; font-size: 2.6rem; line-height: 1; color: var(--blue-2); font-weight: 800; }

.guide-section { background: var(--pale-2); }
.cohorts-block { margin-bottom: 36px; }
.cohorts-empty { max-width: 720px; margin: 0 auto; padding: 40px 32px; text-align: center; border: 1px dashed var(--blue-2); border-radius: 20px; background: #fff; box-shadow: 0 12px 28px rgba(37, 123, 253, .06); }
.cohorts-empty-tag { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 14px; padding: 5px 14px; border-radius: 999px; background: rgba(242, 140, 40, .12); color: var(--orange-dark); font-size: .76rem; font-weight: 800; letter-spacing: .04em; }
.cohorts-empty-tag::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--orange); }
.cohorts-empty h3 { margin: 0 0 12px; font-size: clamp(1.15rem, 2vw, 1.4rem); color: var(--blue-deep, #0000AF); }
.cohorts-empty p { margin: 0 0 24px; color: var(--ink-soft); font-size: .95rem; line-height: 1.85; }
.cohorts-empty-actions { display: flex; flex-direction: column; align-items: center; gap: 12px; }
.cohorts-empty-actions .button { min-width: 280px; }
.cohorts-empty-note { margin: 22px auto 0 !important; padding-top: 18px; border-top: 1px dashed var(--line); max-width: 560px; color: var(--muted) !important; font-size: .82rem !important; line-height: 1.75 !important; }
.cohorts-empty .cohorts-empty-link { display: inline; color: var(--blue); font-weight: 800; text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 1.5px; text-decoration-skip-ink: none; }
.cohorts-empty .cohorts-empty-link span { padding-left: 2px; }
.cohorts-empty .cohorts-empty-link:hover { color: var(--blue-deep, #0000AF); text-decoration-thickness: 2px; }
.cohorts-head { max-width: 880px; margin: 0 auto 24px; text-align: center; }
.cohorts-head h2 { margin: 6px 0 10px; }
.cohorts-head p { margin: 0; color: var(--ink-soft); }
.cohort-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; padding: 0; margin: 0; list-style: none; max-width: 1080px; margin-left: auto; margin-right: auto; }
.cohort-card { display: flex; flex-direction: column; gap: 16px; padding: 22px 24px; border: 1px solid var(--line); border-radius: 18px; background: #fff; box-shadow: 0 10px 28px rgba(37, 123, 253, .08); }
.cohort-card-head { display: flex; flex-direction: column; gap: 8px; }
.cohort-card-tag { align-self: flex-start; padding: 3px 10px; border-radius: 999px; background: var(--orange); color: #fff; font-size: .72rem; font-weight: 900; letter-spacing: .04em; }
.cohort-card-title { margin: 0; font-size: 1.12rem; color: var(--blue); font-weight: 800; }
.cohort-card-list { display: grid; grid-template-columns: auto 1fr; column-gap: 16px; row-gap: 8px; margin: 0; padding: 14px 0 0; border-top: 1px dashed var(--line); font-size: .92rem; }
.cohort-card-list dt { color: var(--muted); font-weight: 700; white-space: nowrap; }
.cohort-card-list dd { margin: 0; color: var(--ink); font-weight: 700; font-feature-settings: 'palt' 1; }
.cohort-card-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 4px; }
.cohort-card-action { display: inline-flex; align-items: center; justify-content: center; gap: 6px; min-height: 44px; padding: 10px 14px; border-radius: 10px; font-weight: 800; text-decoration: none; font-size: .9rem; letter-spacing: .02em; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.cohort-card-action:hover { transform: translateY(-1px); }
.cohort-card-action--primary { background: var(--orange); color: #fff; box-shadow: 0 8px 18px rgba(242,140,40,.28); }
.cohort-card-action--primary:hover { background: var(--orange-dark); }
.cohort-card-action--secondary { background: #fff; color: var(--blue); border: 1px solid var(--blue-2); }
.cohort-card-action--secondary:hover { background: var(--pale); }
.speech-card { padding: 28px; border-radius: 24px; background: var(--panel-2); color: #fff; box-shadow: var(--shadow); }
.speech-card span { color: var(--sky); font-weight: 900; }
.speech-card p { margin: 14px 0 0; color: #fff; font-size: 1.25rem; font-weight: 800; }
.flow-list { display: grid; gap: 12px; padding: 0; margin: 0; list-style: none; counter-reset: flow; }
.flow-list li { counter-increment: flow; position: relative; padding: 16px 16px 16px 58px; border: 1px solid var(--line); border-radius: 14px; background: #fff; }
.flow-list li::before { content: counter(flow); position: absolute; left: 16px; top: 17px; display: grid; place-items: center; width: 28px; height: 28px; border-radius: 50%; background: var(--blue-2); color: #fff; font-size: .86rem; font-weight: 900; }
.flow-list strong, .flow-list span { display: block; }
.flow-list span { color: var(--muted); }
.checklist-card { display: grid; grid-template-columns: .72fr 1.28fr; gap: 28px; align-items: start; margin-top: 28px; padding: 24px; border: 1px solid var(--line); border-radius: 22px; background: #fff; box-shadow: 0 14px 34px rgba(37, 123, 253, .07); }
.checklist-head { display: flex; flex-direction: column; gap: 6px; }
.checklist-head h3 { margin: 0; }
.check-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin: 0; padding: 0; list-style: none; }
.check-grid li { padding: 13px 14px; border-left: 4px solid var(--blue-2); border-radius: 11px; background: var(--pale-2); color: var(--ink-soft); font-weight: 800; }
.checklist-lead { margin: 12px 0 0; color: var(--ink-soft); font-size: .96rem; line-height: 1.8; }
.checklist-card .check-grid { grid-template-columns: 1fr; }
.checklist-card .check-grid li strong { color: var(--blue); }
.notice-box { margin-top: 28px; padding: 22px 24px; border-left: 6px solid var(--orange); border-radius: 18px; background: var(--yellow); }
.notice-box p { margin-bottom: 0; color: var(--ink-soft); }

.faq-section { background: #fff; }
.faq-groups { display: grid; gap: 40px; max-width: 880px; margin: 0 auto; }
.faq-group-title { display: flex; align-items: center; gap: 10px; margin: 0 0 16px; padding-bottom: 12px; border-bottom: 2px solid var(--line); font-size: 1.16rem; color: var(--blue); }
.faq-group-title::before { content: ""; flex: 0 0 auto; width: 8px; height: 22px; border-radius: 3px; background: var(--orange); }
.faq-item { border: 1px solid var(--line); border-radius: 14px; background: #fff; box-shadow: 0 8px 22px rgba(37, 123, 253, .06); overflow: hidden; transition: box-shadow .2s ease, border-color .2s ease; }
.faq-item + .faq-item { margin-top: 12px; }
.faq-item[open] { border-color: var(--blue-2); box-shadow: 0 14px 30px rgba(37, 123, 253, .12); }
.faq-item summary { display: flex; align-items: center; gap: 14px; padding: 18px 22px; list-style: none; cursor: pointer; font-weight: 800; color: var(--ink); line-height: 1.6; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before { content: "Q"; flex: 0 0 auto; display: grid; place-items: center; width: 30px; height: 30px; border-radius: 8px; background: var(--pale); color: var(--blue); font-family: var(--font-en); font-weight: 800; font-size: .95rem; }
.faq-item summary > span { flex: 1; }
.faq-item summary::after { content: ""; flex: 0 0 auto; width: 11px; height: 11px; border-right: 2.5px solid var(--blue-2); border-bottom: 2.5px solid var(--blue-2); transform: rotate(45deg) translateY(-2px); transition: transform .2s ease; }
.faq-item[open] summary::after { transform: rotate(225deg) translateY(-2px); }
.faq-item summary:hover { color: var(--blue-2); }
.faq-answer { padding: 0 22px 20px 66px; }
.faq-answer p { margin: 0; color: var(--ink-soft); font-size: .96rem; line-height: 1.9; }
.faq-answer strong { color: var(--blue-deep, #0000AF); font-weight: 700; }
.faq-chart { margin: 18px 0 0; padding: 18px 18px 8px; border: 1px solid var(--line); border-radius: 14px; background: var(--pale-2); }
.faq-chart figcaption { margin-bottom: 12px; color: var(--blue); font-size: .9rem; font-weight: 800; }
.faq-chart-canvas { position: relative; height: 280px; }
.faq-note { max-width: 880px; margin: 28px auto 0; color: var(--muted); font-size: .86rem; line-height: 1.8; }
@media (max-width: 720px) {
  .faq-answer { padding: 0 18px 18px; }
  .faq-item summary { padding: 16px 18px; }
  .faq-chart-canvas { height: 240px; }
}

.access-section { background: #fff; }
.address { font-weight: 800; color: var(--ink); }
.access-stack { display: grid; gap: 14px; }
.map-placeholder { display: grid; place-items: center; min-height: 220px; padding: 24px; border: 1px solid var(--line); border-radius: 20px; background: linear-gradient(135deg, #fff, var(--pale)); text-align: center; }
.map-placeholder span { color: var(--blue-2); font-weight: 900; letter-spacing: .08em; }
.map-placeholder strong { font-size: 1.4rem; }
.map-placeholder p { max-width: 420px; margin-bottom: 0; }
.map-placeholder.has-map { display: block; padding: 0; overflow: hidden; }
.map-placeholder iframe { width: 100%; height: 320px; border: 0; display: block; }

.final-cta { position: relative; background: radial-gradient(circle at 80% 18%, rgba(105,173,255,.28), transparent 32%), radial-gradient(circle at 12% 88%, rgba(242,140,40,.18), transparent 30%), linear-gradient(135deg, #0b1524 0%, #132238 60%, #10294d 100%); color: #fff; overflow: hidden; }
.final-cta::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 42px 42px; mask-image: linear-gradient(180deg, rgba(0,0,0,.6) 0%, transparent 90%); pointer-events: none; }
.final-cta .container { position: relative; z-index: 1; }
.final-cta .eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 6px 16px; border-radius: 999px; background: rgba(105, 173, 255, .14); border: 1px solid rgba(105, 173, 255, .35); color: var(--sky); }
.final-cta .eyebrow::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--orange); box-shadow: 0 0 0 4px rgba(242, 140, 40, .22); animation: cta-pulse 1.8s ease-in-out infinite; }
@keyframes cta-pulse { 0%, 100% { box-shadow: 0 0 0 4px rgba(242, 140, 40, .22); } 50% { box-shadow: 0 0 0 8px rgba(242, 140, 40, .05); } }
.final-cta h2 { margin-top: 18px; font-size: clamp(2rem, 4vw, 3.4rem); line-height: 1.32; color: #fff; }
.final-cta .cta-panel > p { font-size: 1.05rem; max-width: 640px; margin-inline: auto; }
.final-cta p, .cta-note { color: #d7e8fb; }
.final-cta .button.primary { box-shadow: 0 20px 44px rgba(242,140,40,.42); }
.cta-actions { display: flex; flex-direction: column; align-items: center; gap: 18px; margin: 32px 0 22px; }
.text-link { display: inline-flex; align-items: center; gap: 6px; color: #cfe6ff; font-weight: 700; text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 1px; font-size: .95rem; }
.text-link:hover { color: #fff; text-decoration-thickness: 2px; }
.cta-panel { max-width: 860px; text-align: center; }
.cta-note { margin: 0; font-size: .92rem; }
.offseason-actions { margin: 0 0 20px; }
.offseason-actions p { margin: 0; color: #eaf3ff; font-size: .98rem; line-height: 1.75; }
.offseason-actions .offseason-note { margin-top: 14px; padding-top: 12px; border-top: 1px dashed rgba(255,255,255,.18); color: rgba(234,243,255,.78); font-size: .85rem; }
.offseason-actions a { color: #ffd9b0; font-weight: 800; text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 1px; }
.offseason-actions a:hover { color: #fff; text-decoration-thickness: 2px; }
.print-only { display: none; }
.print-pamphlet { margin-top: 20px; padding: 16px; border: 1px solid #bbb; text-align: left; }
.site-footer { padding: 44px 0 96px; color: var(--muted); border-top: 1px solid var(--line); background: #fff; }
.footer-layout { display: grid; grid-template-columns: 1.1fr 1fr .8fr; gap: 28px; align-items: start; }
.footer-brand img { width: 220px; height: auto; display: block; margin-bottom: 14px; }
.footer-brand p { margin-bottom: 4px; color: var(--ink); font-weight: 900; }
.footer-brand small { color: var(--muted); }
.footer-address { font-style: normal; }
.footer-address span { display: inline-flex; margin-bottom: 8px; color: var(--blue-2); font-size: .82rem; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.footer-address p { margin-bottom: 0; color: var(--ink-soft); }
.footer-links { display: grid; gap: 10px; }
.footer-links a { color: var(--blue); font-weight: 800; text-decoration: none; }
.footer-links a:hover { text-decoration: underline; }
.mobile-sticky { display: none; }

@media (max-width: 980px) {
  .nav-toggle { display: inline-flex; }
  .header-drawer { display: flex; flex-direction: column; gap: 8px; position: absolute; top: 100%; left: 0; right: 0; padding: 14px 20px 20px; background: rgba(251, 253, 255, .98); border-bottom: 1px solid rgba(217, 231, 245, .9); box-shadow: 0 16px 32px rgba(16, 34, 56, .08); backdrop-filter: blur(14px); transform: translateY(-10px); opacity: 0; visibility: hidden; transition: transform .2s ease, opacity .2s ease, visibility .2s ease; }
  .site-header.nav-open .header-drawer { transform: translateY(0); opacity: 1; visibility: visible; }
  .header-nav { display: flex; flex-direction: column; gap: 0; margin: 0; font-size: 1rem; }
  .header-nav a { display: block; padding: 14px 4px; border-bottom: 1px solid var(--line); color: var(--ink); font-weight: 700; }
  .header-nav a:last-child { border-bottom: 0; }
  .header-cta { display: inline-flex; margin-top: 8px; width: 100%; min-height: 48px; }
  .site-header { position: sticky; }
  .hero-layout, .curriculum-layout, .demo-layout, .movie-layout, .access-layout { grid-template-columns: 1fr; grid-template-areas: none; gap: 38px; }
  .demo-layout > .product-mock { order: 2; }
  .hero-visual { position: static; }
  .sticky-heading { position: static; }
  .people-grid { grid-template-columns: repeat(2, 1fr); }
  .teachers-grid, .voices-grid { grid-template-columns: 1fr; }
  .teachers-roster-list { grid-template-columns: repeat(2, 1fr); }
  .checklist-card { grid-template-columns: 1fr; }
  .cohort-grid { grid-template-columns: 1fr; }
  .footer-layout { grid-template-columns: 1fr; }
  .electives { padding: 36px 26px; }
  .electives-head { grid-template-columns: 1fr; align-items: start; row-gap: 12px; }
  .electives-head .electives-badge { grid-column: 1; grid-row: auto; }
  .electives-head h3 { grid-column: 1; grid-row: auto; }
  .electives-head p { grid-column: 1; grid-row: auto; }
  .electives-grid { grid-template-columns: 1fr; }
  .elective-label { font-size: .82rem; }
  .elective-card h4 { font-size: 1.15rem; }
  .elective-tags span { font-size: .8rem; }
}

@media (max-width: 760px) {
  .container { width: min(100% - 32px, 1160px); }
  body { padding-bottom: 72px; }
  .section, .hero { padding: 64px 0; }
  .compare-section, .final-cta { padding: 72px 0; }
  .site-header { padding: 12px 16px; gap: 14px; }
  .brand { gap: 10px; }
  .brand img { width: 92px; }
  .brand-title { padding-left: 10px; gap: 3px; }
  .brand-title-kicker { display: none; }
  .brand-title-main { font-size: .92rem; }
  .brand-title-cohort { font-size: .62rem; padding: 1px 5px; }
  .roadmap { padding-left: 36px; }
  .roadmap::before { left: 12px; }
  .roadmap-note { padding-left: 36px; }
  .roadmap > li::before { left: -32px; width: 14px; height: 14px; top: 30px; box-shadow: 0 0 0 4px rgba(105,173,255,.18); }
  .roadmap article { grid-template-columns: 1fr; padding: 22px 18px; }
  .roadmap b { top: 10px; right: 14px; font-size: 2.6rem; }
  .roadmap h3, .roadmap p { padding-right: 70px; }
  .compare-table tbody td:nth-child(2) { border-left-width: 2px; border-right-width: 2px; }
  .cohort-card-actions { grid-template-columns: 1fr; }
  .nowrap { white-space: normal; }
  .hero-highlights { grid-template-columns: 1fr; }
  .system-grid { grid-template-columns: 1fr; }
  h1 { font-size: clamp(2.15rem, 12vw, 3.2rem); }
  .hero-visual { display: none; }
  .floating-metric { position: static; display: inline-block; margin: 14px 8px 0 0; }
  .hero-stats { gap: 18px; padding: 0; flex-direction: column; align-items: flex-start; }
  .hero-stats li + li { padding-left: 0; padding-top: 18px; border-top: 1px solid rgba(37, 123, 253, .18); width: 100%; }
  .hero-stats li + li::before { display: none; }
  .hero-stats strong { font-size: clamp(2.8rem, 14vw, 4rem); }
  .value-grid { grid-template-columns: 1fr; }
  .value-card, .value-card:nth-child(4), .value-card:nth-child(5) { grid-column: auto; min-height: auto; }
  .roadmap article { grid-template-columns: 1fr; padding: 22px 18px; }
  .workspace-footer { grid-template-columns: 1fr; }
  .product-mock { min-height: 320px; }
  .mock-app { grid-template-columns: 124px 1fr; }
  .mock-app-sidebar { padding: 14px 10px; }
  .mock-app-main { padding: 14px; }
  .mock-row { grid-template-columns: 1.4fr .7fr .9fr; }
  .people-grid { grid-template-columns: 1fr; }
  .teachers-grid, .voices-grid { grid-template-columns: 1fr; }
  .teachers-roster-list { grid-template-columns: 1fr; }
  .check-grid { grid-template-columns: 1fr; }
  .scroll-hint { display: block; }
  .button { width: 100%; }
  .mobile-sticky { display: block; position: fixed; left: 0; right: 0; bottom: 0; z-index: 40; padding: 10px 16px; background: rgba(251,253,255,.94); border-top: 1px solid var(--line); }
  .mobile-sticky a { display: flex; justify-content: center; padding: 13px; border-radius: 11px; background: var(--orange); color: #fff; text-decoration: none; font-weight: 900; }
}

@media print {
  .site-header, .mobile-sticky, .hero-actions, .video-placeholder { display: none; }
  body { color: #000; background: #fff; }
  .section, .hero { padding: 20px 0; }
  .container { width: 100%; }
  .hero, .curriculum-section, .final-cta, .guide-section, .demo-section { background: #fff; color: #000; }
  .curriculum-section p, .speech-card p, .primary-card p { color: #000; }
  .value-card, .roadmap article, .speech-card, .table-wrap { box-shadow: none; border-color: #bbb; }
  .site-footer { display: block; padding: 20px 0; }
  .footer-layout { grid-template-columns: 1fr; gap: 8px; }
  .footer-brand img { width: 120px; }
  .print-only { display: block; }
  a[href]::after { content: " (" attr(href) ")"; font-size: 10pt; }
}