.album-inner {
  width: 100%;
  margin: 3rem auto 0;
}

.album {
  width: 100%;
  margin: 0 0 6rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.album-explain {
  width: 50%;
  margin: 0 5% 0 0;
}

.album-explain p {
  font-size: 16px;
  line-height: 1.8;
  font-feature-settings: 'palt';
}

.album-explain p span {
  display: block;
  margin: 0 0 0.6em;
  font-size: 34px;
  font-weight: 700;
}

.album-jaket {
  width: 45%;
}

.album-text {
  width: 70%;
}

.album-text p {
  margin: 0 0 0;
  font-size: 22px;
  font-weight: 400;
  font-feature-settings: 'palt';
}

a.table_link:hover {
  color: #ff5500;
}

.store {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  line-height: 1.4;
  margin: 0 0 3rem;
}

.store-name {
  width: 46%;
  max-height: 3.4em;
  padding: 0.3em 1em;
  color: #fff;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.store-name:nth-child(odd) {
  background: #444;
}

.store-name:nth-child(even) {
  background: #1a1a1a;
}

.store-goods {
  width: 42%;
  max-height: 3.4em;
  padding: 0.3em 1em;
  color: #1a1a1a;
  background: #fff3ba;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.store-goods:nth-child(odd) {
  background: #fbec99;
}

.store-goods:nth-child(even) {
  background: #f0da6a;
}

.store-buy {
  width: 12%;
  max-height: 3.4em;
  padding: 0.3em;
  text-align: center;
  color: #1a1a1a;
  background: #ffd300;
  display: flex;
  justify-content: center;
  align-items: center;
}

.store-buy:nth-child(odd) {
  background: #d2ecfa;
}

.store-buy:nth-child(even) {
  background: #c1e3f6;
}

.playlist {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.playlist-list {
  width: 48%;
  margin: 0 4% 0 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}

.playlist-num {
  width: 5%;
  margin: 0 2% 0.3em 0;
}

.playlist-name {
  width: 92%;
  margin: 0 0 0.3em 0;
  overflow-wrap: break-word;
}

.playlist-name .credit {
  font-size: 13px;
  margin-bottom: 0;
  padding-left: 3em;
  text-indent: -3em;
}

.playlist-name .desc {
  width: 100%;
}

.playlist-thumb {
  width: 48%;
  margin: 0 0 0 0;
}

.mov-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.mov-thumb iframe {
  width: 100%;
  height: 100%;
}

.mov-thumb-m {
  margin: 0 0 2rem;
}

.mov-thumb-name {
  width: 100%;
  padding: 0.4em 0;
  background: #f5d952;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 15px;
}

@media screen and (min-width: 1px) and (max-width: 767px) {
  .album-inner {
    margin: 2rem auto 0;
  }

  .album {
    width: 100%;
    margin: 0 0 3rem;
    display: block;
  }

  .album-explain {
    width: 100%;
    margin: 0;
  }

  .album-explain p {
    font-size: 14px;
  }

  .album-explain p span {
    display: block;
    margin: 0 0 0.6em;
    font-size: 20px;
  }

  .album-jaket {
    width: 80%;
    margin: 0 auto 2rem;
  }

  .album-text {
    width: 100%;
  }

  .album-text p {
    margin: 0;
    font-size: 16px;
  }

  .store-name {
    width: 100%;
    height: auto;
    padding: 0.3em 1em;
  }

  .store-name:nth-child(odd) {
    background: #1a1a1a;
  }

  .store-name:nth-child(even) {
    background: #1a1a1a;
  }

  .store-goods {
    width: 70%;
    height: auto;
  }

  .store-goods:nth-child(odd) {
    background: #f0da6a;
  }

  .store-goods:nth-child(even) {
    background: #fbec99;
  }

  .store-buy {
    width: 30%;
    height: auto;
  }

  .store-buy:nth-child(odd) {
    background: #d2ecfa;
  }

  .store-buy:nth-child(even) {
    background: #d2ecfa;
  }

  .playlist {
    display: block;
    font-size: 14px;
  }

  .playlist-name .credit {
    font-size: 12px;
  }

  .playlist-list {
    width: 100%;
    margin: 0 4% 2rem 0;
  }

  .playlist-thumb {
    width: 100%;
  }

  .mov-thumb-name {
    padding: 0.4em 0;
    text-align: center;
    font-size: 14px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
  .album-inner {
    margin: 2rem auto 0;
  }

  .album-explain p {
    font-size: 14px;
  }

  .album-explain p span {
    font-size: 28px;
  }

  .album-text p {
    margin: 0 0 0;
    font-size: 18px;
    font-weight: 400;
    font-feature-settings: 'palt';
  }

  .store {
    font-size: 14px;
    margin: 0 0 2rem;
  }

  .mov-thumb-name {
    text-align: center;
    font-size: 12px;
  }
}
