@media screen and (min-width: 1024px) {
  .visible-md, .visible-sm {
    display: none;
  }
  .visible-lg {
    display: inherit;
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .visible-lg, .visible-sm {
    display: none;
  }
  .visible-md {
    display: inherit;
  }
}
@media screen and (max-width: 749px) {
  .visible-lg, .visible-md {
    display: none;
  }
  .visible-sm {
    display: inherit;
  }
}
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: rgba(0, 0, 0, 0);
}
* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  line-height: 1.5;
}
@media screen and (min-width: 750px) {
  html {
    font-size: 10px;
  }
}
@media screen and (max-width: 749px) {
  html {
    font-size: 2.66666vw;
  }
}
body {
  width: 100%;
  overflow-x: hidden;
  background: #fff;
  font-family: "Noto Serif JP", YuGothic, "Yu Gothic", "Hiragino Kaku Gothic ProN", "ãƒ’ãƒ©ã‚®ãƒŽè§’ã‚´ ProN W3", sans-serif;
  color: #333;
}
main {
  display: block;
}
li {
  list-style-type: none;
}
a {
  text-decoration: none;
  color: inherit;
}
@media screen and (min-width: 750px) {
  a {
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  a::before, a::after {
    -webkit-transition: all .3s;
    transition: all .3s;
  }
}
img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}
svg {
  width: 100%;
  height: auto;
}
sup {
  font-size: .5em;
  vertical-align: super;
}
input, button, textarea, select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
}
address {
  font-style: normal;
}
html, body {
  overflow-x: hidden;
}
@media screen and (min-width: 750px) {
  .l-inner-lg {
    width: 90%;
    max-width: 1400px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 749px) {
  .l-inner-lg {
    padding: 0 1.5rem;
  }
}
@media screen and (min-width: 750px) {
  .l-inner {
    width: 90%;
    max-width: 1100px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 749px) {
  .l-inner {
    padding: 0 1.5rem;
  }
}
@media screen and (min-width: 750px) {
  .l-inner-ex {
    width: 90%;
    max-width: 1100px;
    margin: 0 auto;
  }
}
@media screen and (min-width: 750px) {
  .l-inner-sm {
    width: 90%;
    max-width: 920px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 749px) {
  .l-inner-sm {
    padding: 0 1.5rem;
  }
}
.footer {
  background: #4c4c4e;
  color: #fff;
}
@media screen and (min-width: 750px) {
  .footer {
    padding: 8rem 0;
  }
}
@media screen and (max-width: 749px) {
  .footer {
    padding: 4rem 0;
  }
}
.footerSns__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media screen and (min-width: 750px) {
  .footerSns__list {
    gap: 4rem;
  }
}
@media screen and (max-width: 749px) {
  .footerSns__list {
    gap: 2rem;
  }
}
.footerSns__img {
  width: 1.8rem;
}
.footerLogo {
  text-align: center;
}
@media screen and (min-width: 750px) {
  .footerLogo {
    margin: 4rem 0;
  }
}
@media screen and (max-width: 749px) {
  .footerLogo {
    margin: 2.5rem 0;
  }
}
.footerSns__link:hover, .footerLogo__link:hover {
  opacity: .7;
}
.footerLogo__img {
  width: 18rem;
}
.footerCopyright {
  text-align: center;
  font-size: 1.2rem;
}
/*
 header_logo
-------------------------------------------------- */
@media only screen and (max-width: 599px) {
    .header_logo {
        width: 35%;
        position: absolute;
        top: 2.5%;
        left: 17px;
        z-index: 2;
    }
}
@media only screen and (min-width: 600px) and (max-width: 1024px) {
    .header_logo {
        width: 22%;
        position: absolute;
        top: 3%;
        left: 24px;
        z-index: 2;
    }
}
@media only screen and (min-width: 1025px) {
    .header_logo {
        width: 10%;
        position: absolute;
        top: 3%;
        left: 27px;
      z-index: 2;
    }
}



@media screen and (min-width: 1024px) {
  .product__row {
    gap: 7rem
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .product__row {
    gap: 3rem
  }
}
@media screen and (min-width: 750px) {
  .product__row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
}
.product__col {
  display: block
}
@media screen and (min-width: 1024px) {
  .product__col {
    width: calc((100% - 14rem)/3)
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .product__col {
    width: calc((100% - 6rem)/3)
  }
  .-product-sm .product__col {
    width: calc((100% - 6rem)/2)
  }
}
@media screen and (min-width: 1024px) {
  .product__col:hover .productThumb__img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1)
  }
  .product__col:hover .productThumb__head {
    -webkit-transform: translateY(-1rem);
    transform: translateY(-1rem)
  }
  .product__col:hover .productThumb::after {
    bottom: 1rem
  }
}
@media screen and (max-width: 749px) {
  .product__col + .product__col {
    margin-top: 4.5rem
  }
}
.productThumb {
  position: relative;
  overflow: hidden
}
@media screen and (max-width: 749px) {
  .productThumb {
    max-width: 27rem;
    margin: 0 auto
  }
}
.productThumb::after {
   content: "";
  display: block;
  font-family: "icomoon" !important;
  font-size: 4rem;
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  -webkit-transition: all .3s;
  transition: all .3s;
  line-height: 1
}
@media screen and (min-width: 1024px) {
  .productThumb::after {
    bottom: 3rem
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .productThumb::after {
    bottom: 1rem
  }
}
@media screen and (max-width: 749px) {
  .productThumb::after {
    bottom: 1.5rem
  }
}
@media screen and (min-width: 750px) {
  .-product-sm .productThumb::after {
    bottom: 2rem
  }
}
.productThumb::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  border-bottom: 4rem solid rgba(0, 0, 0, 0)
}
.productThumb.regalia::before {
  border-left: 4rem solid #112e53
}
.productThumb.regalia-gold::before {
  border-left: 4rem solid #be9349
}
.productThumb.regalia-platinum::before {
  border-left: 4rem solid #a6aeb5
}
.productThumb.emotion-v::before, .productThumb.the-granregalia::before {
  border-left: 4rem solid #656565
}
.productThumb__img {
  -webkit-transition: all .3s;
  transition: all .3s;
  width: 100%
}
.productThumb__head {
  position: absolute;
  left: 0;
  right: 0;
  text-align: center;
  z-index: 1;
  -webkit-transition: -webkit-transform .3s;
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s
}
@media screen and (min-width: 1024px) {
  .productThumb__head {
    top: 3.5rem
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .productThumb__head {
    top: 2rem
  }
}
@media screen and (max-width: 749px) {
  .productThumb__head {
    top: 3.5rem
  }
}
@media screen and (min-width: 750px) {
  .-product-sm .productThumb__head {
    top: 2.5rem
  }
}
@media screen and (min-width: 750px) {
  .productThumb__en__img {
    height: 2.4rem
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .productThumb__en__img {
    height: 1.8rem
  }
}
@media screen and (max-width: 749px) {
  .productThumb__en__img {
    height: 1.5rem
  }
}
@media screen and (min-width: 750px) {
  .-product-sm .productThumb__en__img {
    height: 1.7rem
  }
}
@media screen and (min-width: 750px) {
  .productThumb__jp {
    font-size: 1.6rem
  }
}
@media screen and (max-width: 749px) {
  .productThumb__jp {
    font-size: 1.4rem
  }
}
@media screen and (min-width: 750px) {
  .-product-sm .productThumb__jp {
    font-size: 1.4rem
  }
}
.productThumb__en + .productThumb__jp {
  margin-top: 1rem
}
.productThumb__jp::after {
  content: "";
  display: block;
  width: 2.6rem;
  height: 1px;
  background: #333;
  margin: 1rem auto 0
}
@media screen and (min-width: 750px) {
  .productHead {
    font-size: 1.8rem;
    margin: 2rem 0
  }
}
@media screen and (max-width: 749px) {
  .productHead {
    font-size: 1.6rem;
    margin: 1.5rem 0
  }
}
.productHead__jp {
  font-weight: normal
}
@media screen and (min-width: 750px) {
  .productHead__jp {
    margin: .2rem 0
  }
}
.product__tags {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 2rem
}
@media screen and (min-width: 1024px) {
  .product__tags {
    font-size: 1.4rem
  }
}
@media screen and (max-width: 1023px) {
  .product__tags {
    font-size: 1.2rem
  }
}
@media screen and (min-width: 750px) {
  .product__tags {
    gap: 1rem
  }
}
@media screen and (max-width: 749px) {
  .product__tags {
    gap: .5rem
  }
}
.product__tag {
  background: #777;
  color: #fff;
  border-radius: .5rem;
  text-align: center;
  white-space: nowrap
}
@media screen and (min-width: 750px) {
  .product__tag {
    padding: .3rem 1.5rem
  }
}
@media screen and (max-width: 749px) {
  .product__tag {
    padding: .3rem .7rem
  }
}
.productHead__price .sm {
  font-size: .8em
}
.productHardness {
  border: 1px solid #333;
  border-radius: 3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: .8rem
}
@media screen and (min-width: 1024px) {
  .productHardness {
    font-size: 1.4rem;
    padding: 0 1.7rem
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .productHardness {
    font-size: 1.2rem;
    padding: 0 1.3rem
  }
}
@media screen and (min-width: 750px) {
  .productHardness {
    height: 4rem
  }
}
@media screen and (max-width: 749px) {
  .productHardness {
    height: 3rem;
    font-size: 1.2rem;
    padding: 0 1.5rem
  }
}
.productHardness::before {
  content: "かため"
}
.productHardness::after {
  content: "やわらかめ"
}
.productHardness span {
  height: 1px;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  background: #333;
  position: relative
}
.productHardness span[data-level="0"]::after {
  left: calc(0 * 12.5% - 0.45rem)
}
.productHardness span[data-level="1"]::after {
  left: calc(1 * 12.5% - 0.45rem)
}
.productHardness span[data-level="2"]::after {
  left: calc(2 * 12.5% - 0.45rem)
}
.productHardness span[data-level="3"]::after {
  left: calc(3 * 12.5% - 0.45rem)
}
.productHardness span[data-level="4"]::after {
  left: calc(4 * 12.5% - 0.45rem)
}
.productHardness span[data-level="5"]::after {
  left: calc(5 * 12.5% - 0.45rem)
}
.productHardness span[data-level="6"]::after {
  left: calc(6 * 12.5% - 0.45rem)
}
.productHardness span[data-level="7"]::after {
  left: calc(7 * 12.5% - 0.45rem)
}
.productHardness span[data-level="8"]::after {
  right: 0
}
.productHardness span::after {
  content: "";
  display: block;
  width: .9rem;
  height: .9rem;
  border: 1px solid #333;
  background: #fff;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}
.productLine__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 6rem 0
}
@media screen and (max-width: 1023px) {
  .productLine__list {
    gap: 1rem
  }
}
.productLine {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  padding: 1.5rem;
  -webkit-transition: all .3s;
  transition: all .3s;
  cursor: pointer
}
@media screen and (min-width: 1024px) {
  .productLine {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 0px;
    flex: 1 1 0
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .productLine {
    width: 22rem
  }
}
@media screen and (max-width: 749px) {
  .productLine {
    width: calc(50% - .5rem)
  }
}
@media screen and (max-width: 1023px) {
  .productLine {
    background: rgba(255, 255, 255, .3)
  }
}
.productLine::before, .productLine::after {
  -webkit-transition: all .3s;
  transition: all .3s;
  content: "";
  display: block;
  width: 1.2rem;
  height: 1.2rem;
  width: 0;
  height: 0;
  border-style: solid;
  position: absolute
}
@media screen and (max-width: 1023px) {
  .productLine::before, .productLine::after {
    display: none
  }
}
.productLine::before {
  left: 0;
  top: 0;
  border-width: 12px 12px 0 0;
  border-color: #fff rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0)
}
.productLine::after {
  right: 0;
  bottom: 0;
  border-width: 0 0 12px 12px;
  border-color: rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #fff rgba(0, 0, 0, 0)
}
.productLine:hover {
  background: rgba(255, 255, 255, .3)
}
.productCat__logo {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  min-height: 12rem
}
@media screen and (min-width: 750px) {
  .productCat__logo:not(.-vtop) {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
  }
}
@media screen and (max-width: 749px) {
  .productCat__logo {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
  }
}
@media screen and (max-width: 749px) {
  .productLine__logo__img {
    width: 10rem
  }
}
.productLine__foot {
  margin-top: 1.5rem
}
.productLine__name {
  white-space: nowrap
}
@media screen and (min-width: 750px) {
  .productLine__name {
    font-size: 1.8rem
  }
}
@media screen and (max-width: 749px) {
  .productLine__name {
    font-size: 1.4rem
  }
}
.productLine__more {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: .5rem;
  font-size: 1.2rem;
  margin-top: 2.5rem
}
.productLine__more::before {
  content: "";
  display: block;
  width: 3.4rem;
  height: 3.4rem;
  background-image: url("../img/top/icon_plus.svg");
  background-size: 100%;
  background-repeat: no-repeat
}


/* --------------------------------------------- 
 popup
--------------------------------------------- */
.popup {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  background: rgba(51, 51, 51, .8);
  z-index: 20
}
.popup__inner {
  position: absolute;
  width: 90%;
  max-width: 1100px;
  overflow: hidden;
  max-height: 90vh;
  background: #fff;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column
}
.popup__head {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  background-image: url("../img/top/popup_head.jpg");
  background-size: cover;
  color: #fff
}
@media screen and (min-width: 750px) {
  .popup__head {
    padding: 1.5rem 4rem 1.5rem 3rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
  }
}
@media screen and (max-width: 749px) {
  .popup__head {
    padding: 1.5rem .5rem
  }
}
@media screen and (min-width: 750px) {
  .popup__head__main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    gap: 3rem;
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    margin-right: 3rem
  }
}
.popup__logo {
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column
}
@media screen and (min-width: 750px) {
  .popup__logo {
    height: 100%
  }
}
@media screen and (min-width: 750px) {
  .popup__logo__img {
    width: 10rem
  }
}
@media screen and (max-width: 749px) {
  .popup__logo__img {
    width: 8rem
  }
}
.popup__title {
  display: block;
  margin-top: .8rem
}
@media screen and (min-width: 750px) {
  .popup__title {
    font-size: 1.2rem
  }
}
@media screen and (max-width: 749px) {
  .popup__title {
    font-size: 1rem
  }
}
@media screen and (min-width: 750px) {
  .popup__lead {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 1.6rem;
    line-height: 2
  }
}
@media screen and (max-width: 749px) {
  .popup__lead {
    font-size: 1.2rem;
    text-align: center;
    line-height: 1.8;
    margin-top: 1rem
  }
}
.popup__close {
  cursor: pointer
}
@media screen and (min-width: 750px) {
  .popup__close {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
  }
}
@media screen and (max-width: 749px) {
  .popup__close {
    position: absolute;
    right: 1.5rem;
    top: 1.5rem;
    width: 2.4rem
  }
}
.popup__body {
  overflow: auto;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1
}
@media screen and (min-width: 1024px) {
  .popup__body {
    padding: 6.5rem
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .popup__body {
    padding: 6.5rem
  }
}
@media screen and (max-width: 749px) {
  .popup__body {
    padding: 4rem 1.5rem
  }
}
.popup {
  display: none
}


/* 
 lineup__btn
--------------------------- */
.lineup__btn {
  max-width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border: 2px solid #333;
  font-weight: 500;
  border-radius: 99.9rem;
  position: relative
}
@media screen and (min-width: 750px) {
  .lineup__btn {
    width: 45rem;
    height: 8rem;
    margin: 5rem auto 0;
    font-size: 2.5rem
  }
}
@media screen and (max-width: 749px) {
  .lineup__btn {
    margin-top: 5rem;
    height: 5rem;
    font-size: 1.6rem
  }
}
.lineup__btn::after {
  content: "";
  font-family: "icomoon" !important;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}
@media screen and (min-width: 750px) {
  .lineup__btn::after {
    right: 3rem
  }
}
@media screen and (max-width: 749px) {
  .lineup__btn::after {
    right: 2rem
  }
}
.lineup__btn:hover {
  background: #333;
  color: #fff
}

.lineup__btn_w {
  max-width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border: 2px solid #fff;
  color:#fff;

  font-weight: 500;
  border-radius: 99.9rem;
  position: relative
}
@media screen and (min-width: 750px) {
  .lineup__btn_w {
    width: 45rem;
    height: 8rem;
    margin: 5rem auto 15rem;
    font-size: 2.5rem;
    color:#fff;
  }
}
@media screen and (max-width: 749px) {
  .lineup__btn_w {
    margin-top: 5rem;
    height: 5rem;
    font-size: 1.6rem
  }
}
.lineup__btn_w::after {
  content: "";
  font-family: "icomoon" !important;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}
@media screen and (min-width: 750px) {
  .lineup__btn_w::after {
    right: 3rem
  }
}
@media screen and (max-width: 749px) {
  .lineup__btn_w::after {
    right: 2rem
  }
}
.lineup__btn_w:hover {
  background: rgba(255, 255, 255, .3);
  color: #fff
}
.popup-open {
  overflow: hidden
}
.popup-open body {
  overflow: hidden
}







/*
topProductsplide
--------------------------- */
#topProductsplide .topProductCol {
    display:flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    max-width: 1360px;
    margin: 0 auto;
    gap: 10px;
}
.product_splide__slide {
  height: auto
}
@media screen and (max-width: 599px) {
  .product_splide__slide {
    width: 250px;
    height: auto
  }
}
.swiper-slide.productSwiper__slide {
  width: 24.5rem;
  height: auto
}
.productSlide {
  height: 100%;
  padding: 4rem 2rem 2rem;
  background: #f5f5f5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative
}
.productSlide:hover .productSlide__img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1)
}
.productSlide::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  border-bottom: 4rem solid rgba(0, 0, 0, 0)
}
.productSlide.regalia::before {
  border-left: 4rem solid #112e53
}
.productSlide.regalia-gold::before {
  border-left: 4rem solid #be9349
}
.productSlide.regalia-platinum::before {
  border-left: 4rem solid #a6aeb5
}
.productSlide.emotion-v::before, .productSlide.the-granregalia::before {
  border-left: 4rem solid #656565
}
.productSlide__head {
  text-align: center;
  margin-bottom: 18rem;
  position: relative;
  z-index: 1
}
.productThumb__en__img {
  height: 1.6rem
}
.productSlide__jp {
  font-size: 1.6rem;
  margin-top: 1rem;
  font-weight: 500
}
.productSlide__jp::after {
  content: "";
  display: block;
  height: 1px;
  width: 2rem;
  background: #333;
  margin: 1rem auto 0
}
.productSlide__thumb {
  position: absolute;
  top: 7rem;
  right: 0;
  text-align: right;
  overflow: hidden
}
.productSlide__img {
  height: 23rem;
  -webkit-transition: all .3s;
  transition: all .3s
}
.prodcuctSlide__foot {
  position: relative;
  z-index: 1;
  margin-bottom: 3rem
}
.productSlide__lead {
  font-size: 1.4rem;
  line-height: 1.8;
  margin-bottom: 3rem
}
.productSlide__more {
  font-size: 1.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative
}
.productSlide__more::after {
  content: "";
  font-family: "icomoon" !important;
  position: absolute;
  line-height: 1;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  font-size: 120%
}
@media screen and (max-width: 749px) {
  .lineup__btnarea {
    width: 90%;
    margin: 0 auto
  }
}
.wrapper {
  opacity: 0
}
.pt__vh {
  padding-top: 100vh;
}

.bg-white {
  background: #fff
}

/*
 sec_head 
------------------- */
.sec__head {
  text-align: center;
  padding: 8rem 1.8rem 8rem;
}
.concept .sec__head {
  color: #fff;
  padding-bottom: 0;
}
.products .sec__head {
  color: #fff;
  padding-bottom: 15rem;    
}
@media screen and (max-width: 599px) {
   .concept .sec__head {
    padding: 0 1.5rem 10rem;
  }
   .concept__out .sec__body .sec__head {
     color: #fff;
   }
  .products .sec__head {
    padding: 0 0 10rem;
  }
  .shop .sec__head {
    padding: 3rem 0 0;
  }
}
@media screen and (min-width: 600px) and (max-width: 1024px) {
  
}
@media screen and (min-width: 1025px) {
  .sec__head {
    padding: 0 0 13rem;
  }
  .concept__out .sec__body .sec__head {
     color:#fff;
   }
  .concept .sec__head {
    color:#fff;
  }
  .shop .sec__head {
    padding: 6rem 0 0;
  }
}


/*
 sec__headHd 
------------------- */
.sec__headHd {
  position: relative
}
@media screen and (min-width: 750px) {
  .sec__headHd {
    padding-bottom: 5rem;
    margin-bottom: 5rem
  }
}
@media screen and (max-width: 749px) {
  .sec__headHd {
    padding-bottom: 3rem;
    margin-bottom: 3rem
  }
}
.sec__headHd::before {
  content: "";
  width: 3.5rem;
  height: 2px;
  background: #333;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%)
}
.concept .sec__headHd::before, .products .sec__headHd::before {
  background: #fff
}

/*
 sec__en 
------------------- */
@media screen and (max-width: 749px) {
  .sec__en {
    margin: 0 auto
  }
  .concept .sec__en {
    width: 20.7rem;
    margin-bottom: 1rem;
  }
  .products .sec__en {
    width: 23.1rem
  }
  .shop .sec__en {
    width: 13rem
  }
  .voice .sec__en {
    width: 13.5rem
  }
}

/*
 sec__ttl 
------------------- */
.sec__ttl {
  font-weight: 500;
}
@media screen and (max-width: 599px) {
  .sec__ttl {
    font-weight: 500;
     font-size: 1.8rem;
  }
  .concept .sec__ttl {
    font-size: 2.2rem;
    margin-top: 20px;
  }
}
@media screen and (min-width: 600px) and (max-width: 1024px) {
  .sec__ttl {
    font-size: 1.8rem;
  }
  .concept .sec__ttl {
    font-size: 2rem;
    margin-top: 20px;
  }
}
@media screen and (min-width: 1025px) {
  .sec__ttl {
    font-size: 2.2rem;
    margin-top: 0;
  }
  .concept .sec__ttl {
    font-size: 3.5rem;
    margin-top: 20px;
  }
  .products .sec__ttl {
    font-size: 3rem;
    margin-top: 0;
  }
}

/*
 sec__body
------------------- */
@media screen and (min-width: 750px) {
  .sec__body {
    padding: 14rem 0 14rem;
  }
  .concept__out .sec__body {
    padding-top:3rem;
  }
}
@media screen and (max-width: 749px) {
  .sec__body {
    padding: 3rem 0;
  }
}


/* --------------------------------------

- hero

-------------------------------------- */
.hero {
  position: fixed !important;
  top: 0;
  left: 0;
  z-index: -1 !important;
  width: 100%;
  height: 100vh;
}
.hero::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  background: rgba(17, 47, 83, .7);
  -webkit-transition: .3s all;
  transition: .3s all;
  z-index: 11;
}
.hero.-active::before, .hero.-products::before {
  opacity: 1
}

/* 
 heroSlider_img
-------------------------- */
@media screen and (max-width: 599px) {
  .heroSlider_img {
      z-index:10;
      opacity: 1;
      width: 100%;
      height: 100vh;
      background-position: center center;
      background-repeat: no-repeat;
      background-size: cover;
      position: absolute;
      left: 0;
      top: 0;
  }
}
@media screen and (min-width: 600px) and (max-width: 1024px) {
  .heroSlider_img {
      z-index:10;
      opacity: 1;
      width: 100%;
      height: 920px;
      background-position: center center;
      background-repeat: no-repeat;
      background-size: cover;
      position: absolute;
      left: 0;
      top: 0;
  }
}
@media screen and (min-width: 1025px) {
  .heroSlider_img {
      z-index:10;
      opacity: 1;
      width: 100%;
      height: 920px;
      background-position: center center;
      background-repeat: no-repeat;
      background-size: cover;
      position: absolute;
      left: 0;
      top: 0;
  }
}

@media screen and (max-width: 599px) {
    #hero .heroSlider .hero__slide1 .heroSlider_img {
        background-image: url(../img/top/main_sp01.jpg);
    }
    #hero .heroSlider .hero__slide2 .heroSlider_img {
        background-image: url(../img/top/main_sp02.jpg);
    }
    #hero .heroSlider .hero__slide3 .heroSlider_img {
        background-image: url(../img/top/main_sp03.jpg);
    }
}
@media screen and (min-width: 600px) and (max-width: 1024px) {
    #hero .heroSlider .hero__slide1 .heroSlider_img {
        background-image: url(../img/top/main_sp01.jpg);
    }
    #hero .heroSlider .hero__slide2 .heroSlider_img {
        background-image: url(../img/top/main_sp02.jpg);
    }
    #hero .heroSlider .hero__slide3 .heroSlider_img {
        background-image: url(../img/top/main_sp03.jpg);
    }
}
@media screen and (min-width: 1025px) {
    #hero .heroSlider .hero__slide1 .heroSlider_img {
        background-image: url(../img/top/main_pc01.jpg);
    }
    #hero .heroSlider .hero__slide2 .heroSlider_img {
        background-image: url(../img/top/main_pc02.jpg);
    }
    #hero .heroSlider .hero__slide3 .heroSlider_img {
        background-image: url(../img/top/main_pc03.jpg);
    }
}




