.member-panel {
  width: 100%;
  margin: .5em 0 0;
  padding: .4em .5em;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .35em;
  font-size: .78em;
  color: #05313b;
}

.member-panel button,
.member-dialog button {
  border: 1px solid #000;
  background: #fee;
  color: #000;
  padding: .25em .6em;
  border-radius: 3px;
  cursor: pointer;
}

#memberOpenBtn {
  background: #fff2b8;
  font-weight: 700;
}

.member-panel button:hover,
.member-dialog button:hover {
  background: #ffd8d8;
}

.member-panel span {
  max-width: 11em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.member-locked {
  opacity: .55;
}

.member-locked label::after {
  content: " " attr(data-member-label);
  color: #a33;
  font-size: .9em;
}

.member-dialog {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(0, 0, 0, .36);
}

.member-dialog-inner {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(92vw, 520px);
  transform: translate(-50%, -50%);
  background: #70cdfb;
  border: .15rem outset #66cbff;
  border-radius: .35rem;
  box-shadow: 0 0 .6em #000;
  padding: 1em;
  text-align: left;
  font-size: .86em;
}

.member-dialog-title {
  font-size: 1.18em;
  color: #000;
  margin: 0 0 .6em;
  text-align: center;
  font-weight: 700;
}

.member-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .65em;
  margin: 0 0 .8em;
}

.member-intro-card {
  border: 1px solid rgba(0, 0, 0, .35);
  border-radius: .25rem;
  padding: .58em;
  background: rgba(255, 255, 255, .55);
}

.member-intro-card strong {
  display: block;
  margin: 0 0 .32em;
  color: #000;
  font-size: .9em;
  font-weight: 700;
}

.member-intro-card span {
  display: block;
  line-height: 1.4;
  font-size: .88em;
}

.member-intro-card em {
  display: inline-flex;
  margin-top: .5em;
  padding: .12em .46em;
  border: 1px solid rgba(0, 0, 0, .25);
  border-radius: 999px;
  background: #fff2b8;
  color: #4a2a00;
  font-style: normal;
  font-size: .68em;
  font-weight: 700;
}

.member-plan-pro-vvip {
  background: rgba(242, 235, 255, .76);
}

.member-price-card {
  padding: .6em;
}

.member-price-row {
  display: grid;
  grid-template-columns: auto minmax(5.8em, 1fr);
  gap: .16em .42em;
  align-items: center;
  border: 1px solid rgba(0, 0, 0, .18);
  border-radius: .22rem;
  padding: .34em .44em;
  background: rgba(255, 247, 214, .58);
}

.member-price-row + .member-price-row {
  margin-top: .38em;
}

.member-plan-name {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3em;
  border: 1px solid rgba(0, 0, 0, .35);
  border-radius: 999px;
  padding: .06em .42em;
  background: #fff;
  font-size: .68em;
  font-weight: 700;
}

.member-plan-price {
  color: #262626;
  font-size: .86em;
  font-weight: 700;
  line-height: 1.15;
  white-space: nowrap;
}

.member-plan-note {
  grid-column: 2;
  color: #555;
  font-size: .62em;
  line-height: 1.25;
}

#memberCopyWechatBtn {
  margin-top: .55em;
  background: #fff2b8;
}

.member-dialog-status {
  min-height: 2.2em;
  margin: 0 0 .65em;
  line-height: 1.4;
  text-align: center;
}

.member-redeem-box {
  display: grid;
  gap: .35em;
}

.member-redeem-box label {
  color: #000;
  font-size: .9em;
}

#memberCodeInput {
  width: 100%;
  padding: .55em;
  border: 1px solid #000;
  background: #fee;
  color: #000;
}

.member-dialog-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .8em;
  margin: 1em 0 0;
}

@media (max-width: 991.98px) {
  .member-panel {
    font-size: .22rem;
    margin: .1rem 0 0;
    padding: .05rem;
  }

  .member-panel span {
    max-width: 4rem;
  }

  .member-dialog-inner {
    width: 82vw;
    padding: .3rem;
  }

  .member-intro {
    grid-template-columns: 1fr;
    gap: .18rem;
  }

  .member-dialog-actions {
    gap: .2rem;
    flex-wrap: wrap;
  }
}
