@charset "UTF-8";

/* --------------------------------------------
 * HEADER
 * ------------------------------------------ */
/* -------------------
 * PC
 * ---------------- */

header {
  position: fixed;
  width: 100%;
  z-index: 21;
 }

.header {
  position: relative;
  width: 100%;
  background-color: var(--color-white);
  border-bottom: 1px solid var(--color-extralightgray);
  z-index: 20;
}

.header-flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 20px;
  transition: padding 0.6s ease;
}

.header::before {
  content: "";
  display: block;
  width: 100%;
  height: 8px;
  background-color: var(--color-primary);
  text-align: center;
  color: var(--color-white);
  transition: height 0.6s ease;
}

.header_logo a {
  width: 140px;
  display: block;
}

.header_logo img {
  width: 100%;
  height: auto;
}

.pc-menu-info_item-title {
  font-size: var(--size-ssss);
  color: var(--color-text);
  line-height: 1.2;
}

/* 新規登録、ログイン icon */
.header-icon {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.header-icon_btn a {
  border-radius: 4px;
  padding: 4px 24px;
  margin: 0 4px;
  font-size: var(--size-sss);
  font-weight: bold;
  color: var(--color-text);
  background-color: var(--color-accent);
  border: 1px solid var(--color-darkgray);
  transition: background-color 0.5s ease;
}

.header-icon_btn a:hover {
  background-color: var(--color-bg-pink);
  color: var(--color-text);
}

/* カート マイページ アイコン */
.header-icon_cart {
  position: relative;
  width: 50px;
  height: 40px;
  padding-left: 12px;
}

.header-icon_item,
.header-icon_cart {
  min-width: 54px;
  height: 40px;
  text-align: center;
}

.header-icon_cart a,
.header-icon_item a {
  display: block;
}

.header-icon_cart img,
.header-icon_item img {
  width: 30px;
  height: 31px;
}

.header-icon_cart span,
.header-icon_item span {
  display: block;
  color: var(--color-primary);
  font-size: var(--size-ssss);
  margin-top: -4px;
  text-align: center;
}

.header-icon_cart .cart-num {
  display: inline-block;
  position: absolute;
  top: -2px;
  right: -2px;
  min-width: 17px;
  min-height: 17px;
  background-color: var(--color-accent);
  color: var(--color-text);
  font-size: var(--size-ssss);
  font-weight: bold;
  text-align: center;
  border-radius: 8px;
  padding-top: 2px;
}

.header-icon_menu {
  width: 46px;
  height: 32px;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.header-icon_menu-guide {
  color: var(--color-primary);
  font-size: var(--size-ssss);
  margin-top: -4px;
}

.header-info {
  display: flex;
  align-items: center;
  margin-right: 20px;
}

.member {
  padding-right: 12px;
}

.member_rank {
  display: flex;
  align-items: center;
  font-size: var(--size-ssss);
  color: var(--color-text);
}

.member_rank::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  text-align: center;
}

.member_rank[data="none"]::before {
  width: 100%;
  text-align: left;
  content: "一般会員";
  display: inline-block;
}

.member_rank[data="bronze"]::before {
  background-image: url(../img/common/icons/icon_rank-bronze.png);
}
.member_rank[data="bronze"]::after {
  content: "ブロンズ";
  display: inline-block;
}

.member_rank[data="silver"]::before {
  background-image: url(../img/common/icons/icon_rank-silver.png);
}
.member_rank[data="silver"]::after {
  content: "シルバー";
}

.member_rank[data="gold"]::before {
  background-image: url(../img/common/icons/icon_rank-gold.png);
}
.member_rank[data="gold"]::after {
  content: "ゴールド";
}

.member_rank[data="platinum"]::before {
  background-image: url(../img/common/icons/icon_rank-platinum.png);
}
.member_rank[data="platinum"]::after {
  content: "プラチナ";
}

.member_name {
  min-width: 100px;
  max-width: 200px;
  line-height: 1.0;
  font-size: var(--size-sss);
  color: var(--color-text);
}

.member-point {
  font-size: var(--size-ss);
  text-align: center;
}

.member-point-title {
  font-size: var(--size-ssss);
  color: var(--color-text);
}

.member-point-text {
  font-size: var(--size-ss);
  font-weight: bold;
  color: var(--color-text);
}

@media screen and (max-width: 900px) {
  .member {
    padding-right: 0;
    margin-bottom: 20px;
  }

  .member_name {
    font-size: var(--size-s);
  }

  .member-point-title {
    font-size: var(--size-ss);
  }

  .member-point-text {
    font-size: var(--size-m);
  }

  .pc-menu-info_item-title {
    display: none;
  }
}

/* --------------------------------------------
 * グローバルメニュー
 * ------------------------------------------ */

.global-menu {
  position: relative;
  z-index: 10;
  box-shadow: 0px 4px 4px -2px rgba(0,0,0,0.1);
}

.pc-menu {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  background-color: var(--color-white);
}

.pc-menu_item a,
.dropdown-title {
  display: block;
  color: var(--color-primary);
  font-size: var(--size-sss);
  font-weight: bold;
  padding: 16px 24px;
  transition: padding 0.6s ease;
}

.pc-menu_item  {
  position: relative;
  color: var(--color-white);
}

.pc-menu_item a::after {
  content: "";
  position: absolute;
  bottom: 12px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 0;
  height: 2px;
  background-color: var(--color-accent);
  transition: .3s;
}

.pc-menu_dropdown {
  display: block;
  width: 100%;
  min-width: 150px;
  background-color: var(--color-primary);
  border: 2px solid var(--color-extralightgray);
  overflow: hidden;
  position: absolute;
  top: calc(100% - 2px);
  left: 0;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  z-index: -1;
}
.pc-menu_dropdown.hidden {
  position: absolute;
  pointer-events: none;
  transform: translateY(-100%);
  z-index: -1;
}

.pc-menu_dropdown_item a {
  color: var(--color-white);
}

.pc-menu_dropdown_item a:hover {
  background-color: var(--color-white);
  color: var(--color-link);
  text-decoration: underline;
}

.is-arrow-drop {
  position: relative;
  padding-right: 8px;
}

.is-arrow-drop:after {
  content: "";
  position: absolute;
  top: calc(50% - 4px);
  right: 16px;
  width: 4px;
  height: 4px;
  border: 1px solid;
  border-color: transparent transparent var(--color-darkgray) var(--color-darkgray);
  transform: rotate(-45deg);
}

.sp-menu {
  display: none;
}

/* -------------------
 * スマホ
 * ---------------- */
@media screen and (max-width: 900px) {
  .pc-menu {
    display: none;
  }

  .sp-menu {
    display: block;
  }

  .header_logo a {
    width: 220px;
  }

  .header-info {
    display: none;
  }

  /* アクセシビリティ対策 */
  .visuallyHidden {
    border: 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    white-space: nowrap;
    width: 1px;
  }

  /* ハンバーガーボタン */
  .hamburger {
    appearance: none;
    background-color: transparent;
    border: none;
    cursor: pointer;
    display: block;
    width: 40px;
    height: 24px;
    /* outline: none; */
    position: relative;
    transition: transform .6s, width .6s;
    z-index: 100;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }

  .hamburger-line {
    background-color: var(--color-primary);
    height: 3px;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 0;
    transition: inherit;
    width: 100%;
  }

  .hamburger-line::before,
  .hamburger-line::after {
    background-color: var(--color-primary);
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    transition: inherit;
    width: 100%;
  }

  .hamburger-line::before {
    top: 10px;
  }
  .hamburger-line::after {
    top: 20px;
  }

  /* open */
  .hamburger[aria-expanded="true"] .hamburger-line {
    transform: translateY(12px) rotate(-45deg);
  }
  .hamburger[aria-expanded="true"] .hamburger-line::before {
    transform: translateY(-12px) translateX(20px) rotate(45deg);
    width: 0;
  }
  .hamburger[aria-expanded="true"] .hamburger-line::after {
    transform: translateY(-20px) rotate(90deg);
  }

  .overlay {
    background-color: #333;
    cursor: pointer;
    height: 100vh;
    left: 0;
    opacity: 0;
    position: fixed;
    top: 0;
    transition: opacity .6s, visibility .6s;
    visibility: hidden;
    width: 100vw;
    z-index: 10;
  }

  .overlay.active {
    opacity: .8;
    visibility: visible;
  }

  /* メニュー */
  .modal-container {
    background-color: var(--color-primary);
    position: fixed;
    z-index: 31;
  }

  .modal-container {
    height: 100%;
    right: -100%;
    transition: right .6s ease-in-out;
    width: 90%;
    max-width: 480px;
  }

  .modal-container[aria-hidden="false"] {
    right: 0;
    transition: right .6s ease-in-out;
  }

  .modal-container[aria-hidden="false"] {
    overflow-y: scroll;
  }

  .sp-menu-container {
    padding: 0;
    padding-bottom: 140px;
  }

  .sp-menu-info {
    background-color: var(--color-white);
    border-radius: 8px;
    padding: 12px;
    margin: 12px;
    display: flex;
    justify-content: space-around;
    text-align: center;
  }

  .sp-menu-info_item-title {
    font-size: var(--size-ss);
    font-weight: bold;
    color: var(--color-darkgray);
    margin-bottom: 4px;
  }

  .sp-menu-info_item-btn a {
    display: block;
    background-color: var(--color-accent);
    border: 2px solid var(--color-darkgray);
    border-radius: 6px;
    padding: 6px 24px;
    font-size: var(--size-ss);
    color: var(--color-text);
  }

  .sp-menu-info_item-point {
    font-size: var(--size-m);
    font-weight: bold;
    color: var(--color-primary);
  }

  .sp-menu-title {
    font-size: var(--size-sss);
    font-weight: bold;
    color: var(--color-white);
    padding: 4px 8px;
  }

  .sp-menu_item-link {
    display: block;
    background-color: var(--color-white);
    color: var(--color-text);
    font-size: var(--size-ss);
    padding: 12px;
    border-bottom: 1px solid var(--color-extralightgray);
  }

  /* 右 */
  .sp-menu_item-link.is-arrow-r {
    position: relative;
  }
  .sp-menu_item-link.is-arrow-r::after {
    content: "";
    position: absolute;
    top: calc(50% - 4px);
    right: 16px;
    width: 4px;
    height: 4px;
    border: 1px solid;
    border-color: transparent transparent var(--color-gray) var(--color-gray);
    transform: rotate(-135deg);
  }

  .header-icon_cart {
    padding-left: 0;
    padding-right: 12px;
  }

  .header-icon_cart .cart-num {
    right: 12px;
  }
}

@media screen and (max-width: 900px) {
  .header_logo a {
    width: 120px;
  }

  .header-flex {
    padding: 8px 12px 10px 12px;
  }

  .header-icon_btn a {
    font-size: var(--size-sss);
    padding: 4px 6px;
    margin-right: 12px;
  }
}

@media screen and (max-width: 320px) {
  .header-icon_btn a {
    font-size: 10px;
  }
}

/* --------------------------------------------
 * FOOTER
 * ------------------------------------------ */

footer {
  position: relative;
  background-color: var(--color-primary);
  padding-top: var(--size-xl);
  z-index: 20;
}

footer::before {
  content: '';
  position: absolute;
  width: 100%;
  height: clamp(3.75rem, 3rem + 3.75vw, 7.5rem);
  top: clamp(-4.375rem, -3.824rem + 0.98vw, -5rem);
  left: 0;
  background-origin: border-box;
  background-size: 100% auto;
  background-position: center bottom;
  background-repeat: no-repeat;
  background-image: url('../img/common/wave-footer.svg');
}

.footer {
  background-origin: border-box;
  background-size: 100% auto;
  background-position: center bottom;
  background-repeat: no-repeat;
  background-image: url('../img/common/wave-footer-base.svg');
}

.footer-container {
  max-width: var(--width-m);
  display: flex;
  justify-content: space-around;
  margin-left: auto;
  margin-right: auto;
  padding-top: var(--size-l);
  padding-bottom: var(--size-xxl);
}

.footer-link_title {
  color:  var(--color-white);
  font-size: var(--size-ss);
  font-weight: bold;
  margin-bottom: 4px;
}

.footer-link_item {
  font-size: var(--size-s);
  margin: 8px 0;
}

.footer-link_item li {
  padding: 4px 12px;
}

.footer-link_other li {
  padding: 6px 0;
}

.footer-link_item li a,
.footer-link_other ul li a {
  position: relative;
  display: inline-block;
  color: var(--color-white);
  font-size: var(--size-sss);
  padding-left: 12px;
}

.footer-link_item li a:hover,
.footer-link_other ul li a:hover {
  text-decoration: underline;
}

.footer-link_item li a::after,
.footer-link_other ul li a::after {
  content: "";
  position: absolute;
  top: calc(50% - 4px);
  left: 0;
  width: 4px;
  height: 4px;
  border: 1px solid;
  border-color: transparent transparent var(--color-white) var(--color-white);
  transform: rotate(-135deg);
}

/* SNS */
.footer-link_sns li {
  padding: 2px 0;
}

.footer-link_sns li a {
  color:  var(--color-white);
  font-size: 13px;
  padding-left: 12px;
  position: relative;
}

.footer-link_sns li a:hover {
  text-decoration: underline;
}

.footer-link_sns li a::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  vertical-align: middle;
  background-image: url(../img/common/icons/icon_open-in-new.svg);
  background-size: contain;
  background-repeat: no-repeat;
  margin-bottom: 4px;
  margin-left: 4px;
}