@media screen and (max-width: 599px) {
    .heroSlider .swiper-slide {
        position: relative;
    }
    .heroSlider .swiper-slide .heroSlider_img {
        transition: transform 6s cubic-bezier(0.4, 0, 0.2, 0.21); 
    }
    .heroSlider .swiper-slide-active .heroSlider_img {
        transform: scale(1.08); 
    }
}

@media screen and (min-width: 600px) and (max-width: 1024px) {
    .heroSlider .swiper-slide {
        position: relative;
    }
    .heroSlider .swiper-slide .heroSlider_img {
        transition: transform 6s cubic-bezier(0.4, 0, 0.2, 0.21); 
    }
    .heroSlider .swiper-slide-active .heroSlider_img {
        transform: scale(1.05); 
    }
}

@media screen and (min-width: 1025px) {
    .heroSlider .swiper-slide {
        position: relative;
    }
    .heroSlider .swiper-slide .heroSlider_img {
        transition: transform 6s cubic-bezier(0.4, 0, 0.2, 0.21); 
    }
    .heroSlider .swiper-slide-active .heroSlider_img {
        transform: scale(1.05); 
    }
}


/* --------------------------------------
- heroMainLogo
-------------------------------------- */
@media screen and (max-width: 599px) {
   .heroMainLogo {
    position: absolute;
    transition: .3s all;
    top: 0;
    left: 0;
    width: 100%;
  }
  .mainLogoWrap {
    height: 100vh;
    width: 100%;
    overflow: hidden;
    position: relative;
  }
  .mainLogo {
    z-index:11;
    position: absolute;
    top: 45%;
    left:50%;
    transform:translate(-50%,-50%);
    width: 70%;
    height:auto;
  }
}
@media screen and (min-width: 600px) and (max-width: 1024px) {
   .heroMainLogo {
    position: absolute;
    transition: .3s all;
    top: 0;
    left: 0;
    width: 100%;
  }
  .mainLogoWrap {
    height: 100vh;
    width: 100%;
    overflow: hidden;
    position: relative;
  }
  .mainLogo {
    z-index:11;
    position: absolute;
    top: 45%;
    left:50%;
    transform:translate(-50%,-50%);
    width: 35%;
    height:auto;
  }
}
@media screen and (min-width: 1025px) {
  .heroMainLogo {
    position: absolute;
    transition: .3s all;
    top: 0;
    left: 0;
    width: 100%;
  }
  .mainLogoWrap {
      height: 100vh;
      width: 100%;
      overflow: hidden;
      position: relative;
  }
  .mainLogo {
      z-index:11;
      position: absolute;
      top: 45%;
      left:50%;
      transform:translate(-50%,-50%);
      width: 20%;
      height:auto;
  }
}

