/*

オンラインショップについて
https://www.primaham.co.jp/shop/

*/

.hero-cmn-01.shop {
 margin-bottom: 0;
 background-color: #E60012;
}
.hero-cmn-01.shop .nav-breadcrumb ul li,
.hero-cmn-01.shop .nav-breadcrumb ul li a,
.hero-cmn-01.shop .ttl-cmn-01 .txt-title {
 color: #fff;
}
.hero-cmn-01.shop .ttl-cmn-01 .txt-title {
 position: relative;
 padding-left: 40px;
}
.hero-cmn-01.shop .ttl-cmn-01 .txt-title::before {
 content: "";
 position: absolute;
 top: 3px;
 left: 0;
 width: 29px;
 height: 26px;
 background-image: url(/common/img/shop/icon_shop_cart.svg);
 background-repeat: no-repeat;
 background-size: 100% auto;
}
.hero-cmn-01.shop .ttl-cmn-01 {
}

.contents.shop {
 margin-bottom: 20px;
 padding-top: 42px;
 padding-bottom: 95px;
 background-image: url(/common/img/shop/bg_shop_01.png);
 background-color: #F9F4EB;
 background-size: 270px 270px;
 background-repeat: repeat;
}
.contents.shop img {
 max-width: 100%;
 height: auto;
}
.ttl-shop-01 {
}
.ttl-shop-01 .txt-title {
 position: relative;
 padding-left: 16px;
 font-size: 24px;
 font-weight: 700;
}
.ttl-shop-01 .txt-title::before {
 content: "";
 position: absolute;
 top: 50%;
 left: 0;
 width: 6px;
 height: 1.2em;
 margin-top: -.6em;
 background-color: #E60012;
}
.shop-main {
 margin-top: 28px;
}
.shop-bnr {
 border-radius: 16px;
 overflow: hidden;
}
.shop-bnr .shop-bnr-block {
 display: flex;
 background-color: #fff;
 transition: all 0.3s ease;
}
.shop-bnr a.shop-bnr-block:hover {
 opacity: 0.8;
}
.shop-bnr .shop-bnr-block .shop-bnr-img {
 width: 648px;
}
.shop-bnr .shop-bnr-block .shop-bnr-detail {
 display: flex;
 flex-direction: column;
 flex: 1;
}
.shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-text {
 padding: 46px 32px 40px;
 font-size: 16px;
 line-height: 2;
}
.shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link {
 text-align: right;
 padding-right: 25px;
}
.shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span {
 position: relative;
 display: inline-block;
 font-weight: 700;
 font-size: 14px;
 padding: 0 22px 0 20px;
}
.shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span::before,
.shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span::after {
 content: "";
 position: absolute;
 top: 50%;
 background-size: auto 100%;
 background-repeat: no-repeat;
}
.shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span::before {
 left: 0;
 width: 12px;
 height: 12px;
 margin-top: -6px;
 background-image: url(/common/img/link_blank.svg);
}
.shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span::after {
 right: 0;
 width: 8px;
 height: 12px;
 margin-top: -6px;
 background-image: url(/common/img/arrow_red.svg);
}
.shop-intro {
 margin-top: 40px;
 padding: 20px 30px 40px;
 background-color: #fff;
}
.shop-intro .ttl-shop-intro {}
.shop-intro .ttl-shop-intro > .txt-title {
 font-size: 18px;
 font-weight: 700;
}
.shop-intro .shop-intro-list {
 margin-top: 15px;
 gap: 35px;
 display: flex;
 flex-wrap: wrap;
 align-items: center;
}
.shop-intro .shop-intro-list > li {
 width: calc((100% - 35px) / 2);
}
.shop-intro .shop-intro-block {
 display: flex;
 gap: 20px;
 align-items: center;
 transition: all 0.3s ease;
}
.shop-intro a.shop-intro-block:hover {
 opacity: 0.8;
}
.shop-intro .shop-intro-block .shop-intro-img {
 width: 220px;
}
.shop-intro .shop-intro-block .shop-intro-detail {
 flex: 1;
 font-size: 14px;
}

