/* ========================================
   JSHP Distribution Toprunner Page Styles
   ======================================== */

/* 背景のみ個別指定（高さ・テキストは pages.css の .page-header に準拠） */
.page-header.jshp-hero {
  background-image: url('../images/products/toprunner3-lineup.webp');
  color: var(--color-white);
}

.page-header.jshp-hero .jshp-hero-content,
.page-header.jshp-hero .jshp-hero-visual,
.page-header.jshp-hero .jshp-hero-title-wrap {
  display: contents;
}

.page-header.jshp-hero .jshp-hero-visual-image {
  display: none;
}

.page-header.jshp-hero .page-title,
.page-header.jshp-hero .page-subtitle {
  color: var(--color-white);
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
}

.jshp-product-image-overlay {
  width: 45%;
  max-width: 560px;
}

.jshp-transformer-image {
  width: 100%;
  height: auto;
  filter: drop-shadow(4px 4px 8px rgba(0,0,0,0.3));
}

.jshp-page .content-box {
  background-color: var(--color-white);
  border: none;
  border-radius: var(--radius-none);
  padding: var(--spacing-3xl) var(--container-padding);
  margin-bottom: var(--spacing-3xl);
}

.jshp-page .section .container {
  max-width: var(--container-max-width);
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}

.jshp-page .section-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-gray-800);
  margin: var(--spacing-lg) 0 calc(var(--spacing-xs) * -1);
}

.jshp-page p {
  line-height: var(--line-height-relaxed);
  color: var(--color-gray-700);
  margin-bottom: var(--spacing-md);
  font-size: var(--font-size-base);
}

.jshp-page p:last-of-type {
  margin-bottom: 0;
}

.jshp-footnote {
  font-size: var(--font-size-sm);
  color: var(--color-gray-600);
  font-style: italic;
  margin-top: var(--spacing-lg);
  padding-left: var(--spacing-lg);
  border-left: 3px solid var(--color-gray-300);
}

.jshp-lineup-table-wrapper {
  overflow-x: auto;
  margin: var(--spacing-2xl) 0;
}

.jshp-lineup-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 800px;
  font-size: var(--font-size-sm);
}

.toprunner-mark {
  display: block;
  margin-top: var(--spacing-sm);
}

.toprunner-mark .section-title {
  margin: 0 0 var(--spacing-xs);
}

.toprunner-mark .toprunner-mark-text {
  display: block;
}

.toprunner-mark .toprunner-mark-text p {
  margin: 0 0 var(--spacing-xs);
}

.toprunner-mark .toprunner-mark-text p:last-of-type {
  margin-bottom: 0;
}

.jshp-lineup-table thead {
  background-color: var(--color-primary);
  color: white;
}

.jshp-lineup-table thead th {
  padding: var(--spacing-md);
  text-align: center;
  font-weight: var(--font-weight-bold);
  border: 1px solid rgba(255,255,255,0.3);
}

.jshp-lineup-table tbody th,
.jshp-lineup-table tbody td {
  padding: var(--spacing-md);
  text-align: center;
  border: 1px solid var(--color-gray-300);
  vertical-align: middle;
}

.jshp-lineup-table tbody th {
  background-color: var(--color-gray-100);
  font-weight: var(--font-weight-semibold);
}

.jshp-lineup-table tbody tr:nth-child(even) {
  background-color: var(--color-gray-50);
}

.jshp-lineup-table tbody td {
  line-height: 1.6;
}

/* Responsive */
@media (max-width: 991px) {
  .jshp-page .content-box {
    padding: var(--spacing-2xl);
  }

  .toprunner-mark {
    justify-content: flex-start;
  }
}

@media (max-width: 768px) {
  .page-header.jshp-hero {
    background-image: url('../images/products/toprunner3-lineup_sp.webp');
  }

  .jshp-page .content-box {
    padding: var(--spacing-xl) var(--container-padding);
  }

  .jshp-page .section .container {
    max-width: 100%;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
  }

  .jshp-lineup-table {
    min-width: 0;
    font-size: var(--font-size-xs);
  }

  .toprunner-mark {
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
  }

  .toprunner-mark img {
    width: 40%;
    max-width: 120px;
    float: none;
    margin: 0 auto var(--spacing-sm);
    padding-bottom: -10px;
  }
}

@media (min-width: 769px) {
  .toprunner-mark {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-md);
  }

  .toprunner-mark .toprunner-mark-text {
    flex: 1 1 auto;
    max-width: 700px;
  }

  .toprunner-mark img {
    flex: 0 0 auto;
    width: 180px;
    height: auto;
    margin: 0;
    filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.2));
  }
}
