.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: "02 / 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;
}
.stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 48px;
  margin-top: 48px;
  padding-top: 48px;
  border-top: 1px solid var(--color-gray-2);
}
.stat .num {
  font-family: var(--font-en); font-size: clamp(40px, 5vw, 64px);
  font-weight: 400; letter-spacing: -0.03em; line-height: 1;
}
.stat .lbl {
  font-family: var(--font-jp); font-size: 13px; color: var(--color-gray-4);
  margin-top: 12px; line-height: 1.7;
}

.value-list { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--color-gray-2); }
.value-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;
}
.value-list .n { font-family: var(--font-en); font-size: 13px; color: var(--color-gray-3); font-weight: 500; }
.value-list .t { font-family: var(--font-jp); font-size: clamp(18px, 1.8vw, 22px); line-height: 1.5; }
.value-list .d { font-family: var(--font-jp); font-size: 14px; color: var(--color-gray-4); line-height: 1.85; }
@media (max-width: 768px) {
  .value-list li { grid-template-columns: 50px 1fr; }
  .value-list .d { grid-column: 1 / -1; padding-left: 50px; }
}

.product-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 96px;
  align-items: center;
  padding: 96px 0;
  border-top: 1px solid var(--color-gray-2);
  border-bottom: 1px solid var(--color-gray-2);
}
.product-visual {
  aspect-ratio: 4/5;
  background: var(--color-gray-1);
  position: relative;
  overflow: hidden;
}
.product-visual img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.product-info .name {
  font-family: var(--font-en); font-size: clamp(36px, 4.5vw, 56px);
  font-weight: 400; letter-spacing: -0.025em; line-height: 1.05;
}
.product-info .desc { margin-top: 24px; color: var(--color-gray-4); line-height: 1.85; max-width: 38ch; }
.product-info .price {
  font-family: var(--font-en); font-size: 22px; font-weight: 500;
  margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--color-gray-2);
  display: flex; justify-content: space-between; align-items: baseline;
}
.product-info .price .unit { font-size: 12px; color: var(--color-gray-4); font-weight: 400; }
.product-actions { margin-top: 32px; }
.product-buy {
  width: 100%;
  max-width: 300px;
  justify-content: center;
}
@media (max-width: 900px) { .product-card { grid-template-columns: 1fr; gap: 48px; } }
@media (max-width: 900px) {
  .product-buy { max-width: none; }
}

.channel-list {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 0;
  border-top: 1px solid var(--color-gray-2);
}
.channel-list li {
  padding: 32px 0;
  border-bottom: 1px solid var(--color-gray-2);
  font-family: var(--font-jp); font-size: 16px; line-height: 1.7;
  display: flex; align-items: baseline; gap: 16px;
}
.channel-list li:nth-child(odd) { padding-right: 32px; }
.channel-list li:nth-child(even) { padding-left: 32px; border-left: 1px solid var(--color-gray-2); }
.channel-list .n { font-family: var(--font-en); font-size: 12px; color: var(--color-gray-3); }
@media (max-width: 768px) {
  .channel-list { grid-template-columns: 1fr; }
  .channel-list li:nth-child(even) { padding-left: 0; border-left: 0; }
  .channel-list li:nth-child(odd) { padding-right: 0; }
}

.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;
}