.shop-other {
 margin-top: 55px;
}
.shop-other .shop-other-text {
 margin-top: 24px;
 font-size: 16px;
}
.shop-other .shop-other-bnr {
 display: flex;
 margin-top: 30px;
 gap: 20px;
 flex-wrap: wrap;
 align-items: center;
 justify-content: center;
}
.shop-other .shop-other-bnr > li {
 width: calc((100% - 40px) / 3);
}
.shop-other .shop-other-block {
 display: block;
 transition: all 0.3s ease;
}
.shop-other a.shop-other-block:hover {
 opacity: 0.8;
}
.shop-other .shop-other-block .shop-other-detail {
 margin-top: 10px;
}
.shop-other .shop-other-block .shop-other-detail .shop-other-link {
}
.shop-other .shop-other-block .shop-other-detail .shop-other-link > span {
 position: relative;
 display: inline-block;
 font-weight: 700;
 font-size: 14px;
 padding: 0 16px 0 20px;
}
.shop-other .shop-other-block .shop-other-detail .shop-other-link > span::before,
.shop-other .shop-other-block .shop-other-detail .shop-other-link > span::after {
 content: "";
 position: absolute;
 top: 50%;
 background-size: auto 100%;
 background-repeat: no-repeat;
}
.shop-other .shop-other-block .shop-other-detail .shop-other-link > span::before {
 left: 0;
 width: 12px;
 height: 12px;
 margin-top: -6px;
 background-image: url(/common/img/link_blank.svg);
}
.shop-other .shop-other-block .shop-other-detail .shop-other-link > span::after {
 right: 0;
 width: 8px;
 height: 12px;
 margin-top: -6px;
 background-image: url(/common/img/arrow_red.svg);
}

