@charset "utf-8";
.content {
  position: relative;
  padding: 30px 0 0;
  overflow: hidden;
}
.content:after {
  content: "";
  display: block;
  width: 480px;
  height: 10px;
  position: absolute;
  bottom: 0;
  right: 0;
}
.content.meguri {
  height: 1005px;
}
.content.meguri:after {
  background: #b4b5ff;
}
.content.reina {
  height: 1105px;
}
.content.reina:after {
  background: #feb2a5;
}
.content.koiti {
  height: 705px;
}
.content.koiti:after {
  background: #32acf0;
}
.char {
  opacity: 0;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.char.show {
  opacity: 1;
  -webkit-transform: scale(1);
          transform: scale(1);
}
.char__head {
  margin-bottom: 10px;
}
.koiti .char__head {
  margin-bottom: 50px;
}
.charInner {
  width: 480px;
  position: relative;
}
.char__voice {
  width: 280px;
  position: relative;
  margin-left: auto;
  margin-bottom: 30px;
}
.char__voice__name {
  position: absolute;
  bottom: 0;
  right: 0;
}
.voiceList {
  display: table;
}
.voiceList > li {
  display: table-cell;
  padding-right: 5px;
}
.voiceList > li > a {
  display: block;
  width: 30px;
  height: 30px;
  background-color: #ddd;
  box-shadow: 0 0 15px rgba(0,0,0,0.07) inset;
  border-radius: 2px;
  text-decoration: none;
  transition: background-color 150ms linear;
}
.voiceList > li > a:before {
  width: 30px;
  height: 30px;
  color: #fff;
  font-size: 20px;
  line-height: 30px;
  text-align: center;
}
.meguri .voiceList > li > a:hover,
.meguri .voiceList > li > a[data-playing="true"] {
  background: #6f75da;
}
.reina .voiceList > li > a:hover,
.reina .voiceList > li > a[data-playing="true"] {
  background: #c7566d;
}
.char__variation {
  width: 280px;
  margin-left: auto;
  margin-bottom: 30px;
}
.char__variation:after {
  content: "";
  display: block;
  clear: both;
}
.char__variation > li {
  float: left;
  height: 30px;
  padding: 0 15px;
  border-radius: 2px;
  background: #ddd;
  box-shadow: 0 0 15px rgba(0,0,0,0.07) inset;
  color: #fff;
  font-size: 14px;
  line-height: 30px;
  letter-spacing: 0.15em;
  text-indent: 0.15em;
  cursor: pointer;
  transition: background-color 150ms linear;
}
.char__variation > li + li {
  margin-left: 10px;
}
.meguri .char__variation > li:hover {
  background: #6f75da;
}
.reina .char__variation > li:hover {
  background: #c7566d;
}
.meguri .char__variation > li.current,
.reina .char__variation > li.current {
  background: #fff;
  box-shadow: none;
  color: #333;
  cursor: default;
}
.char__profile {
  width: 280px;
  margin-left: auto;
  margin-bottom: 50px;
}
.char__profile > dt {
  float: left;
  width: 70px;
  height: 24px;
  margin-bottom: 5px;
  padding: 0 10px;
  border-radius: 3px 0 0 3px;
  line-height: 24px;
  text-align: right;
}
.char__profile > dd {
  width: 170px;
  margin-bottom: 5px;
  padding: 0 10px;
  background: #fff;
  border-radius: 0 3px 3px 0;
  line-height: 24px;
  overflow: hidden;
}
.meguri .char__profile > dt {
  background: #d9daff;
}
.reina .char__profile > dt {
  background: #fed8d2;
}
.koiti .char__profile > dt {
  background: #c1e6fa;
}
.char__desc {
  margin-top: -0.6em;
  line-height: 2.2;
  text-align: right;
}
.koiti .char__desc {
  width: 430px;
  position: absolute;
  top: 0;
  left: 530px;
  z-index: 1;
  line-height: 1.6;
  text-align: left;
}
.char__img {
  position: absolute;
  top: 40px;
  right: 60px;
}
.char__img > img {
  display: none;
  position: relative;
}
.meguri .char__img > img:nth-child(2) {
  right: 50px;
}
.reina .char__img > img:nth-child(2) {
  left: 15px;
}
.char__word {
  position: absolute;
  top: 15px;
}
.meguri .char__word {
  right: -50px;
}
.reina .char__word {
  right: -70px;
}
.koiti .char__word {
  right: -50px;
}
.charList {
  position: absolute;
  top: 215px;
  left: 0;
}
.charList > li {
  width: 120px;
  height: 120px;
  position: relative;
  margin-left: -60px;
  margin-bottom: 20px;
  border: solid 3px #fff;
  border-radius: 50%;
  box-sizing: border-box;
  cursor: pointer;
}
.charList > li:after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0,0,0,0.3);
  border-radius: 50%;
  transition: background-color 150ms linear;
}
.charList > li:hover:after,
.charList > li.current:after {
  background-color: rgba(0,0,0,0);
}
.charList > li.current {
  box-shadow: none;
  cursor: default;
}
.charList > li .name {
  display: table;
  width: 1em;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto 0;
  font-size: 16px;
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  text-shadow: 0 2px #fff, 2px 0 #fff, 0 -2px #fff, -2px 0 #fff;
  line-height: 1.2;
  -webkit-transform: translateX(0px);
          transform: translateX(0px);
  opacity: 0;
  transition: opacity 150ms ease-out, -webkit-transform 150ms ease-out;
  transition: transform 150ms ease-out, opacity 150ms ease-out;
  transition: transform 150ms ease-out, opacity 150ms ease-out, -webkit-transform 150ms ease-out;
}
.charList > li:hover .name,
.charList > li.current .name {
  -webkit-transform: translateX(30px);
          transform: translateX(30px);
  opacity: 1;
}
.charList__meguri {
  background-color: #b4b5ff;
  background-image: url("../../images/char/meguri_char.png");
  background-repeat: no-repeat;
  background-size: 180%;
  background-position: 0 -10px;
  box-shadow: 0 2px #b4b5ff, 0 1px #b4b5ff inset;
  color: #6f75da;
}
.charList__reina {
  background-color: #feb2a5;
  background-image: url("../../images/char/reina_char.png");
  background-repeat: no-repeat;
  background-size: 180%;
  background-position: -50px -10px;
  box-shadow: 0 2px #feb2a5, 0 1px #feb2a5 inset;
  color: #c7566d;
}
.charList__koiti {
  background-color: #32acf0;
  background-image: url("../../images/char/koiti_char.png");
  background-repeat: no-repeat;
  background-size: 120%;
  background-position: 0 -10px;
  box-shadow: 0 2px #32acf0, 0 1px #32acf0 inset;
  color: #32acf0;
}