.footer-logo {
  padding-bottom: clamp(6.25rem, 5.147rem + 1.96vw, 7.5rem);
  text-align: center;
}

.footer-logo img {
  width: 90%;
  max-width: 320px;
  height: auto;
}

.copyright-container {
  background-color: var(--color-bg-base);
  margin-top: -1px;
  text-align: center;
}

.copyright {
  padding: 20px 8px;
  font-size: var(--size-ssss);
  color: var(--color-primary);
}

.top-to-btn {
  position: absolute;
  bottom: 40px;
  right: 12px;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background-color: var(--color-primary);
  display: grid;
  place-content: center;
  color: var(--color-white);
  font-size: 12px;
  text-align: center;
  z-index: 10;
}

@media screen and (max-width: 900px) {
  footer::before {
    top: clamp(-2.5rem, -1.81rem + 3.45vw, -3.75rem);
    background-image: url('../img/common/wave-footer-sp.svg');
  }

  .footer {
    background-image: url('../img/common/wave-footer-base-sp.svg');
  }

  .footer-container {
    display: block;
    padding: 32px 20px 60px 20px;
  }

  .copyright {
    padding: 20px 8px 40px 8px;
  }

  .footer-logo {
    padding-bottom: clamp(5rem, 4.31rem + 3.45vw, 6.25rem);
  }
}

/* animation */
.header-flex.is-animation {
  padding: 6px 20px 8px 20px;
  transition: padding 0.6s ease;
}

.pc-menu_item.is-animation a,
.dropdown-title.is-animation {
  padding: 10px 24px;
  transition: padding 0.6s ease;
}

@media screen and (max-width: 900px) {
  .header-flex.is-animation {
    padding: 8px 12px 10px 12px;
  }

  .pc-menu_item.is-animation a,
  .dropdown-title.is-animation {
    padding: 16px 24px;
    transition: none;
  }
}