@media screen and (max-width:768px) {
 .hero-cmn-01.shop {
  margin-bottom: 0;
 }
 .hero-cmn-01.shop .bg-img,
 .hero-cmn-01.shop .container {
  height: calc((102 / 375) * 100vw);
 }
 .hero-cmn-01 .nav-breadcrumb {
  margin-bottom: calc((7 / 375) * 100vw);
 }
 .hero-cmn-01.shop .ttl-cmn-01 .txt-title {
  padding-left: calc((40 / 375) * 100vw);
 }
 .hero-cmn-01.shop .ttl-cmn-01 .txt-title::before {
  top: calc((3 / 375) * 100vw);
  width: calc((29 / 375) * 100vw);
  height: calc((26 / 375) * 100vw);
 }
 .contents.shop {
  margin-bottom: 20px;
  padding-top: calc((36 / 375) * 100vw);
  padding-bottom: 95px;
  background-image: url(/common/img/shop/bg_shop_01.png);
  background-color: #F9F4EB;
  background-size: 270px 270px;
  background-repeat: repeat;
 }
 .ttl-shop-01 .txt-title {
  padding-left: calc((16 / 375) * 100vw);
  font-size: calc((20 / 375) * 100vw);
 }
 .ttl-shop-01 .txt-title::before {
  width: calc((6 / 375) * 100vw);
 }
 .shop-main {
  margin-top: calc((20 / 375) * 100vw);
 }
 .shop-bnr {
  border-radius: calc((16 / 375) * 100vw);
 }
 .shop-bnr .shop-bnr-block {
  position: relative;
  padding-bottom: calc((20 / 375) * 100vw);
  flex-direction: column;
 }
 .shop-bnr .shop-bnr-block::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  pointer-events: none;
  border: 1px solid #D1D1D1;
  border-radius: calc((16 / 375) * 100vw);
 }
 .shop-bnr .shop-bnr-block .shop-bnr-img {
  width: 100%;
 }
 .shop-bnr .shop-bnr-block .shop-bnr-detail {
  display: flex;
  flex-direction: column;
 }
 .shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-text {
  padding: calc((18 / 375) * 100vw) calc((20 / 375) * 100vw) calc((10 / 375) * 100vw);
  font-size: calc((15 / 375) * 100vw);
  line-height: 1.66;
 }
 .shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link {
  text-align: right;
  padding-right: calc((20 / 375) * 100vw);
 }
 .shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span {
  position: relative;
  display: inline-block;
  font-weight: 700;
  font-size: calc((14 / 375) * 100vw);
  padding: 0 calc((16 / 375) * 100vw) 0 calc((20 / 375) * 100vw);
 }
 .shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span::before,
 .shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span::after {
  content: "";
  position: absolute;
  top: 50%;
  background-size: auto 100%;
  background-repeat: no-repeat;
 }
 .shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span::before {
  width: calc((12 / 375) * 100vw);
  height: calc((12 / 375) * 100vw);
  margin-top: calc((-6 / 375) * 100vw);
 }
 .shop-bnr .shop-bnr-block .shop-bnr-detail .shop-bnr-link > span::after {
  width: calc((8 / 375) * 100vw);
  height: calc((12 / 375) * 100vw);
  margin-top: calc((-6 / 375) * 100vw);
 }
 .shop-intro {
  width: auto;
  margin: calc((25 / 375) * 100vw) -10px 0;
  padding: calc((30 / 375) * 100vw) calc((20 / 375) * 100vw) calc((40 / 375) * 100vw);
 }
 .shop-intro .ttl-shop-intro {}
 .shop-intro .ttl-shop-intro > .txt-title {
  font-size: calc((18 / 375) * 100vw);
 }
 .shop-intro .shop-intro-list {
  margin-top: calc((15 / 375) * 100vw);
  gap: calc((30 / 375) * 100vw);
  display: flex;
  flex-direction: column;
 }
 .shop-intro .shop-intro-list > li {
  width: 100%;
 }
 .shop-intro .shop-intro-block {
  display: flex;
  gap: calc((14 / 375) * 100vw);
  flex-direction: column;
  align-items: center;
 }
 .shop-intro .shop-intro-block .shop-intro-img {
  width: 100%;
 }
 .shop-intro .shop-intro-block .shop-intro-detail {
  flex: 1;
  font-size: calc((14 / 375) * 100vw);
  line-height: 1.6;
 }
 .shop-other {
  margin-top: calc((55 / 375) * 100vw);
  padding: 0 13px;
 }
 .shop-other .shop-other-text {
  margin-top: calc((20 / 375) * 100vw);
  font-size: calc((15 / 375) * 100vw);
  line-height: 1.6;
 }
 .shop-other .shop-other-bnr {
  display: flex;
  margin-top: calc((24 / 375) * 100vw);
  gap: calc((24 / 375) * 100vw);
  flex-wrap: wrap;
 }
 .shop-other .shop-other-bnr > li {
  width: 100%;
 }
 .shop-other .shop-other-block .shop-other-detail {
  margin-top: calc((4 / 375) * 100vw);
 }
 .shop-other .shop-other-block .shop-other-detail .shop-other-link {
 }
 .shop-other .shop-other-block .shop-other-detail .shop-other-link > span {
  font-size: calc((14 / 375) * 100vw);
  padding: 0 calc((16 / 375) * 100vw) 0 calc((20 / 375) * 100vw);
 }
 .shop-other .shop-other-block .shop-other-detail .shop-other-link > span::before {
  width: calc((12 / 375) * 100vw);
  height: calc((12 / 375) * 100vw);
  margin-top: calc((-6 / 375) * 100vw);
 }
 .shop-other .shop-other-block .shop-other-detail .shop-other-link > span::after {
  width: calc((8 / 375) * 100vw);
  height: calc((12 / 375) * 100vw);
  margin-top: calc((-6 / 375) * 100vw);
 }
}