@charset "UTF-8";
.product-list .maker-logo {
  border-radius: 0.31vw;
  /*height: ;*/
  -o-object-fit: cover;
     object-fit: cover;
  /*position: absolute;*/
  width: auto;
  max-height: 100%;
}

.product-list .maker-logo-col {
  flex: 0 0 auto;
  /* flex-grow, flex-shrink, flex-basis */
  width: 15%;
  /* 好きな幅に設定 */
  height: 100%;
}

.product-list .product-name-col {
  flex: 0 0 auto;
  /* flex-grow, flex-shrink, flex-basis */
  width: 60%;
  /* 好きな幅に設定 */
  display: none !important;
}

.product-list .applications-col {
  flex: 0 0 auto;
  /* flex-grow, flex-shrink, flex-basis */
  width: 12.5%;
  /* 好きな幅に設定 */
  background-color: var(--chestnut);
  height: auto;
}

.product-list .applications-number-col {
  flex: 0 0 auto;
  /* flex-grow, flex-shrink, flex-basis */
  width: 12.5%;
  /* 好きな幅に設定 */
}

.product-list .card {
  background-color: var(--white);
  border: 2px solid;
  border-color: var(--chestnut);
  border-radius: 10px;
  box-shadow: 0vw 0.23vw 0.47vw rgba(0, 0, 0, 0.1607843137);
}

.product-list .reddish-brown-border {
  border-bottom: 1px solid var(--chestnut);
  /* ラインの太さと色を指定 */
}

.product-list .discount-icon {
  background-image: url("/img/discount-icon.png");
  background-size: cover;
  background-position: center;
  width: 80%;
}

.product-list .position-relative {
  position: relative;
}

.product-list .text-on-image {
  line-height: 1;
}

.product-list .title {
  font-size: 2.35rem;
}

.product-list .current-price-icon {
  background-color: var(--chestnut);
  border-radius: 0.23vw;
}

.product-list .current-price {
  color: var(--text-strong-color);
  font-style: normal;
  font-weight: 700;
}

.product-list .special-deals-border {
  border: 2px solid;
  border-color: var(--chestnut);
  border-radius: 10px;
}

.product-list .special-deals-background {
  background-color: var(--chablis);
  border-radius: 10px 0 0 10px;
  color: var(--chestnut);
  font-size: 110%;
  font-style: normal;
  font-weight: 500;
}

.product-list .special-deals-progress {
  background-color: var(--chablis);
  border: 1px solid;
  border-color: var(--chestnut);
  border-radius: 3px;
}

