@import url("./common.css");

/* Reset and base styles */
* {
  margin: 0;
}

/* Breadcrumb */
.breadcrumb {
  display: inline-block;
}

/* Book section */
.book-section {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 40px;
  width: 100%;
  margin-top: 30px;
}

.book-info {
  flex: 3;
}

.book-title {
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  font-size: var(--font-size-pc-large);
}

.book-price {
  font-weight: var(--font-weight-bold);
  color: var(--color-black);
  font-size: var(--font-size-pc-base);
  margin-top: 10px;
}

.book-description {
  color: var(--color-black);
  font-size: var(--font-size-pc-base);
  margin-top: 20px;
}

.book-description-caption {
  color: var(--color-black);
  font-size: var(--font-size-pc-note);
}

.book-image-card {
  flex: 2;
  display: flex;
  justify-content: center;
  align-items: center;
}

.book-image-card img {
  height: 300px;
  width: auto;
}

/* Table section */
.table-section {
  margin-top: 40px;
}

.content-table {
  width: 100%;
  border-collapse: collapse;
}

.table-row {
  display: flex;
  flex-direction: row;
  border-bottom: 1px solid var(--color-primary);
  background-color: var(--color-white);
  color: var(--color-black);
  font-size: var(--font-size-pc-base);
}

.table-row:first-child {
  border-top: 1px solid var(--color-primary);
}

.table-header-cell {
  min-width: 200px;
  padding: 30px;
  font-weight: var(--font-weight-bold);
}

.table-content-cell {
  padding: 30px;
}

.cta-section {
  margin-top: 40px;
}

/* 767px以下でbook-image-cardを縦に並べる */
@media (width <= 767px) {
  .book-price {
    font-size: var(--font-size-sp-base);
  }

  .book-description {
    font-size: var(--font-size-sp-base);
    margin-top: 30px;
  }

  .book-description-caption {
    font-size: var(--font-size-sp-note);
  }
  .book-section {
    flex-direction: column;
    gap: 20px;
  }

  .book-image-card {
    width: 100%;
  }

  /* テーブルを縦並びに変更 */
  .table-row {
    flex-direction: column;
    font-size: var(--font-size-sp-base);
  }

  .table-header-cell {
    padding: 20px 20px 0 20px;
  }

  .table-content-cell {
    padding: 20px;
  }
}