.-active .heroMainLogo {
  opacity: 0;
}


/* --------------------------------------
- scrolldown
-------------------------------------- */
.scrolldown {
  position: absolute;
  left: 50%;
  bottom: 0;
  height: 50px;
  -webkit-transition: .3s all;
  transition: .3s all;
    z-index: 1,
}
.-active .scrolldown {
  opacity: 0
}
.scrolldown span {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  top: -25px;
  color: #fff;
  font-weight: 500;
  letter-spacing: .05em;
  font-size: 1.8rem;
  -webkit-transition: .3s all;
  transition: .3s all
}
.scrolldown::after {
  content: "";
  position: absolute;
  top: 0;
  width: 1px;
  height: 3rem;
  background: #fff;
  -webkit-animation: pathmove 1.4s ease-in-out infinite;
  animation: pathmove 1.4s ease-in-out infinite;
  opacity: 0
}
@-webkit-keyframes pathmove {
  0% {
    height: 0;
    top: 0;
    opacity: 0
  }
  30% {
    height: 3rem;
    opacity: 1
  }
  100% {
    height: 0;
    top: 5rem;
    opacity: 0
  }
}
@keyframes pathmove {
  0% {
    height: 0;
    top: 0;
    opacity: 0
  }
  30% {
    height: 3rem;
    opacity: 1
  }
  100% {
    height: 0;
    top: 5rem;
    opacity: 0
  }
}
@media screen and (min-width: 750px) {
  .concept {
    margin-top: 5rem
  }
}
@media screen and (max-width: 749px) {
  .concept {
    margin-top: 3rem
  }
}
.concept__headFt__ttl {
  font-weight: 500;
  margin-bottom: 1em;
    color:#fff;
}
@media screen and (min-width: 750px) {
  .concept__headFt__ttl {
    font-size: clamp(3rem, 2.5vw, 4rem);
      color:#fff;
  }
}
@media screen and (max-width: 749px) {
  .concept__headFt__ttl {
    font-size: 2.2rem;
      color:#fff;
  }
}
.concept__headFt__txt {
  font-weight: 400;
  line-height: 2.1;
    color:#fff;
}
@media screen and (min-width: 750px) {
  .concept__headFt__txt {
    font-size: clamp(1.8rem, 1.6vw, 2.1rem);
      color:#fff;
  }
}
@media screen and (max-width: 749px) {
  .concept__headFt__txt {
    font-size: 1.4rem;
      color:#fff;
  }
}
.concept__in {
  position: relative;
  background: #fff
}
@media screen and (min-width: 750px) {
  .concept__in {
    max-width: 1600px;
    margin: 0 auto;
    padding: 15rem 0 0
  }
}
@media screen and (max-width: 749px) {
  .concept__in {
    padding: 3rem 0 0
  }
}
.concept__in::before {
  content: "";
  height: 100%;
  width: 100vw;
  background: #fff;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index: -1
}
.concept__in.bg-gray {
  background: #f2f2f2
}
.concept__in.bg-gray::before {
  background: #f2f2f2
}
@media screen and (min-width: 750px) {
  .concept__in.bg-gray {
    padding: 29rem 0 15rem
  }
}
@media screen and (max-width: 749px) {
  .concept__in.bg-gray {
    padding: 12rem 0 0
  }
}
.concept__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}
@media screen and (min-width: 750px) {
  .concept__flex {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    margin-bottom: 10vw
  }
}
@media screen and (max-width: 749px) {
  .concept__flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    margin-bottom: 3rem
  }
}
@media screen and (min-width: 750px) {
  .concept__flex__txt {
    margin-left: 5%
  }
}
@media screen and (max-width: 749px) {
  .concept__flex__txt {
    padding: 0 1.5rem
  }
}
@media screen and (min-width: 750px) {
  .concept__flex2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start
  }
}
.concept__txt {
  line-height: 2
}
@media screen and (min-width: 750px) {
  .concept__txt {
    max-width: clamp(30rem, 30vw, 35rem)
  }
}
@media screen and (min-width: 750px) {
  .concept__img01 {
    max-width: 80rem;
    width: 50%
  }
}
@media screen and (min-width: 1024px) {
  .concept__img01 {
    margin: 0 6.3%
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .concept__img01 {
    margin: 0 0 0 6.3%
  }
}
@media screen and (max-width: 749px) {
  .concept__img01 {
    width: 32rem;
    margin: 2rem 0 3rem auto
  }
}
@media screen and (min-width: 750px) {
  .concept__img02 {
    position: absolute;
    max-width: 60rem;
    width: 37.5%;
    top: 33%;
    left: 0
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .concept__img02 {
    top: 42%
  }
}
@media screen and (max-width: 749px) {
  .concept__img02 {
    position: relative;
    left: -1.5rem;
    width: 32rem
  }
}
@media screen and (min-width: 750px) {
  .concept__img03 {
    position: absolute;
    max-width: 90rem;
    width: 56.3%;
    top: 55%;
    left: 0
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .concept__img03 {
    width: 48%;
    top: 62%
  }
}
@media screen and (max-width: 749px) {
  .concept__img03 {
    position: relative;
    left: -1.5rem;
    width: 100%
  }
}
@media screen and (min-width: 750px) {
  .concept__txtbox2 {
    max-width: clamp(44rem, 60%, 66rem);
    margin-top: -12vw
  }
}
@media screen and (max-width: 749px) {
  .concept__txtbox2 {
    margin-top: 3rem
  }
}
@media screen and (min-width: 750px) {
  .concept__logo {
    width: 14rem;
    margin: 0 auto clamp(3rem, 2.8vw, 4.5rem)
  }
}
@media screen and (max-width: 749px) {
  .concept__logo {
    width: 14rem;
    margin: 0 auto 2rem
  }
}
.concept__ttl {
  text-align: center;
  line-height: 1.6
}
@media screen and (min-width: 750px) {
  .concept__ttl {
    font-size: clamp(2rem, 2.1vw, 3rem);
    margin-bottom: 2rem
  }
}
@media screen and (max-width: 749px) {
  .concept__ttl {
    font-size: 2rem;
    margin-bottom: 1.5rem
  }
}
.concept__txtLg {
  line-height: 2.5
}
@media screen and (min-width: 750px) {
  .concept__txtLg {
    font-size: clamp(1.4rem, 1.1vw, 1.6rem);
    margin-left: auto
  }
}
@media screen and (max-width: 749px) {
  .concept__txtLg {
    font-size: 1.4rem;
    margin: 3rem 0
  }
}
.concept__txtLg2 {
  line-height: 2.2
}
@media screen and (min-width: 750px) {
  .concept__txtLg2 {
    font-size: clamp(1.4rem, 1.1vw, 1.6rem)
  }
}
@media screen and (max-width: 749px) {
  .concept__txtLg2 {
    font-size: 1.4rem
  }
}
.concept__txtMd {
  line-height: 2.5
}
@media screen and (min-width: 750px) {
  .concept__txtMd {
    font-size: clamp(1.4rem, 1.1vw, 1.6rem)
  }
}
@media screen and (max-width: 749px) {
  .concept__txtMd {
    font-size: 1.4rem
  }
}
.concept__txtSm {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 2.1;
  font-size: 1.2rem
}
@media screen and (min-width: 750px) {
  .concept__txtSm {
    margin-top: 2rem;
    margin-left: auto
  }
}
@media screen and (max-width: 749px) {
  .concept__txtSm {
    margin: 1rem 0 0
  }
}
.concept__txtSm::before {
  content: "※"
}
.concept__img05 {
  position: relative;
  z-index: 1
}
@media screen and (min-width: 750px) {
  .concept__img05 {
    max-width: 102rem;
    width: 92.7%;
    margin: 48.4vw auto max(-16rem, -9.4vw)
  }
}
@media screen and (max-width: 749px) {
  .concept__img05 {
    width: 100%;
    margin: 4rem 0 -6rem
  }
}
@media screen and (min-width: 750px) {
  .concept__img06 {
    max-width: 90rem;
    width: 56.3%;
    margin-right: 6.3%
  }
}
@media screen and (max-width: 749px) {
  .concept__img06 {
    width: 100%
  }
}
@media screen and (min-width: 750px) {
  .concept__img07 {
    max-width: 50rem;
    width: 31.3%;
    margin-top: 12.5vw
  }
}
@media screen and (max-width: 749px) {
  .concept__img07 {
    width: 25rem;
    display: none
  }
}
@media screen and (min-width: 750px) {
  .concept__img04 {
    position: absolute;
    max-width: 60rem;
    width: 37.5%;
    top: 67%;
    right: 0
  }
}
@media screen and (max-width: 749px) {
  .concept__img04 {
    width: 32rem;
    position: relative;
    right: -1.5rem;
    margin: 2.4rem 0 0 auto
  }
}
@media screen and (min-width: 750px) {
  .concept__img08 {
    position: absolute;
    max-width: 40rem;
    width: 28.6%;
    top: 48%;
    right: 0
  }
}
@media screen and (max-width: 749px) {
  .concept__img08 {
    width: 100vw;
    position: relative;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    margin-top: 6rem
  }
}
@media screen and (min-width: 750px) {
  .concept__img09 {
    position: relative;
    max-width: 140rem;
    width: 87.5%;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    margin-top: 8.6vw
  }
}
@media screen and (max-width: 749px) {
  .concept__img09 {
    width: 100%;
    margin-top: 3rem
  }
}
.desc {
  color: #fff;
  background: #112f53
}
.desc__in {
  position: relative;
  max-width: 1600px;
  margin: 0 auto
}
@media screen and (min-width: 750px) {
  .desc__in {
    padding: 22rem 0 13rem
  }
}
@media screen and (max-width: 749px) {
  .desc__in {
    padding: 5rem 0
  }
}
@media screen and (min-width: 750px) {
  .descHd__img {
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: clamp(60rem, 60vw, 80rem);
    background: url(../img/top/img_desc01.webp) center/cover
  }
}
@media screen and (max-width: 749px) {
  .descHd__img {
    width: 32rem;
    margin: 3rem 0 0 auto;
    position: relative;
    right: -1.5rem
  }
}
.descHd__ttl {
  font-weight: 500
}
@media screen and (min-width: 750px) {
  .descHd__ttl {
    font-size: clamp(2.6rem, 2.5vw, 4rem);
    margin-bottom: clamp(10rem, 10vw, 18rem)
  }
}
@media screen and (max-width: 749px) {
  .descHd__ttl {
    font-size: 2.4rem;
    margin-bottom: 3rem
  }
}
@media screen and (min-width: 750px) {
  .descHd__graph {
    width: 43.6%
  }
}
@media screen and (max-width: 749px) {
  .descHd__graph {
    margin-top: 3rem
  }
}
.descHd__graph__txt {
  font-weight: 400;
  text-align: center;
  margin-bottom: 1rem
}
@media screen and (min-width: 750px) {
  .descHd__graph__txt {
    font-size: 1.8rem
  }
}
@media screen and (max-width: 749px) {
  .descHd__graph__txt {
    font-size: 1.4rem
  }
}
@media screen and (min-width: 750px) {
  .descMd {
    margin-top: 12rem
  }
}
@media screen and (max-width: 749px) {
  .descMd {
    margin-top: 5rem
  }
}
.descMd__ttl {
  font-weight: 500;
  text-align: center
}
@media screen and (min-width: 750px) {
  .descMd__ttl {
    font-size: clamp(2.6rem, 2.5vw, 4rem);
    margin-bottom: 3rem
  }
}
@media screen and (max-width: 749px) {
  .descMd__ttl {
    font-size: 2.2rem;
    margin-bottom: 2rem
  }
}
@media screen and (min-width: 750px) {
  .descMd__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
  }
}
.descMd__item {
  font-weight: 400;
  line-height: 1.8;
  font-size: clamp(1.4rem, 1.1vw, 1.6rem)
}
@media screen and (min-width: 750px) {
  .descMd__item {
    width: 48.2%
  }
}
@media screen and (max-width: 749px) {
  .descMd__item + .descMd__item {
    margin-top: 2rem
  }
}
@media screen and (min-width: 750px) {
  .descFt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-top: 8rem
  }
}
@media screen and (max-width: 749px) {
  .descFt {
    margin-top: 5rem
  }
}
@media screen and (min-width: 1024px) {
  .descItem {
    width: 29.1%
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .descItem {
    width: 30%
  }
}
@media screen and (max-width: 749px) {
  .descItem + .descItem {
    margin-top: 3rem
  }
}
.descItem__ttl {
  font-weight: 500
}
@media screen and (min-width: 750px) {
  .descItem__ttl {
    font-size: clamp(2rem, 1.8vw, 2.5rem);
    margin-top: 2rem
  }
}
@media screen and (max-width: 749px) {
  .descItem__ttl {
    font-size: 1.8rem;
    margin-top: 1.5rem
  }
}
.descItem__txt {
  font-weight: 400;
  line-height: 1.8;
  font-size: clamp(1.4rem, 1.1vw, 1.6rem)
}
@media screen and (min-width: 750px) {
  .descItem__txt {
    margin-top: 1.5rem
  }
}
@media screen and (max-width: 749px) {
  .descItem__txt {
    margin-top: 1rem
  }
}
@media screen and (min-width: 750px) {
  .voice {
    padding: 11rem 0 0
  }
}
@media screen and (max-width: 749px) {
  .voice {
    padding: 3rem 0 0
  }
}
.voice__head {
  position: relative;
  text-align: center
}
@media screen and (min-width: 750px) {
  .voice__head {
    min-height: 60rem;
    max-width: 1600px;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
  }
}
@media screen and (min-width: 750px) {
  .voice__img01 {
    max-width: 90rem;
    position: absolute;
    top: 0;
    left: 0;
    height: clamp(60rem, 60vw, 60rem);
    background: url(../img/top/img_voice.webp) center/cover
  }
}
@media screen and (min-width: 1024px) {
  .voice__img01 {
    width: 56.3%
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .voice__img01 {
    width: 50%
  }
}
@media screen and (max-width: 749px) {
  .voice__img01 {
    width: 100vw;
    position: relative;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    margin-bottom: 3rem
  }
}
@media screen and (min-width: 1024px) {
  .voice__headHd {
    margin: 0 6.6% 0 min(62.5%, 100rem)
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .voice__headHd {
    margin: 0 6.6% 0 58%
  }
}
@media screen and (min-width: 750px) {
  .voice__box {
    margin-top: clamp(4rem, 5.3vw, 8.5rem)
  }
}
@media screen and (max-width: 749px) {
  .voice__box {
    margin-top: 4rem
  }
}
.voice__txt {
  line-height: 2.5
}
@media screen and (min-width: 750px) {
  .voice__txt {
    font-size: 1.6rem
  }
}
@media screen and (max-width: 749px) {
  .voice__txt {
    font-size: 1.4rem
  }
}
@media screen and (min-width: 750px) {
  .voice__txt .lg {
    font-size: 3.5rem
  }
}
@media screen and (max-width: 749px) {
  .voice__txt .lg {
    font-size: 3rem
  }
}
.voice__txt sup {
  font-size: 1.2rem
}
.voice__kome {
  line-height: 2.1;
  margin-top: 1em;
  font-size: 1.2rem
}
.voice__lead {
  text-align: center;
  font-weight: 500
}
@media screen and (min-width: 750px) {
  .voice__lead {
    font-size: clamp(2rem, 2vw, 2.5rem);
    margin-bottom: 4rem
  }
}
@media screen and (max-width: 749px) {
  .voice__lead {
    font-size: 1.8rem;
    margin-bottom: 2.5rem
  }
}
.swiper-slide.voiceItem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  border: 2px solid #333;
  font-weight: 500
}
@media screen and (min-width: 750px) {
  .swiper-slide.voiceItem {
    height: 18rem;
    width: 18rem;
    font-size: 1.8rem
  }
}
@media screen and (max-width: 749px) {
  .swiper-slide.voiceItem {
    height: 14rem;
    width: 14rem;
    font-size: 1.4rem
  }
}
.bg__video {
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -webkit-transition: .5s all;
  transition: .5s all;
  vertical-align: bottom
}
@media screen and (min-width: 750px) {
  .bnrlist {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding-top: 10rem
  }
}
@media screen and (max-width: 749px) {
  .bnrlist {
    padding: 3rem .5rem 0
  }
}
@media screen and (min-width: 750px) {
  .bnritem {
    width: calc(50% - 5px)
  }
}
@media screen and (min-width: 750px) {
  .bnritem:nth-child(1) .bnrAnc {
    height: 80rem
  }
}
@media screen and (min-width: 750px) {
  .bnritem:nth-child(1) .bnrAnc::before {
    background-image: url(../img/top/topbnr01_bg.webp)
  }
}
@media screen and (max-width: 749px) {
  .bnritem:nth-child(1) .bnrAnc::before {
    background-image: url(../img/top/topbnr01_bg_sp.webp)
  }
}
@media screen and (min-width: 750px) {
  .bnritem:nth-child(2) .bnrAnc {
    height: 39.5rem
  }
}
@media screen and (min-width: 750px) {
  .bnritem:nth-child(2) .bnrAnc:nth-child(1) {
    margin-bottom: 1rem
  }
}
@media screen and (min-width: 750px) {
  .bnritem:nth-child(2) .bnrAnc:nth-child(1)::before {
    background-image: url(../img/top/topbnr02_bg.webp)
  }
}
@media screen and (max-width: 749px) {
  .bnritem:nth-child(2) .bnrAnc:nth-child(1)::before {
    background-image: url(../img/top/topbnr02_bg_sp.webp)
  }
}
@media screen and (min-width: 750px) {
  .bnritem:nth-child(2) .bnrAnc:nth-child(2)::before {
    background-image: url(../img/top/topbnr03_bg.webp)
  }
}
@media screen and (max-width: 749px) {
  .bnritem:nth-child(2) .bnrAnc:nth-child(2)::before {
    background-image: url(../img/top/topbnr03_bg_sp.webp)
  }
}
@media screen and (max-width: 749px) {
  .bnritem:nth-child(2) .bnrAnc {
    margin-top: .5rem
  }
}
.bnrAnc {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  color: #fff;
  overflow: hidden
}
@media screen and (min-width: 750px) {
  .bnrAnc:hover::before {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
  }
}
@media screen and (max-width: 749px) {
  .bnrAnc {
    height: 20rem
  }
}
.bnrAnc::before {
  content: "";
  background-position: center;
  background-size: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  -webkit-transition: .3s all;
  transition: .3s all
}
@media screen and (min-width: 750px) {
  .bnr__txt {
    font-size: clamp(1.8rem, 1.6vw, 2.5rem)
  }
}
@media screen and (max-width: 749px) {
  .bnr__txt {
    font-size: 1.8rem
  }
}
.bnr__ttl {
  margin-top: .7rem
}
@media screen and (min-width: 750px) {
  .bnr__ttl {
    font-size: clamp(2.5rem, 2.8vw, 4.5rem)
  }
}
@media screen and (max-width: 749px) {
  .bnr__ttl {
    font-size: 2.5rem
  }
}
@media screen and (min-width: 750px) {
  .bnr__logo {
    width: clamp(28rem, 25.4vw, 406px);
    margin: 2.5rem 0
  }
}
@media screen and (max-width: 749px) {
  .bnr__logo {
    width: 27rem;
    margin: 1.5rem 0
  }
}
@media screen and (min-width: 750px) {
  .bnr__log02 {
    width: clamp(15rem, 14.4vw, 230px);
    margin: 2.5rem 0
  }
}
@media screen and (max-width: 749px) {
  .bnr__log02 {
    width: 13.5rem;
    margin: 1.5rem 0
  }
}
.bnr__btn {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}
@media screen and (min-width: 750px) {
  .bnr__btn {
    font-size: clamp(1.6rem, 1.4vw, 2rem);
    right: 4rem;
    bottom: 4rem;
    margin: 0 1.5rem
  }
}
@media screen and (max-width: 749px) {
  .bnr__btn {
    font-size: 1.2rem;
    right: .8rem;
    bottom: .8rem
  }
}
.bnr__btn .arrow {
  display: block
}
@media screen and (min-width: 750px) {
  .bnr__btn .arrow {
    width: 5rem;
    margin-left: 2rem
  }
}
@media screen and (max-width: 749px) {
  .bnr__btn .arrow {
    width: 2rem;
    margin-left: .5rem
  }
}
@media screen and (min-width: 750px) {
  .shopList {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: flex-start;
  }
}
@media screen and (min-width: 1024px) {
  .shopItem {
    width: 29.1%
  }
  .shopItem:nth-child(n+4) {
    margin-top: 6.5rem
  }
  .shopItem:not(:nth-child(3)) {
    margin-right:6.9rem;
  }
}
@media screen and (min-width: 750px)and (max-width: 1023px) {
  .shopItem {
    width: 48%
  }
  .shopItem:nth-child(odd) {
    margin-right: 4%
  }
  .shopItem:nth-child(n+3) {
    margin-top: 5rem
  }
}
@media screen and (max-width: 749px) {
  .shopItem + .shopItem {
    margin-top: 3rem
  }
}
.shopItem__ttl {
  border-bottom: 1px solid #333
}
@media screen and (min-width: 750px) {
  .shopItem__ttl {
    font-size: 2rem;
    padding-bottom: 2rem;
    margin-bottom: 3rem
  }
}
@media screen and (max-width: 749px) {
  .shopItem__ttl {
    font-size: 1.6rem;
    padding-bottom: 1rem;
    margin-bottom: 2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
  }
  .shopItem__ttl::after {
    content: "";
    width: .8rem;
    height: .8rem;
    border-top: 1px solid #333;
    border-right: 1px solid #333;
    -webkit-transform: rotate(135deg) translate(50%, -50%);
    transform: rotate(135deg) translate(50%, -50%);
    margin-right: 1rem
  }
  .shopItem__ttl.-active::after {
    -webkit-transform: rotate(135deg) translate(50%, -50%) scale(-1, -1);
    transform: rotate(135deg) translate(50%, -50%) scale(-1, -1)
  }
}
@media screen and (max-width: 749px) {
  .shopShow {
    display: none
  }
}
.shopRoom {
  line-height: 2
}
@media screen and (min-width: 750px) {
  .shopRoom {
    font-size: 1.5rem
  }
}
@media screen and (max-width: 749px) {
  .shopRoom {
    font-size: 1.4rem
  }
}
@media screen and (min-width: 750px) {
  .shopRoom + .shopRoom {
    margin-top: 2.5rem
  }
}
@media screen and (max-width: 749px) {
  .shopRoom + .shopRoom {
    margin-top: 2rem
  }
}
.map__icon {
  color: #333;
  border-bottom: 1px solid #333;
  position: relative
}
@media screen and (min-width: 750px) {
  .map__icon {
    margin-left: 2.5rem
  }
  .map__icon:hover {
    opacity: .7
  }
}
@media screen and (max-width: 749px) {
  .map__icon {
    margin-left: 2.3rem
  }
}
.map__icon::before {
  content: "";
  color: #fff;
  width: .4rem;
  height: .4rem;
  border: solid 1px currentColor;
  border-radius: 3rem;
  background: #fff;
  position: absolute;
  left: -1.9rem;
  top: .7rem;
  z-index: 1
}
.map__icon::after {
  content: "";
  color: #333;
  width: 1.2rem;
  height: 1.2rem;
  border: solid 1px currentColor;
  border-radius: .7em .7em .7em 0;
  background: currentColor;
  position: absolute;
  left: -2.3rem;
  top: .3rem;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}



.splide-1 .splide__track .splide__list .splide__slide {
    z-index:10;
    opacity: 1;
    width: 100%;
    height: 100vh;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    left: 0;
    top: 0;
}



/* ズーム */
.splide-1 .splide__track .splide__list .splide__slide img {
  transition: 8s ease-out;
}
.splide-1 .splide__track .splide__list .splide__slide.is-active img {
  transform: scale(1.15);
  transition-delay: 0s;
}
/* スライドのサイズ調整 */
.splide-1 .splide__track .splide__list .splide__slide img {
  height: auto;
  width: 100%;
}

















/* ---------------------------------------------------------

- splide 

--------------------------------------------------------- */
.splide__arrows,
.splide__pagination {
    display:none;
}
@media screen and (max-width: 599px) {
  .splide__track {
     margin: 0 auto;
  }
  .splide .product_splide__slide {
    width: 100%;
    //height: auto
  }
  .splide .splide__list {
    //
    height: 100%;
    /* padding: 4rem 2rem 2rem; */
    /* background: #f5f5f5; */
    display: flex;
    //gap:50px;
    /* position: relative; */
    flex-wrap: nowrap;
  }
  .splide .productSlide {

  }
  .splide .splide__list a { 
    width: auto!important;
  }
 .splide .productSlide:hover .productSlide__img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1)
  }
  .splide .productSlide::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    border-bottom: 4rem solid rgba(0, 0, 0, 0)
  }
  .splide .productSlide.regalia::before {
    border-left: 4rem solid #112e53
  }
  .splide .productSlide.regalia-gold::before {
    border-left: 4rem solid #be9349
  }
  .splide .productSlide.regalia-platinum::before {
    border-left: 4rem solid #a6aeb5
  }
  .splide .productSlide.emotion-v::before, .productSlide.the-granregalia::before {
    border-left: 4rem solid #656565
  }
  .splide .productSlide__head {
    text-align: center;
    margin-bottom: 18rem;
    position: relative;
    z-index: 1
  }
  .splide .productThumb__en__img {
    height: 1.6rem
  }
  .splide .productSlide__jp {
    font-size: 1.6rem;
    margin-top: 1rem;
    font-weight: 500
  }
  .splide .productSlide__jp::after {
    content: "";
    display: block;
    height: 1px;
    width: 2rem;
    background: #333;
    margin: 1rem auto 0
  }
  .splide .productSlide__thumb {
    position: absolute;
    top: 7rem;
    right: 0;
    text-align: right;
    overflow: hidden
  }
  .splide .productSlide__img {
    height: 23rem;
    -webkit-transition: all .3s;
    transition: all .3s
  }
  .splide .prodcuctSlide__foot {
    position: relative;
    z-index: 1;
    margin-bottom: 3rem
  }
  .splide .productSlide__lead {
    font-size: 1.4rem;
    line-height: 1.8;
    margin-bottom: 3rem
  }
  .splide .productSlide__more {
    font-size: 1.6rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative
  }
  .splide .productSlide__more::after {
    content: "";
    font-family: "icomoon" !important;
    position: absolute;
    line-height: 1;
    right: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    font-size: 120%
  }
}
@media screen and (min-width: 600px) and (max-width: 1024px) {
     .splide__track {
     margin: 0 auto;
  }
  .splide .product_splide__slide {
    width: 100%;
    //height: auto
  }
  .splide .splide__list {
    //
    height: 100%;
    /* padding: 4rem 2rem 2rem; */
    /* background: #f5f5f5; */
    display: flex;
    gap:50px;
    /* position: relative; */
    flex-wrap: nowrap;
  }
  .splide .productSlide {

  }
  .splide .splide__list a {
    width: auto!important;
  }
 .splide .productSlide:hover .productSlide__img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1)
  }
  .splide .productSlide::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    border-bottom: 4rem solid rgba(0, 0, 0, 0)
  }
  .splide .productSlide.regalia::before {
    border-left: 4rem solid #112e53
  }
  .splide .productSlide.regalia-gold::before {
    border-left: 4rem solid #be9349
  }
  .splide .productSlide.regalia-platinum::before {
    border-left: 4rem solid #a6aeb5
  }
  .splide .productSlide.emotion-v::before, .productSlide.the-granregalia::before {
    border-left: 4rem solid #656565
  }
  .splide .productSlide__head {
    text-align: center;
    margin-bottom: 18rem;
    position: relative;
    z-index: 1
  }
  .splide .productThumb__en__img {
    height: 1.6rem
  }
  .splide .productSlide__jp {
    font-size: 1.6rem;
    margin-top: 1rem;
    font-weight: 500
  }
  .splide .productSlide__jp::after {
    content: "";
    display: block;
    height: 1px;
    width: 2rem;
    background: #333;
    margin: 1rem auto 0
  }
  .splide .productSlide__thumb {
    position: absolute;
    top: 7rem;
    right: 0;
    text-align: right;
    overflow: hidden
  }
  .splide .productSlide__img {
    height: 23rem;
    -webkit-transition: all .3s;
    transition: all .3s
  }
  .splide .prodcuctSlide__foot {
    position: relative;
    z-index: 1;
    margin-bottom: 3rem
  }
  .splide .productSlide__lead {
    font-size: 1.4rem;
    line-height: 1.8;
    margin-bottom: 3rem
  }
  .splide .productSlide__more {
    font-size: 1.6rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative
  }
  .splide .productSlide__more::after {
    content: "";
    font-family: "icomoon" !important;
    position: absolute;
    line-height: 1;
    right: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    font-size: 120%
  }
}
@media screen and (min-width: 1025px) {
  .splide {
     /* visibility:visible; */
  }  
  .topProductCol .splide:not(.is-active) .splide__list {
    display: flex;
    gap: 32px;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
  }
  .splide__track {
    max-width: 1360px;
    margin: 0 auto;
  }
}



#topProductsplide .topProductCol {
    display:flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    max-width: 1360px;
    margin: 0 auto;
    gap: 10px;
}







