.hero-headline__dot {
  color: #004D6D;
  font-size: 1.5em;
  line-height: 0;
  vertical-align: -0.06em;
}
.page-hero { padding-top: 200px; padding-bottom: 120px; border-bottom: 1px solid var(--color-gray-2); }
.page-hero .eyebrow {
  font-family: var(--font-en); font-size: 12px; color: var(--color-gray-4);
  letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 32px; display: inline-block;
}
.page-hero .eyebrow::before { content: "03 / 03 "; color: var(--color-gray-3); margin-right: 12px; }
.page-hero h1 {
  font-family: var(--font-en); font-weight: 400;
  font-size: clamp(56px, 10vw, 144px); line-height: 0.98;
  letter-spacing: -0.04em; margin: 0;
}
.page-hero h1 .accent-dot {
  display: inline-block; width: 0.18em; height: 0.18em; border-radius: 50%;
  background: var(--accent); transform: translateY(-0.05em); margin-left: 0.06em;
}
.page-hero .sub {
  margin-top: 48px; max-width: 56ch; font-family: var(--font-jp);
  font-size: clamp(18px, 1.5vw, 22px); line-height: 1.7; color: var(--color-black);
}
.twocol { display: grid; grid-template-columns: 1fr 2fr; gap: 96px; align-items: start; }
@media (max-width: 900px) { .twocol { grid-template-columns: 1fr; gap: 32px; } }
.longread { font-family: var(--font-jp); font-size: 16px; line-height: 2; color: var(--color-gray-4); max-width: 56ch; }
.longread p + p { margin-top: 24px; }
.pull {
  font-family: var(--font-jp); font-size: clamp(24px, 2.6vw, 36px); font-weight: 300;
  line-height: 1.55; color: var(--color-black); margin: 64px 0;
  padding-left: 32px; border-left: 1px solid var(--accent); max-width: 32ch;
}

.usp-list { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--color-gray-2); }
.usp-list li {
  display: grid; grid-template-columns: 60px 1fr 1.2fr; gap: 32px;
  padding: 32px 0; border-bottom: 1px solid var(--color-gray-2); align-items: baseline;
}
.usp-list .n { font-family: var(--font-en); font-size: 13px; color: var(--color-gray-3); font-weight: 500; }
.usp-list .t { font-family: var(--font-jp); font-size: clamp(18px, 1.8vw, 22px); line-height: 1.5; }
.usp-list .d { font-family: var(--font-jp); font-size: 14px; color: var(--color-gray-4); line-height: 1.85; }
@media (max-width: 768px) {
  .usp-list li { grid-template-columns: 50px 1fr; }
  .usp-list .d { grid-column: 1 / -1; padding-left: 50px; }
}

.program-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: var(--color-gray-2);
  border: 1px solid var(--color-gray-2);
}
.program-grid > div {
  background: var(--color-white);
  padding: 48px 32px;
  min-height: 280px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.program-grid .pn {
  font-family: var(--font-en); font-size: 12px; font-weight: 500;
  color: var(--color-gray-4); letter-spacing: 0.05em;
}
.program-grid .pt {
  font-family: var(--font-jp); font-size: clamp(20px, 2vw, 26px);
  font-weight: 400; line-height: 1.4; margin-top: 12px;
}
.program-grid .pd {
  font-family: var(--font-jp); font-size: 13px; color: var(--color-gray-4);
  line-height: 1.85; margin-top: 24px;
}
@media (max-width: 768px) {
  .program-grid { grid-template-columns: 1fr; }
}

.flow-list {
  counter-reset: flow; list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
}
.flow-list li {
  counter-increment: flow; padding: 32px 0;
  border-top: 1px solid var(--color-black);
  font-family: var(--font-jp); position: relative;
}
.flow-list li::before {
  content: "0" counter(flow);
  font-family: var(--font-en); font-size: 12px; font-weight: 500;
  color: var(--color-gray-4); display: block; margin-bottom: 16px;
}
.flow-list .ft { font-size: clamp(20px, 2vw, 26px); font-weight: 400; line-height: 1.4; }
.flow-list .fd { font-size: 14px; color: var(--color-gray-4); margin-top: 12px; line-height: 1.7; }
@media (max-width: 768px) { .flow-list { grid-template-columns: 1fr; } }

.cta-block { text-align: center; padding: 160px 0; border-top: 1px solid var(--color-gray-2); }
.cta-block h2 {
  font-family: var(--font-en); font-weight: 400;
  font-size: clamp(40px, 6vw, 88px); letter-spacing: -0.03em;
  line-height: 1.05; margin-bottom: 48px;
}
.cta-block .accent-dot {
  display: inline-block; width: 0.16em; height: 0.16em; border-radius: 50%;
  background: var(--accent); transform: translateY(-0.05em); margin-left: 0.06em;
}
