.ef-page { background: #f8fafc; }
.ef-hero { background: #fff; border-bottom: 1px solid var(--line); }
.ef-hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 40px; align-items: center; padding: 64px 0; }
.ef-title { margin: 18px 0 0; font-size: clamp(40px, 5vw, 66px); line-height: 1.05; letter-spacing: -0.04em; }
.ef-lead { margin: 24px 0 0; color: #475569; font-size: 18px; line-height: 1.8; max-width: 760px; }
.ef-hero-image-box { overflow: hidden; border: 1px solid var(--line); border-radius: 32px; background: #fff; padding: 12px; box-shadow: 0 24px 60px rgba(15,23,42,.10); }
.ef-hero-image { width: 100%; min-height: 420px; border-radius: 24px; object-fit: cover; }
.stats-mini { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-top: 32px; }
.mini-box { padding: 16px; border: 1px solid var(--line); border-radius: 20px; background: #fff; box-shadow: 0 10px 24px rgba(15,23,42,.04); }
.mini-box span { display: block; font-size: 14px; color: #64748b; }
.mini-box strong { display: block; margin-top: 6px; font-size: 16px; }
.intro-grid, .feature-stack, .related-stack { display: grid; gap: 26px; }
.intro-card, .feature-showcase, .related-card { display: grid; grid-template-columns: 1fr .95fr; gap: 28px; align-items: center; padding: 28px; border: 1px solid var(--line); border-radius: 30px; background: #fff; box-shadow: 0 12px 30px rgba(15,23,42,.05); }
.intro-card.reverse, .feature-showcase.reverse, .related-card.reverse { grid-template-columns: .95fr 1fr; }
.intro-card img, .feature-showcase img, .related-card img { width: 100%; min-height: 260px; height: 100%; object-fit: cover; border-radius: 24px; }
.intro-copy h2, .feature-showcase-copy h3, .related-copy h3 { margin: 0; font-size: 38px; line-height: 1.12; letter-spacing: -.03em; }
.intro-copy h2 { color: #1f3c88; }
.related-copy h3 { color: #d12b4b; }
.intro-copy p, .feature-showcase-copy p, .related-copy p { margin: 16px 0 0; color: #64748b; line-height: 1.85; font-size: 16px; }
.ef-band { padding: 72px 0; background: #0f2f78; color: #fff; }
.ef-band h2, .type-band h2, .ef-cta h2 { margin: 0; font-size: clamp(34px, 4vw, 54px); line-height: 1.08; letter-spacing: -.03em; }
.ef-band p, .type-band p, .ef-cta p { margin: 18px auto 0; max-width: 980px; line-height: 1.85; color: rgba(255,255,255,.80); font-size: 18px; }
.narrow { max-width: 980px; }
.advantage-panel { padding: 40px; border: 1px solid var(--line); border-radius: 34px; background: #fff; box-shadow: 0 18px 50px rgba(15,23,42,.08); }
.advantage-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; margin-top: 44px; }
.adv-item { display: flex; align-items: flex-start; gap: 14px; padding: 18px; border: 1px solid var(--line); background: #f8fafc; border-radius: 20px; }
.adv-item span { width: 30px; height: 30px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; background: #1f3c88; color: #fff; font-weight: 700; flex-shrink: 0; }
.adv-item p { margin: 0; line-height: 1.75; color: #334155; }
.type-band { margin-top: 72px; padding: 86px 0; background: #081f58; color: #fff; }
.type-band-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 40px; }
.type-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; }
.type-card { padding: 24px; border-radius: 24px; border: 1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.05); backdrop-filter: blur(8px); }
.type-icon { width: 48px; height: 48px; border-radius: 18px; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,.10); color: #8fb2ff; font-weight: 800; }
.type-card h3 { margin: 18px 0 0; font-size: 24px; }
.type-card p { margin: 12px 0 0; color: rgba(255,255,255,.78); line-height: 1.8; }
.related-card .text-link { margin-top: 18px; }
.ef-cta { padding: 84px 0; border-top: 1px solid var(--line); background: #fff; }
.ef-cta-grid { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center; }
@media (max-width: 1100px) {
  .ef-hero-grid, .type-band-grid, .ef-cta-grid, .intro-card, .intro-card.reverse, .feature-showcase, .feature-showcase.reverse, .related-card, .related-card.reverse { grid-template-columns: 1fr; }
  .stats-mini, .advantage-grid, .type-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 768px) {
  .stats-mini, .advantage-grid, .type-grid { grid-template-columns: 1fr; }
  .advantage-panel, .intro-card, .feature-showcase, .related-card { padding: 22px; }
}
