@charset "utf-8";

/* 印刷時のスタイル */
@media print {
  /* 印刷モードでない場合は何もしない */

  /* 印刷モードの時のみ適用 */
  body.printing {
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
  }

  /* contentsWrapperとmainを表示 */
  body.printing #contentsWrapper {
    display: block !important;
    visibility: visible !important;
    position: relative;
  }

  body.printing main {
    display: block !important;
    visibility: visible !important;
    position: relative;
  }

  /* 印刷時の縦幅を80%に縮小し、中央配置 */
  body.printing #contentsWrapper {
    transform: scaleY(0.8) !important;
    -webkit-transform: scaleY(0.8) !important;
    transform-origin: top center !important;
    -webkit-transform-origin: top center !important;
    margin: 0 auto !important;
    width: 100% !important;
    max-width: 1080px !important;
    padding-top: 0 !important;
    display: block !important;
    visibility: visible !important;
  }

  /* 不要な要素を非表示 */
  body.printing #modal,
  body.printing #back-top,
  body.printing .space-section,
  body.printing footer,
  body.printing .breadcrumb-section,
  body.printing .title-section,
  body.printing .page-navigation-section,
  body.printing .products-list-title-section {
    display: none !important;
    visibility: hidden !important;
  }

  /* main内の、print-targetクラスが付いていない.products-detaile-wrapを非表示 */
  body.printing main .products-detaile-wrap:not(.print-target) {
    display: none !important;
    visibility: hidden !important;
  }

  /* main内の、print-sectionクラスが付いていないセクションを非表示 */
  body.printing main > section:not(.print-section) {
    display: none !important;
    visibility: hidden !important;
  }

  /* print-sectionクラスが付いたセクションを表示 */
  body.printing main > section.print-section {
    display: block !important;
    visibility: visible !important;
    position: relative;
    width: 100%;
  }

  /* products-detaile-innerを表示 */
  body.printing .products-detaile-inner {
    display: block !important;
    visibility: visible !important;
    position: relative;
    width: 100%;
  }

  /* headerがprint-targetクラスを持たない場合は非表示 */
  body.printing header:not(.print-target) {
    display: none !important;
    visibility: hidden !important;
  }

  /* print-targetクラスが付いたheaderを表示 */
  body.printing header.print-target {
    display: block !important;
    visibility: visible !important;
    width: 100%;
    padding: 20px 0;
    border-bottom: 1px solid #ccc;
    margin-bottom: 20px;
  }

  body.printing header.print-target .head-inner {
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    visibility: visible !important;
  }

  body.printing header.print-target h1 {
    margin: 0;
    display: block !important;
    visibility: visible !important;
  }

  body.printing header.print-target h1 a {
    display: block !important;
    visibility: visible !important;
  }

  body.printing header.print-target h1 img {
    height: 40px;
    width: auto;
    display: block !important;
    visibility: visible !important;
  }

  /* ナビゲーション、SNSアイコン、ハンバーガーメニューは非表示 */
  body.printing header.print-target .navi,
  body.printing header.print-target .sns-icons,
  body.printing header.print-target button[data-action="toggle-menu"] {
    display: none !important;
    visibility: hidden !important;
  }
  body.printing header.print-target .print {
    display: block !important;
    visibility: visible !important;
    width: 20%;
  }
  /* .products-detaile-wrapのスタイル */
  body.printing .products-detaile-wrap.print-target {
    display: grid !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
    width: 100% !important;
    max-width: 1080px !important;
    margin: 0 auto !important;
    margin-top: 30px !important;
    padding: 40px 20px !important;
    padding-top: 40px !important;
    background-color: #fff !important;
    page-break-inside: avoid;
    page-break-after: always;
    grid-template-columns: minmax(363px, 363px) minmax(182px, 182px) minmax(282px, 282px) !important;
    grid-template-rows: min-content 1fr 1fr auto !important;
    grid-column-gap: 20px !important;
    grid-row-gap: 20px !important;
    grid-template-areas:
      "div5 div1 div1"
      "div5 div2 div3"
      "div5 div2 div4"
      "div5 div2 div6" !important;
    align-items: start !important;
    overflow: visible !important;
    transform: scaleY(1.1) !important;
    transform-origin: top center !important;
    -webkit-transform: scaleY(1.1) !important;
    -webkit-transform-origin: top center !important;
  }

  body.printing .products-detaile-wrap.print-target:last-child {
    page-break-after: auto;
  }

  /* 印刷ボタンは非表示 */
  body.printing .products-detaile-wrap.print-target .print-button {
    display: none !important;
    visibility: hidden !important;
  }

  /* グリッドエリア内の要素を表示 */
  body.printing .products-detaile-wrap.print-target > * {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
  }

  body.printing .products-detaile-wrap.print-target .div1 {
    grid-area: div1;
    display: block !important;
    visibility: visible !important;
    overflow: visible !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
    min-height: auto !important;
    align-self: start !important;
    position: relative;
    z-index: 1;
    transform: scale(1) !important;
  }

  /* div1内の要素が切れないように */
  body.printing .products-detaile-wrap.print-target .div1 > * {
    overflow: visible !important;
    position: relative;
    display: block !important;
  }

  body.printing .products-detaile-wrap.print-target .div2 {
    grid-area: div2;
    display: flex !important;
    visibility: visible !important;
    height: 100%;
    align-items: stretch;
    justify-content: center;
  }

  /* product-size-area内の画像を縦いっぱいに表示 */
  body.printing .products-detaile-wrap.print-target .product-size-area {
    height: 100%;
    display: flex !important;
    align-items: stretch;
    justify-content: center;
  }

  body.printing .products-detaile-wrap.print-target .product-size-area > img {
    height: 100% !important;
    width: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
  }

  body.printing .products-detaile-wrap.print-target .div3 {
    grid-area: div3;
    display: block !important;
    visibility: visible !important;
  }

  body.printing .products-detaile-wrap.print-target .div4 {
    grid-area: div4;
    display: block !important;
    visibility: visible !important;
  }

  body.printing .products-detaile-wrap.print-target .div5 {
    grid-area: div5;
    display: flex !important;
    visibility: visible !important;
    height: 100%;
    align-items: stretch;
    background: #fff !important;
  }

  /* product-image-area内の画像を縦いっぱいに表示 */
  body.printing .products-detaile-wrap.print-target .product-image-area {
    height: 100%;
    display: flex !important;
    align-items: stretch;
    justify-content: center;
  }

  body.printing .products-detaile-wrap.print-target .product-image-area > img {
    height: 90% !important;
    width: auto !important;
    max-width: 100% !important;
    max-height: 90% !important;
    object-fit: contain !important;
  }

  body.printing .products-detaile-wrap.print-target .div6 {
    grid-area: div6;
    display: block !important;
    visibility: visible !important;
  }
  body.printing .products-detaile-wrap.print-target .div6 .case-item li {
    width: calc(100% / 3);
    aspect-ratio: 1/1;
  }
  body.printing .products-detaile-wrap.print-target .div6 .case-item li img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    margin-inline: auto;
    box-sizing: border-box;
  }

  /* 画像の印刷品質を向上 */
  body.printing .products-detaile-wrap.print-target img {
    max-width: 100%;
    height: auto;
    display: block !important;
    visibility: visible !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  /* product-image-areaとproduct-size-area内の画像は縦いっぱいに表示（上記のスタイルを上書き） */
  body.printing .products-detaile-wrap.print-target .product-image-area > img {
    height: 90% !important;
    width: auto !important;
    max-width: 100% !important;
    max-height: 90% !important;
    object-fit: contain !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  body.printing .products-detaile-wrap.print-target .product-size-area > img {
    height: 100% !important;
    width: auto !important;
    max-width: 100% !important;
    max-height: none !important;
    object-fit: contain !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  body.printing .products-detaile-wrap.print-target .product-option-area {
    background-color: #f7f7f7 !important;
  }
  /* 背景色の印刷を有効化 */
  body.printing .products-detaile-wrap.print-target,
  body.printing .product-option-area {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  /* ページ設定 */
  @page {
    margin: 1cm auto;
    size: A4;
  }
}
