@charset "UTF-8";
a[target=_blank]:not([class])::after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: none;
}

body {
  background-color: #f5f5f5;
  color: #2f2121;
}

a {
  color: #1A1719;
}
a:hover {
  color: #2b2b2b;
}

.btn--main {
  background: #333;
  color: #fff;
  font-weight: bold;
  border-radius: 30px;
}
.btn--main:hover {
  background: #111;
}

.btn--birthday i::before {
  transition: none;
}

.btn--sub {
  background: transparent;
  color: #333;
  border-radius: 20em;
}
.btn--sub:hover {
  color: #fff;
  background: #333;
  transition: all 0.2s ease;
}

.detail__btn a::before {
  border-color: #000000;
}

/* 非会員 */
#mypage--app section .area--user-status.status--free {
  background: #999;
}

/* 有料会員 */
#mypage--app section .area--user-status.status--member {
  background: #333;
}

/*FANTY ID レイアウト調整*/
.list--menu .menu__status {
  right: -68%;
}

.list--menu span, .list--payment span {
  width: 60%;
}

@media screen and (min-width: 1px) and (max-width: 755px) {
  .list--menu span {
    width: 65%;
  }
  .list--menu .menu__status {
    right: -55%;
  }
}
.block--card {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  transition: display 0.3s ease;
  /* close icon */
}
.block--card .block--card--inner {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  height: 100%;
  padding-top: 6vh;
}
.block--card .close {
  display: inline-block;
  position: absolute;
  right: 0;
  left: 0;
  top: calc(4dvh + 560px);
  z-index: 100;
  max-width: 200px;
  margin: 0 auto;
  padding: 0.8em;
  border-radius: 100em;
  border: solid 1px #111;
  background: rgba(255, 255, 255, 0);
  color: #111;
  text-align: center;
  cursor: pointer;
}
.block--card .card {
  overflow: hidden;
  width: 300px;
  height: 520px;
  border: solid 3px #DA1870;
  border-radius: 1.6em;
  background: white;
  font-family: neue-haas-grotesk-display, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.01em;
  box-shadow: 0px 5px 15px 0 rgba(0, 0, 0, 0.3);
}
.block--card .card .card--inner {
  display: flex;
  flex-wrap: nowrap;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
}
.block--card .card .card--inner .block--tit--wrap {
  width: 44%;
  border-right: solid 1px #111;
}
.block--card .card .card--inner .block--logo {
  width: 80%;
  margin: 2em auto;
}
.block--card .card .card--inner .block--caption {
  color: #DA1870;
  font-weight: 100;
  font-size: 60px;
  line-height: 0.86;
  letter-spacing: 0;
  transform: rotate(90deg) translateY(0.05em);
}
.block--card .card .card--inner .block--status--wrap {
  width: 56%;
}
.block--card .card .card--inner .block--photo {
  width: 100%;
  height: 60%;
}
.block--card .card .card--inner .block--photo figure {
  overflow: hidden;
  position: relative;
  height: 100%;
}
.block--card .card .card--inner .block--photo figure::after {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-color: #DA1870;
}
.block--card .card .card--inner .block--photo figure img {
  display: block;
  position: absolute;
  top: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background: no-repeat center center;
  background-size: contain;
  line-height: 0;
}
.block--card .card .card--inner .block--photo figure .blur {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  filter: blur(20px);
  transform: scale(1);
}
.block--card .card .card--inner .block--photo figure .blur img {
  width: 100%;
  height: 100%;
  background-size: cover;
  line-height: 0;
  transform: scale(1.5);
}
.block--card .card .card--inner .block--status {
  width: 100%;
  margin: 0 auto;
  color: #111;
}
.block--card .card .card--inner .block--status .nickname,
.block--card .card .card--inner .block--status .joindate,
.block--card .card .card--inner .block--status .number {
  padding: 1em;
  border-top: solid 1px #111;
}
.block--card .card .card--inner .block--status .item--tit {
  display: block;
  margin-bottom: 0.2em;
  font-size: 11px;
  line-height: 1;
  letter-spacing: 0.001em;
}
.block--card .card .card--inner .block--status .item--name, .block--card .card .card--inner .block--status .item--status, .block--card .card .card--inner .block--status .item--number {
  font-weight: 800;
  font-size: 14px;
  line-height: 0.8;
}
.block--card.basic .block--card--inner {
  background: rgba(255, 255, 255, 0);
}
.block--card.basic .card .card--inner .block--status {
  color: #111;
}
.block--card.type--app .block--card--inner {
  padding-top: 3vh;
  padding-top: 3dvh;
}
.block--card.type--app .card {
  max-height: 480px;
}
.block--card.type--app .close {
  bottom: 9vh;
  bottom: 9dvh;
}

body.card-visible .block--card {
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
}
body.card-visible .block--card .card .card--inner .block--photo figure.trigger--delay::after {
  height: 0%;
  transition: height 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.5s;
}/*# sourceMappingURL=mypage-service.css.map */