@charset "UTF-8";
/* Hero Area
-------------------------------- */
.hero {
  background-repeat: no-repeat;
}
@media (max-width: 767.98px) {
  .hero {
    background-image: url("../img/bg_hero_sm.jpg?23040401");
    background-repeat: no-repeat;
    background-position: 0 0;
    background-size: 100% auto;
  }
}
@media (min-width: 768px) {
  .hero {
    background-image: url("../img/bg_hero_lg.jpg?23040401");
    background-position: center center;
    background-size: cover;
  }
}
@media (min-width: 768px) {
  .hero img {
    width: auto;
    height: 100%;
  }
}

@media (min-width: 768px) {
  .hero_inner {
    margin: 0 auto;
    max-width: 1040px;
  }
}
.hero_inner img {
  width: 100%;
  height: auto;
}

.hero_kv {
  margin: 0;
}

/* Category Area
-------------------------------- */
.category {
  background-color: rgba(var(--c-main-blue), 1);
}

@media (max-width: 767.98px) {
  .category_inner {
    padding-top: 4vw;
    padding-bottom: 4vw;
  }
}
@media (min-width: 768px) {
  .category_inner {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

.category_list {
  display: grid;

  grid-template-row: auto;
}
@media (max-width: 767.98px) {
  .category_list {
    grid-template-columns: repeat(4, 23%);
    gap: 0 2.66%;
  }
}
@media (min-width: 768px) {
  .category_list {
    grid-template-columns: repeat(4, 22.7%);
    gap: 0 3.06%;
  }
}

.category_item-link {
  position: relative;
  background-color: rgba(var(--c-true-white), 1);

  font-feature-settings: "palt";
}
@media (max-width: 767.98px) {
  .category_item-link {
    display: block;
    padding: 2.6666666667vw 0 7.0666666667vw;
    border-radius: 1.3333333333vw;
    text-align: center;

    --circle-size: 9.3333333333vw;
    --circle-border-width: 0.4vw;
  }
}
@media (min-width: 768px) {
  .category_item-link {
    display: grid;
    align-items: center;
    justify-content: center;
    padding: 15px 0 25px;
    border-radius: 10px;

    --circle-size: 48px;
    --circle-border-width: 3px;
    grid-template-columns: 48px max-content;
  }
}
@media (min-width: 768px) and (hover: hover) {
  .category_item-link {
    cursor: pointer;
    transition: opacity 0.2s ease-out;
    transition: opacity 0.2s;
  }
  .category_item-link:hover {
    opacity: 0.8;
  }
}
.category_item-link:visited,
.category_item-link:link {
  text-decoration: none;
}
@media (max-width: 767.98px) {
  .-entertainment .category_item-link {
    --icon-size: 4.9333333333vw;
  }
}
@media (min-width: 768px) {
  .-entertainment .category_item-link {
    --icon-size: 25px;
    gap: 0 9px;
  }
}
@media (max-width: 767.98px) {
  .-cuisine .category_item-link {
    --icon-size: 3.8666666667vw;
  }
}
@media (min-width: 768px) {
  .-cuisine .category_item-link {
    --icon-size: 19px;
    gap: 0 9px;
  }
}
@media (max-width: 767.98px) {
  .-fashion .category_item-link {
    --icon-size: 6.1333333333vw;
  }
}
@media (min-width: 768px) {
  .-fashion .category_item-link {
    --icon-size: 31px;
    gap: 0 9px;
  }
}
@media (max-width: 767.98px) {
  .-life .category_item-link {
    --icon-size: 6.1333333333vw;
  }
}
@media (min-width: 768px) {
  .-life .category_item-link {
    --icon-size: 32px;
    gap: 0 9px;
  }
}

.category_item-label {
  min-height: 2em;
  color: rgba(var(--c-main-blue), 1);
  font-weight: 600;

  font-feature-settings: "palt";
}
@media (max-width: 767.98px) {
  .category_item-label {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: -0.2666666667vw;
    font-size: 2.5333333333vw;
    line-height: 1.04;
  }
}
@media (min-width: 768px) {
  .category_item-label {
    display: grid;
    align-items: center;
    letter-spacing: 0.025em;
    font-size: 20px;
    line-height: 1.1;
  }
}

.category_anchor-icon {
  display: inline-flex;
  position: absolute;
  left: 50%;
  transform: rotate(90deg);
}
@media (max-width: 767.98px) {
  .category_anchor-icon {
    bottom: 1.4666666667vw;
    margin-left: -0.8666666667vw;
    width: 1.7333333333vw;
    height: 3.0666666667vw;
  }
}
@media (min-width: 768px) {
  .category_anchor-icon {
    bottom: 3px;
    margin-left: -4.5px;
    width: 9px;
    height: 16px;
  }
}
.category_anchor-icon img {
  width: auto;
  height: 100%;
}
.category_anchor-icon svg {
  width: 100%;
  height: 100%;
}

/*
  Categories Common
  - 専門店エリア共通パーツ
-------------------------------- */
.categories {
  background: linear-gradient(180deg, rgb(255, 255, 255) 0%, rgb(212, 229, 244) 100%);
}
@media (max-width: 767.98px) {
  .categories {
    padding-top: 16vw;
    padding-bottom: 16vw;
  }
}
@media (min-width: 768px) {
  .categories {
    padding-top: 70px;
    padding-bottom: 58.5px;
  }
}

@media (min-width: 768px) {
  .categories_inner {
    padding-right: 0;
    padding-left: 0;
    width: 810px;
  }
}

.categories_title {
  color: rgba(var(--c-main-blue), 1);
  font-weight: 600;
}
@media (max-width: 767.98px) {
  .categories_title {
    margin-bottom: -0.5333333333vw;
    margin-left: 2.6666666667vw;
    font-size: 6.6666666667vw;
    line-height: 1.16;
  }
}
@media (min-width: 768px) {
  .categories_title {
    margin-top: -20px;
    margin-bottom: -26px;
    margin-left: 17px;
    font-size: 42px;
    line-height: 2.24;
  }
}

.categories_meta {
  display: flex;
  align-items: center;
  text-align: center;
}
@media (max-width: 767.98px) {
  .categories_meta {
    --circle-size: 12.2666666667vw;
    --circle-border-width: 0.5333333333vw;
  }
}
@media (min-width: 768px) {
  .categories_meta {
    justify-content: center;

    --circle-size: 74px;
    --circle-border-width: 3px;
  }
}
@media (max-width: 767.98px) {
  .categories_meta.-entertainment {
    --icon-size: 6.4vw;
  }
}
@media (min-width: 768px) {
  .categories_meta.-entertainment {
    --icon-size: 37px;
  }
}
@media (max-width: 767.98px) {
  .categories_meta.-cuisine {
    --icon-size: 5.2vw;
  }
}
@media (min-width: 768px) {
  .categories_meta.-cuisine {
    --icon-size: 32px;
  }
}
@media (max-width: 767.98px) {
  .categories_meta.-fashion {
    --icon-size: 8vw;
  }
}
@media (min-width: 768px) {
  .categories_meta.-fashion {
    --icon-size: 50px;
  }
}
@media (max-width: 767.98px) {
  .categories_meta.-life {
    --icon-size: 8.1333333333vw;
  }
}
@media (min-width: 768px) {
  .categories_meta.-life {
    --icon-size: 51px;
  }
}

@media (max-width: 767.98px) {
  .categories_note {
    margin-top: 6.4vw;
    font-size: 3.2vw;
    line-height: 1.75;
  }
}
@media (min-width: 768px) {
  .categories_note {
    margin-top: 13.5px;
    letter-spacing: 0.025;
    font-size: 16px;
    line-height: 1.625;
  }
}

/*
  Shop Common
  - 専門店アイテム共通パーツ
-------------------------------- */
.shop_container {
  display: flex;
  flex-wrap: wrap;
}
@media (max-width: 767.98px) {
  .shop_container {
    justify-content: space-between;
    margin: 1.3333333333vw -2.6666666667vw 0;
  }
}
@media (min-width: 768px) {
  .shop_container {
    justify-content: center;
    margin-top: 27.5px;
  }
}

.shop_content {
  display: grid;
  background-color: rgba(var(--c-true-white), 1);
  text-align: center;
  box-shadow: 0 0 2rem -0.5rem rgba(0, 0, 0, 0.4);
}
@media (max-width: 767.98px) {
  .shop_content {
    margin: 2.6666666667vw 2vw;
    padding: 2.6666666667vw;
    border-radius: 2.6666666667vw;
    width: 41.3333333333vw;
  }
}
@media (min-width: 768px) {
  .shop_content {
    margin: 11.5px;
    padding: 20px;
    border-radius: 20px;
    width: 240px;
    min-height: 288px;
  }
}

.shop_name {
  display: block;
  color: rgba(var(--c-text-gray), 1);
  font-weight: normal;
}
@media (max-width: 767.98px) {
  .shop_name {
    margin-top: 1.4666666667vw;
    margin-bottom: -0.4vw;
    font-size: 2.9333333333vw;
    line-height: 1.27;
  }
}
@media (min-width: 768px) {
  .shop_name {
    margin-top: 4px;
    margin-bottom: -6px;
    font-size: 16px;
    line-height: 1.75;
  }
}

.shop_benefit {
  font-weight: 600;

  font-feature-settings: "palt";
}
@media (max-width: 767.98px) {
  .shop_benefit {
    margin-top: 1.8666666667vw;
    margin-right: -1.3333333333vw;
    margin-bottom: -0.9333333333vw;
    margin-left: -1.3333333333vw;
    font-size: 2.9333333333vw;
    line-height: 1.58;
  }
}
@media (min-width: 768px) {
  .shop_benefit {
    margin-top: 9.5px;
    margin-right: -15px;
    margin-bottom: -5.5px;
    margin-left: -15px;
    font-size: 17px;
    line-height: 1.65;
  }
}

@media (max-width: 767.98px) {
  .shop_details {
    margin-top: 4.5333333333vw;
  }
}
@media (min-width: 768px) {
  .shop_details {
    display: flex;
    align-items: flex-end;
  }
}

.shop_details-link {
  display: block;
  position: relative;
  background-color: rgba(var(--c-main-magenta), 1);
  text-align: center;
  font-weight: 600;
  line-height: 1;
}
@media (max-width: 767.98px) {
  .shop_details-link {
    padding-top: 4.2666666667vw;
    padding-bottom: 4.2666666667vw;
    border-radius: 6vw;
    font-size: 3.4666666667vw;
  }
}
@media (min-width: 768px) {
  .shop_details-link {
    padding-top: 15px;
    padding-bottom: 15px;
    border-radius: 22px;
    width: 100%;
    font-size: 16px;
  }
}
@media (min-width: 768px) and (hover: hover) {
  .shop_details-link {
    cursor: pointer;
    transition: opacity 0.2s ease-out;
    transition: opacity 0.2s;
  }
  .shop_details-link:hover {
    opacity: 0.8;
  }
}
.shop_details-link:visited,
.shop_details-link:link {
  text-decoration: none;
  color: rgba(var(--c-true-white), 1);
}

/*
  Coming Common
-------------------------------- */
@media (max-width: 767.98px) {
  .comingsoon {
    padding-top: 16vw;
    padding-bottom: 21.6vw;
  }
}
@media (min-width: 768px) {
  .comingsoon {
    padding-top: 70px;
    padding-bottom: 80px;
  }
}

/*
* top.css
*
*/
/* Overwrite template
-------------------------------- */
@media (min-width: 768px) {
  main.top {
    font-size: 18px;
    line-height: 2;
  }
}

main p {
  margin: inherit;
  font-size: inherit;
  line-height: inherit;
}
@media (max-width: 767.98px) {
  main p {
    margin-top: 0;
  }
}