/* =========================================================
   PRIMA GAKKI 80th Anniversary - Archet Pavane
   ========================================================= */

/* images */
img { max-width: 100%; height: auto; }

/* spacing helpers */
.section { margin-top: 80px; }
.section--end { margin-bottom: 30px; }
.block { margin-top: 40px; }
.block-sm { margin-top: 20px; }

/* section label */
.inline-block_bold {
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .04em;
  margin: 24px 0 6px;
}


/* =========================
   Product grid (PC)
   ========================= */

.box_archet > .box_mds {
  margin-bottom: 8px;
  padding-bottom: 0;
}

.box_archet_c {
  padding-top: 0;
  margin-top: 0;
}

.box_archet_c_h60 {
  height: auto;
  width: 100%;
  margin: 15px 0;
}

.box_archet_c2 {
  display: grid;
  grid-template-columns: 220px 220px 270px;
  gap: 15px;
}

.box_archet_c2l { grid-column: 1 / 3; }
.box_archet_c2_r { grid-column: 3 / 4; }

.archet-wide { margin: 0 0 6px; }
.archet-wide img { display: block; width: 100%; }

/* caption overlay */
.thumbcap {
  position: relative;
  overflow: hidden;
}

.thumbcap::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 35%;
  pointer-events: none;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.65) 0%,
    rgba(0, 0, 0, 0.35) 40%,
    rgba(0, 0, 0, 0.0) 100%
  );
}

.thumbcap--archet p {
  position: absolute;
  right: 10px;
  bottom: 8px;
  z-index: 1;
}

.thumbcap--no-caption::after {
  display: none;
}

.thumbcap img { display: block; width: 100%; }

.box_archet_c2l .thumbcap { margin-top: 10px; }

.thumbcap--archet p {
  position: absolute;
  right: 10px;
  bottom: 8px;
  margin: 0;
  font-size: 12px;
  line-height: 1.35;
  letter-spacing: .05em;
  font-feature-settings: "palt";
  text-align: right;
  color: #c8b18b;
}


/* =========================
   Head bars (archet / press)
   ========================= */

.archet_mds,
.pr_archet_mds {
  width: 100%;
  max-width: 740px;
  box-sizing: border-box;
  margin: 0;
  padding: 8px 0 5px 15px;
  background: linear-gradient(to bottom right, #cbb48d, #feecd2);
}

.archet_mds { border-radius: 2px; }
.pr_archet_mds { border-radius: 3px 3px 0 0; }

.archet_mds p,
.pr_archet_mds p {
  margin: 0;
  padding: 0;
  font-size: 14px;
  color: #fff;
}

.archet_mds p {
  font-weight: 700;
  letter-spacing: .02em;
}

.pr_archet_mds p {
  font-family: "montserrat","source-han-sans-japanese",sans-serif;
  font-weight: 600;
  letter-spacing: .04em;
  font-feature-settings: "palt";
}

/* price chips */
.inline-block_archet {
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: 8px 8px 8px 10px;
  background: #fcfaf7;
  border-radius: 3px;
}

.archet_type {
  display: inline-block;
  padding-left: 5px;
  font-size: 12.5px;
}


/* =========================
   Press cards (PC)
   ========================= */

.box_press_n {
  display: grid;
  gap: 20px;
  margin: 0;
  padding: 0;
}

/* Press item spacing: add space before the next heading */
#press .box_press_n + .block-sm.pr_archet_mds {
  margin-top: 15px;
}

.box_press_r {
  display: grid;
  grid-template-columns: 136px 1fr;
  gap: 20px;
  margin: 0;
  padding: 10px;
  background: #fbfbfb;
  border: 1px solid #e5e5e5;
  border-radius: 0 0 3px 3px;
}

.box_press_r:hover { background: #f2f2f2; }

.box_press_rl {
  display: flex;
  justify-content: center;
}

.box_press_rr {
  margin: 2px 0;
  font-size: 12.5px;
  line-height: 1.7;
  text-align: left;
}

.image_size_tate {
  display: block;
  height: 180px;
  width: auto;
}


/* =========================================================
   Shared note blocks used on this page
   ========================================================= */

.box_solo_c_h60 {
  height: auto;
  width: 100%;
  margin: 10px 0;
}


/* =========================
   SP (<= 768px)
   ========================= */

@media (max-width: 768px) {
  .archet_mds,
  .pr_archet_mds {
    max-width: none;
    padding: 8px 10px 6px;
  }

  .box_archet_c2 {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .box_archet_c2l,
  .box_archet_c2_r {
    grid-column: auto;
  }

  .box_press_n { gap: 12px; }

  .box_press_r {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 10px;
  }

  .image_size_tate {
    height: auto;
    width: 100%;
    max-width: 200px;
    margin: 0 auto;
  }
}