@charset "utf-8";

html { scroll-behavior: smooth; }
#globalMain, #globalContents{ overflow: visible; }
#globalWrapper { box-sizing: border-box; }


/* Variables & Setup -------------------- */
:root {
  scroll-padding: 100px;
}

.pg-container-wrapper {
  container-type: inline-size;
  container-name: pg-container-wrapper;
}

.pg-container * { box-sizing: border-box; }

:root .pg-container {
  --color-black: #2d2926; /* 指定色 */
  --color-gray: #4b4f54; /* 指定色 */
  --color-lightgray: #bbbcbc; /* 指定色 */
  --color-offwhite: #f5f5f5;
  --color-white: #fff; /* 指定色 */
  --color-pantone-red: #ef3340; /* 指定色 */
  --color-accent: #F5EE44;
  
  --float: translateY(-5px);
  --transition-all: all .2s ease;
  --space-inline: 2rem; /* innner */
}

/* common -------------------- */ 
.pg-container {
  font-family: "Noto Sans JP", sans-serif;
  max-width: 1420px;
  margin-inline: auto;
  background-color: var(--color-white);
  color: var(--color-black);
  font-size: 16px;
  line-height: 1.4;
  letter-spacing: 0.02em;
  @container pg-container-wrapper (max-width: 768px) {
    font-size: 14px;
  }
  @container pg-container-wrapper (max-width: 375px) {
    font-size: 13px;
  }
  & section{
    padding-block: 2rem;
    &:has(> :first-child.el-heading-g-label) {
      padding-top: 0;
    }
  }
  & .inner{
    padding-inline: var(--space-inline);
  }

  & figure{ 
    text-align: center;
    overflow: hidden;
  }

  & img{
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
  }

  & a{
    color: inherit;
    text-decoration: none;
  }

  & span{
    color: inherit;
    font-weight: inherit;
  }

  & strong{
    font-weight: normal;
  }
}

/* element -------------------- */
/* 見出し(帯) */
.pg-container .el-heading-g-label{
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-block: .4rem .5rem;
  padding-inline: var(--space-inline);
  background-color: var(--color-pantone-red);
  color: var(--color-white);
  & > h2{
    font-size: 150%;
    font-weight: bold;
  }
@container pg-container-wrapper (max-width: 600px) {
  & > h2{
    font-size: 125%;
  }
}
}

/* 見出し（通常） */
.pg-container .el-heading-g{
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-block: 1rem;
  & > h2{
    font-size: 250%;
    font-weight: bold;
    text-transform: uppercase;
  }
@container pg-container-wrapper (max-width: 600px) {
  & > h2{
    font-size: 200%;
  }
}
}

/* CTAボタン */
.pg-container .el-btn-cta{
	display: block;
	width: fit-content;
  padding-inline: 1.25em;
  padding-block: .4em .5em;
  border-radius: 100vmax;
	background-color: var(--color-pantone-red);
	color: var(--color-white);
  text-align: center;
  font-weight: bold;
  white-space: nowrap;
}

/* CTAテキスト */
.pg-container .el-text-cta{
  display: block;
	width: fit-content;
  color: var(--color-pantone-red);
  font-size: 112%;
  font-weight: bold;
  white-space: nowrap;
  &::after{
    content: " ≫";
  }  
}

/* ・・・のリスト */
.pg-container .el-disc-list{
  list-style-type: disc;
  margin-left: 1.5rem;
}

/* img：祖先要素ホバーで拡大 */
.pg-container .el-expansion{
 
  & img {
    transition: transform 0.3s ease;
  }

  &:hover img {
    transform: scale(1.03);
  }
} 

/* ホバーでちょっと浮く */
.pg-container .el-float{
  transition: var(--transition-all);
  &:hover{
    transform: var(--float);
  }
}

/* 文章 */
.pg-container .paragraph{
  line-height: 1.7;
  /* text-align: justify; */

  & + .paragraph{
    margin-top: .5rem;
  }
}

/* 2行以上で... */
.pg-container .textellipsis-2{
	display: -webkit-box;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
  line-clamp: 2;
	-webkit-line-clamp: 2;
}