.product-list .special-deals-progress-bar {
  background: linear-gradient(180deg, #de4e52 0%, #bf4347 100%);
}

.product-list .normal-price {
  font-size: 12px;
}

.product-list .product-image {
  background-size: cover;
  /* 画像を余白なくカバーするように調整 */
  background-position: center;
  /* 画像を中央に配置 */
  width: 100%;
  height: 100%;
}

.product-list .btn-product {
  background: #FFFFFF;
  border-radius: 5px;
  height: 100%;
  /*position: absolute;*/
  width: 100%;
}

.product-list .btn-quotation {
  background: #222222;
  border-radius: 5px;
  height: 100%;
  width: 100%;
}

.product-list .product-item {
  min-height: 35px;
}

.product-list .number-of-applications {
  display: flex;
  align-items: center;
}

.product-list .product-name-size {
  display: flex;
  align-items: center;
}

.price-description {
  font-size: min(var(--h5-font-size), 20px) !important;
}

@media screen and (max-width: 767px) {
  .price-description {
    font-size: max(var(--h5-font-size-sp), 18px) !important;
  }
}
@media screen and (max-width: 575px) {
  .product-list .product-image {
    background-size: contain;
    /* 画像を余白なくカバーするように調整 */
    background-position: center;
    /* 画像を中央に配置 */
    width: 100%;
    height: 100%;
    aspect-ratio: 16/12;
    background-repeat: no-repeat;
  }
  .product-list .maker-logo-col {
    width: 55%;
    padding: 7px 13%;
  }
  .product-list .applications-col {
    width: 24%;
  }
  .product-list .applications-number-col {
    width: 21%;
  }
  .product-list .current-price {
    font-size: 10vw;
    padding-right: 0;
    padding-left: 0;
    width: -moz-fit-content;
    width: fit-content;
  }
  .product-list .btn-quotation {
    padding-top: 3.5vw;
    padding-bottom: 3.5vw;
    width: 50%;
  }
  .product-list .btn-product {
    padding-top: 3.5vw;
    padding-bottom: 3.5vw;
    width: 35%;
    margin-right: 3%;
  }
  .product-list .product-container {
    margin-right: 0%;
    margin-left: 0%;
  }
  .product-list .current-price-icon {
    background-color: var(--chestnut);
    border-radius: 0.23vw;
    font-size: 3vw;
  }
  .product-list .normal-price {
    font-size: 3vw;
  }
  .product-list .text-on-image {
    font-size: 6vw;
  }
  .product-list .product-off {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 17vw;
  }
  .product-list .price {
    font-size: 2vw !important;
  }
  .product-list .special-deals-background {
    font-size: 4vw;
    white-space: nowrap;
  }
  .product-list .product-item {
    height: 10vw;
  }
  .product-list .product-sm-name-col {
    width: 100%;
    padding: 1em 1em 0;
  }
  .product-list .tax-size {
    font-size: 6vw !important;
  }
  .product-list .text-size {
    font-size: 3vw;
  }
  .product-list .details {
    font-size: 4vw;
  }
  .product-list .estimate-request {
    font-size: 4vw;
  }
  .product-list .number-of-applications {
    font-size: 4vw !important;
  }
  .product-list .number-of-households {
    font-size: 4vw !important;
  }
  .product-list .applications-col {
    height: clamp(35px, 10vw, 80px);
  }
}
@media screen and (min-width: 576px) and (max-width: 767px) {
  .product-list .product-image {
    background-size: contain;
    /* 画像を余白なくカバーするように調整 */
    background-position: center;
    /* 画像を中央に配置 */
    width: 100%;
    height: 100%;
    aspect-ratio: 16/12;
    background-repeat: no-repeat;
  }
  .product-list .maker-logo-col {
    width: 55%;
    padding: 7px 13%;
  }
  .product-list .applications-col {
    width: 24%;
  }
  .product-list .applications-number-col {
    width: 21%;
  }
  .product-list .current-price {
    font-size: 10vw;
    padding-right: 0;
    padding-left: 0;
    width: -moz-fit-content;
    width: fit-content;
  }
  .product-list .btn-quotation {
    padding-top: 3.5vw;
    padding-bottom: 3.5vw;
    width: 50%;
  }
  .product-list .btn-product {
    padding-top: 3.5vw;
    padding-bottom: 3.5vw;
    width: 35%;
    margin-right: 3%;
  }
  .product-list .product-container {
    margin-right: 0%;
    margin-left: 0%;
  }
  .product-list .current-price-icon {
    background-color: var(--chestnut);
    border-radius: 0.23vw;
    font-size: 3vw;
  }
  .product-list .normal-price {
    font-size: 3vw;
  }
  .product-list .text-on-image {
    font-size: 6vw;
  }
  .product-list .product-off {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 17vw;
  }
  .product-list .price {
    font-size: 2vw !important;
  }
  .product-list .product-item {
    height: 10vw;
  }
  .product-list .product-sm-name-col {
    width: 100%;
    padding: 1em 1em 0;
  }
  .product-list .tax-size {
    font-size: 6vw !important;
  }
  .product-list .text-size {
    font-size: 3vw;
  }
  .product-list .details {
    font-size: 4vw;
  }
  .product-list .estimate-request {
    font-size: 4vw;
  }
  .product-list .number-of-applications {
    font-size: 4vw !important;
  }
  .product-list .number-of-households {
    font-size: 4vw !important;
  }
  .product-list .special-deals-background {
    font-size: 4vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  /*　for iPad 　*/
  .product-list .normal-price {
    font-size: 0.75rem;
  }
  .product-list .current-price {
    font-size: 5vw;
  }
  .product-list .product-image {
    background-size: contain;
    /* 画像を余白なくカバーするように調整 */
    background-position: center;
    /* 画像を中央に配置 */
    width: 100%;
    height: 100%;
    aspect-ratio: 16/12;
    background-repeat: no-repeat;
  }
  .product-list .normal-price {
    white-space: nowrap;
  }
  .product-list .image-size {
    position: relative;
    left: 12px;
  }
  .product-list .text-on-image {
    font-size: 3vw;
  }
  .product-list .circle-size {
    padding-left: 15px;
    padding-right: 15px;
  }
  .product-list .maker-logo {
    width: 100%;
  }
  .product-list .product-name-col {
    display: flex !important;
  }
  .product-list .product-name-size {
    font-size: min(2vw, 20px) !important;
  }
  .product-list .product-off {
    width: 12.5vw;
  }
  .product-list .special-deals-background {
    font-size: 2vw;
  }
  .product-list .maker-logo-col {
    min-height: 35px;
    height: auto;
  }
}
@media screen and (min-width: 992px) and (max-width: 1199px) {
  .product-list .current-price {
    font-size: 340%;
  }
  .product-list .normal-price {
    font-size: 0.7rem;
  }
  .product-list .text-on-image {
    font-size: 200%;
    top: 47% !important;
  }
  .product-list .product-image {
    background-size: contain;
    /* 画像を余白なくカバーするように調整 */
    background-position: center;
    /* 画像を中央に配置 */
    width: 100%;
    height: 100%;
    aspect-ratio: 16/12;
    background-repeat: no-repeat;
  }
  .product-list .maker-logo {
    width: 100%;
  }
  .product-list .product-name-col {
    display: flex !important;
  }
  .product-list .product-name-size {
    font-size: min(2vw, 25px) !important;
  }
  .product-list .maker-logo-col {
    min-height: 35px;
    height: auto;
  }
  .product-list .number-of-households {
    font-size: min(2vw, 20px) !important;
  }
}
@media screen and (min-width: 1200px) and (max-width: 1399px) {
  /*　for PC　*/
  .product-list .current-price {
    font-size: 380%;
  }
  .product-list .normal-price {
    font-size: 0.9rem;
  }
  .product-list .product-image {
    background-size: contain;
    background-position: center;
    width: 100%;
    height: 100%;
    aspect-ratio: 16/12;
    background-repeat: no-repeat;
  }
  .product-list .maker-logo {
    width: 100%;
  }
  .product-list .product-name-col {
    display: flex !important;
  }
  .product-list .text-on-image {
    font-size: 220%;
  }
  .product-list .product-name-size {
    font-size: min(3vw, 25px) !important;
  }
  .product-list .product-item {
    min-height: 40px;
  }
  .product-list .maker-logo-col {
    min-height: 40px;
    height: auto;
  }
  .product-list .number-of-households {
    font-size: min(1.5vw, 25px) !important;
  }
}
@media screen and (min-width: 1400px) {
  /*　for PC　*/
  .product-list .current-price {
    font-size: 400%;
  }
  .product-list .normal-price {
    font-size: 1rem;
  }
  .product-list .product-image {
    background-size: contain;
    /* 画像を余白なくカバーするように調整 */
    background-position: center;
    /* 画像を中央に配置 */
    width: 100%;
    height: 100%;
    aspect-ratio: 16/12;
    background-repeat: no-repeat;
  }
  .product-list .text-on-image {
    font-size: 220%;
  }
  .product-list .maker-logo {
    width: 100%;
  }
  .product-list .product-name-col {
    display: flex !important;
  }
  .product-list .product-name-size {
    font-size: min(3vw, 25px) !important;
  }
  .product-list .product-item {
    min-height: 50px;
  }
  .product-list .maker-logo-col {
    min-height: 50px;
    height: auto;
  }
  .product-list .number-of-households {
    font-size: min(1.5vw, 25px) !important;
  }
}