/* 動画のabsoアイコン（aにクラス名つける）*/
.pg-container .icon-movie{
	display: block;
	width: 100%;
	position: relative;

  &::after { position: absolute; display: block;	content: ""; width: 100%; height: 0; padding-top: 56.25%;top: 0;	left: 0;	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="100%" version="1.1" viewBox="0 0 68 48" width="100%" fill="%23ffffff"><path d="M66.52,7.74c-0.78-2.93-2.49-5.41-5.42-6.19C55.79,.13,34,0,34,0S12.21,.13,6.9,1.55 C3.97,2.33,2.27,4.81,1.48,7.74C0.06,13.05,0,24,0,24s0.06,10.95,1.48,16.26c0.78,2.93,2.49,5.41,5.42,6.19 C12.21,47.87,34,48,34,48s21.79-0.13,27.1-1.55c2.93-0.78,4.64-3.26,5.42-6.19C67.94,34.95,68,24,68,24S67.94,13.05,66.52,7.74z" fill="%23f00"></path><path d="M 45,24 27,14 27,34" fill="%23fff"></path></svg>') no-repeat center center;	background-size: 20%; }
}

/* 背景：ダーク */
.pg-container .bg-dark{
  background-color: var(--color-black);
  color: var(--color-white);
}

/* 背景：オフホワイト */
.pg-container .bg-ow{
  background-color: var(--color-offwhite);
}

/* swiper -------------------- */
:root .pg-container{
  --swiper-theme-color: #ef3340;
  --swiper-pagination-color:#ef3340;
  --swiper-pagination-bullet-size: 1rem;
  --swiper-navigation-size: 32px;
}

.pg-container .swiper-button-next,
.pg-container .swiper-button-prev {
  width: 50px;
  height: 50px;
  top: 50%;
  z-index: 99;
  transform: translateY(-100%);
  &::after{
    display: none;
  }
}

.pg-container .swiper-button-next{background: url("../img/assets/button-next.png") no-repeat center / contain;}
.pg-container .swiper-button-prev{background: url("../img/assets/button-prev.png") no-repeat center / contain;}

/* gLightbox -------------------- */
:root {
  --plyr-color-main: #ff0000;
}

.goverlay {
	background: rgba(0, 0, 0, .7);
}

/* モーダルウィンドウ -------------------- */
.pg-container .win-modal{
  width: 90%;
  max-width: 1000px;
  max-height: calc(100vh - 150px - 3rem);
}

.pg-container .modal-contents-wrapper{
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
}

.pg-container .modal-contents{
  padding-block: 1.5rem;
  padding-inline: 2rem;
  min-height: 10rem;
@container pg-container-wrapper (max-width: 600px) {
  padding-inline: 0;
}
}

.pg-container .close-modal{
  position: fixed;
  z-index: 3;
  top: calc(50px - 1.5rem);
  right: 1.5rem;
  display: grid;
  place-items: center;  
  width: 3rem;
  height: 3rem;
  border: none;
  border-radius: 100vmax;
  background-color: var(--color-black);

  &::before{
    content: "×";
    color: var(--color-white);
    font-size: 200%;
    font-weight: bold;
    line-height: 1;
  }
}

/* Section-by-section（&article） -------------------- */
/* FV --------------------*/
.pg-container .sec-fv{
  padding-top: 0;
}

.sec-fv .logo-block{
  max-width: 800px;
  margin-inline: auto;
  margin-block: 2.5rem;
}
.sec-fv .unit-box{
  display: flex;
  gap: 1rem 0;
  margin-block: 1rem;
@container pg-container-wrapper (max-width: 900px) {
  flex-direction: column;
  align-items: center;
}
}

.sec-fv .text-block{
  flex: 1;
  padding-inline: var(--space-inline);
}

.sec-fv .image-block{
  display: flex;
  width: 400px;
  max-width: 100%;
  & > img{
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

/* 製品紹介 =============================== */
/* （製品：各セクション共通） */
.at-product section + section{
  margin-top: 3rem;
}

.at-product strong{
  font-weight: bold;
}

.at-product .c-introduction{
  margin-block: 2rem;
  font-size: 112%;
}

.at-product .c-catchcopy{
  font-size: 150%;
  font-weight: bold;
  & + .paragraph{
    margin-top: .5rem;
  }
@container pg-container-wrapper (max-width: 600px) {
  font-size: 125%;
}
}

.at-product .c-cardset{
  --card-width: 280px;
  --card-gap: 1.5rem;

  display: flex;
  flex-wrap: wrap;
  gap: var(--card-gap);
  max-width: calc(var(--card-width) * 4 + var(--card-gap) * 3);
  margin-inline: auto;
  margin-block: 1.5rem;

  & > li{
    width: var(--card-width);
    height: auto;
  }

  & > li > a{
    position: relative;
    display: flex;
    width: 100%;
    height: 100%;
    padding: 1rem;
    padding-bottom: 2rem;
    border-radius: .5rem;
    border: 1px solid var(--color-black);
    &::after{
      content: "+";
      position: absolute;
      bottom: 0;
      right: 0;
      margin: .75rem;
      display: grid;
      place-items: center;
      width: 1.5rem;
      aspect-ratio: 1/1;
      border-radius: 100vmax;
      background-color: var(--color-black);
      color: var(--color-white);
      font-size: 112%;
      font-weight: bold;
    }
  }

  & h3{
    font-weight: bold;
    &::after{
      content: "　";
      display: inline-block;
    }
  }

@container pg-container-wrapper (max-width: 1260px) {
  max-width: calc(var(--card-width) * 3 + var(--card-gap) * 2);
}
@container pg-container-wrapper (max-width: 930px) {
  max-width: calc(var(--card-width) * 2 + var(--card-gap) * 1);
}
@container pg-container-wrapper (max-width: 768px) {
  --card-width: calc((100% - var(--card-gap)) / 2);
  width: 100%;
  max-width: 600px;
}
@container pg-container-wrapper (max-width: 600px) {
  max-width: 450px;
}
}

.at-product .bg-dark .c-cardset{
  & > li > a{
    border-color: var(--color-white);
    &::after{
      background-color: var(--color-white);
      color: var(--color-black);
    }
  }
}

.at-product .c-item-list{
  --cols: 3;
  --item-width: 260px;
  --item-gap: 3rem;

  display: grid;
  grid-template-columns: repeat(var(--cols), var(--item-width));
  gap: var(--item-gap);
  max-width: fit-content;
  margin-inline: auto;

  & > li{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0 1.5rem;
  }

@container pg-container-wrapper (max-width: 768px) {
  --item-gap: 2rem;
}
@container pg-container-wrapper (max-width: 600px) {
  --item-gap: 4rem;
  
  grid-template-columns: 100%;
  max-width: 100%;
  & > li{
    width: 100%;
    flex-direction: row;
  }
}
}

.at-product .image-block{
  width: 90%;
@container pg-container-wrapper (max-width: 600px) {
  width: 150px;
}
}

.at-product .c-item-list .c-product-header{
  position: relative;
  padding-bottom: 3.5rem;
  flex: 1;
  width: 100%;
  & .c-cta-wrapper{
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    justify-content: center;
    font-size: 85%;
  }
@container pg-container-wrapper (max-width: 600px) {
  padding-bottom: 0;
  & .c-cta-wrapper{
    position: static;
    transform: translate(0);
    justify-content: flex-start;
    margin-top: 1rem;
  }
}  
}

.at-product .c-ttl-g{
  display: flex;
  flex-direction: column;
  align-items: center;
  & > *{
    font-weight: bold;
  }
  & > h3{
    font-size: 150%;
  }
@container pg-container-wrapper (max-width: 600px) {
  align-items: flex-start;
}  
}

.at-product .c-cta-wrapper{
  display: flex;
  align-items: center;
  gap: 1rem;

}

/* モーダル内の記述（製品） */
.at-product .win-modal {
  & .product-detail-list{
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1.5rem 1rem;
    margin-block: 1rem;
 
    & dt{
      height: fit-content;
      padding-block: .25rem;
      padding-inline: 1rem;
      border-radius: .5rem;
      background-color: var(--color-gray);
      color: var(--color-white);
      text-align: center;
    }

    & dd{
      padding-block: .25rem;
    }
  }

  & figure{
    max-width: 300px;
    margin-inline: auto;
    margin-block: .5rem 1rem;
  }

  & .el-disc-list + .paragraph{
    margin-top: .25rem;
  }

  & .el-btn-cta{
    min-width: 50%;
    margin-inline: auto;
    margin-top: 2rem;
  }

@container pg-container-wrapper (max-width: 600px) {
  & .product-detail-list{
    grid-template-columns: 100%;
    gap: 0;

    & dt{
      text-align: left;
    }
    & dd{
      padding-bottom: 2rem;
    }
  }
}  
}

  /* PCソフトウェア */
  .sec-pcsoft .unit-box{
    display: flex;
    flex-direction: row;
    justify-content: center;
    margin-block: 3rem;
  @container pg-container-wrapper (max-width: 680px) {
    flex-direction: column;
    max-width: 450px;
    margin-inline: auto;
  }
  }

  .sec-pcsoft .product-header-wrapper{
    position: relative;
    display: flex;
    align-items: center;
    background: url("../img/product/pcs-biasx-image.jpg") no-repeat center / cover;
    width: 600px;
    max-width: calc(100% - 300px);

    &::before{
      content: "";
      position: absolute;
      z-index: 0;
      inset: 0;
      display: block;
      background-color: #ffffffdd;
    }

    & .c-product-header{
      position: relative;
      z-index: 1;
      display: flex;
      flex-direction: column;
      gap: 2rem;
      padding-inline: var(--space-inline);
      padding-block: 2rem;
    }
    @container pg-container-wrapper (max-width: 680px) {
      width: 100%;
      max-width: 100%;
    }
  }

  .sec-pcsoft .c-ttl-g{
    align-items: flex-start;
    color: var(--color-black);
  }

  .sec-pcsoft .image-block{
    width: 300px;
    max-width: calc(50% - 1.5rem);

  @container pg-container-wrapper (max-width: 680px) {
    width: 100%;
    max-width: 100%;
  }
  }

  .sec-pcsoft .win-modal{
    & .c-catchcopy{
      margin-block: 1rem;
    }
  }

  /* アプリ */
  .sec-appli .unit-box{
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 1rem 0;
    width: fit-content;
    margin-inline: auto;
    margin-block: 3rem;
  @container pg-container-wrapper (max-width: 600px) {
    flex-direction: column;
  }
  }

  .sec-appli .image-block{
    width: 300px;
  @container pg-container-wrapper (max-width: 768px) {
    width: 220px;
  }
  }

  .sec-appli .cta-block-wrapper{
    display: flex;
    flex-direction: column-reverse;
    gap: 2.5rem;
    flex: 1;
    max-width: 600px;
    padding-inline: var(--space-inline);
    padding-block: 2rem;
    & .el-btn-cta{
      width: 100%;
    }
  @container pg-container-wrapper (max-width: 414px) {
    gap: 1.5rem;
  }
  }

  .sec-appli .cta-block{
    display: flex;
    gap: 1.5rem;
    max-width: 400px;
    margin-inline: auto;
  }

  .sec-appli .product-detail-list + .cta-block{
    margin-block: 2rem;
  }

  /* デスクトップ＆ホーム用アンプ */
 .sec-damp .c-item-list {
    --cols: 3;
  @container pg-container-wrapper (max-width: 950px) {
    --cols: 2;
  }
  }

  /* ヘッドフォンアンプ */
 .sec-hamp .c-item-list { --cols: 2; }

  /* ライブ＆アウトドア用アンプ */
  .sec-oamp .c-item-list { --cols: 2; }


  /* 周辺機器・アクセサリー */
  .sec-acc .c-item-list{
    --cols: 4;
    --item-width: 220px;
    --item-gap: 2rem;

    & .c-ttl-g{
      font-size: 90%;
    }

    & .c-cta-wrapper{
      font-size: 70%!important;
    }
  @container pg-container-wrapper (max-width: 1024px) {
    --cols: 3;
  }
  @container pg-container-wrapper (max-width: 768px) {
    --cols: 2;
    --item-width: 260px;
  }
  @container pg-container-wrapper (max-width: 600px) {
    & .c-ttl-g{
      font-size: 100%;
    }

    & .c-cta-wrapper{
      font-size: 85%!important;
    }
  }
  }
  


/* ランキング -------------------- */
.pg-container .sec-ranking{
  background-color: var(--color-accent);
  padding-block: 4rem 5rem;
  margin-top: 4rem;
}

/* 1 ~ 2位 */
.sec-ranking .rankingtop-list{
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-block: 2rem;
  & > li{
    display: flex;
  }
  & .el-btn-cta{
    height: fit-content;
    margin-block: auto;
  }
@container pg-container-wrapper (max-width: 414px) {
  & > li{
    flex-direction: column;
    align-items: center;
  }
}
}

.sec-ranking .text-block{
  flex: 1;
  padding-inline: var(--space-inline);
  padding-block: 2rem;
@container pg-container-wrapper (max-width: 414px) {
  padding-inline: 0;
  padding-block: .5rem;
  margin-block: 2rem;
}
}

.sec-ranking .ttl-block-wrapper{
  display: flex;
  gap: 1rem 1.5rem;
  margin-bottom: 1.5rem;
@container pg-container-wrapper (max-width: 600px) {
  flex-direction: column;
}
@container pg-container-wrapper (max-width: 414px) {
  flex-direction: row;
  width: fit-content;
  margin-inline: auto;
}  
}

.sec-ranking .catch{
  font-size: 150%;
@container pg-container-wrapper (max-width: 600px) {
  font-size: 112%;
}
}

.sec-ranking .review-list{
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-left: calc(2rem / 2);
  margin-top: .5rem;
  & > li{
    position: relative;
    margin-top: calc(2rem / 2);
    padding-block: 1rem .75rem;
    padding-inline: 1rem .75rem;
    border-radius: .5rem;
    background-color: var(--color-white);
    font-size: 85%;
    &::before{
      content: "";
      position: absolute;
      top: .25rem;
      left: .25rem;
      transform: translate(-50%, -50%);
      display: block;
      width: 2.2rem;
      aspect-ratio: 1/1;
      background: url("../img/assets/ico-reviewer.png") no-repeat center / contain;
    }
  }
}

/* 3 ~ 5位 */
.sec-ranking .rankingsub-list{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  max-width: calc(300px * 3 + 2rem * 2);
  margin-inline: auto;
  & > li{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
  }
@container pg-container-wrapper (max-width: 980px) {
  grid-template-columns: 100%;
  & > li{
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: repeat(2, 1fr);
  }

  & .image-block{ grid-area: 1 / 1 / 3 / 2; }
  & .ttl-block { 
    grid-area: 1 / 2 / 2 / 3; 
    height: fit-content;
    margin-top: auto;
  }
  & .el-btn-cta { 
    grid-area: 2 / 2 / 3 / 3; 
    height: fit-content;
    margin-bottom: auto;
  }
}
}

/* 1 ~ 5位 共通 */
.sec-ranking .image-block{
  display: grid;
  place-items: center;
  width: 300px;
  max-width: 100%;
  aspect-ratio: 1/1;
  background-color: var(--color-white);
@container pg-container-wrapper (max-width: 768px) {
  width: 200px;
}
@container pg-container-wrapper (max-width: 600px) {
  width: 150px;
}
}

.sec-ranking .ttl-block{
  display: flex;
  gap: 0 .5rem;
  align-items: baseline;
  font-weight: bold;
  & > span:nth-child(1){font-size: 125%;}
  & > span:nth-child(2){font-size: 150%;}
@container pg-container-wrapper (max-width: 450px) {
  flex-direction: column;
}
}

/* PG製品一覧へ -------------------- */
.sec-cta .el-btn-cta{
  margin-inline: auto;
  margin-block: 2rem;
  font-size: 150%;
@container pg-container-wrapper (max-width: 600px) {
  font-size: 125%;
}
}

/* MOVIE -------------------- */
.sec-movie .movie-container{
  margin-top: 1rem;
  & + .movie-container{
    margin-top: 3rem;
  }
}

.sec-movie .sub-heading{
  margin-bottom: 1rem;
  padding-block: .25rem;
  padding-inline: 1rem;
  background-color: var(--color-pantone-red);
  color: var(--color-white);
  font-size: 125%;
}

.sec-movie .movie-list{
  padding-bottom: 3rem;
  & > li{
    width: 80%;
    max-width: 320px;
  }
}

.sec-movie .ttl{
  margin-top: .5rem;
}
