@keyframes chara_serifshow {
  0% {
    opacity: 0;
    transform: scale(1.25);
  }
  40% {
    opacity: 1;
    transform: scale(1);
  }
  60% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: translate(0, -20%) scale(1);
  }
}
@keyframes chara_catch {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(0, -6px) rotate(-1deg) scale(1.05);
  }
  70% {
    transform: translate(0, 0) rotate(1deg);
  }
  100% {
    transform: translate(0, 0);
  }
}
.character__content {
  position: relative;
}
@media (max-width: 834px) {
  .character__content {
    min-height: 145.83vw;
    overflow: hidden;
    padding: 0 0 33.85vw;
  }
}
@media (min-width: 835px) {
  .character__content {
    margin-top: -110px;
    min-height: 820px;
    padding: 0 0 180px;
  }
}

.character__line {
  position: absolute;
  transition: width 0.7s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  width: 0;
  z-index: -2;
}
@media (max-width: 834px) {
  .character__line {
    height: 21.35vw;
    top: 22.65vw;
  }
}
@media (min-width: 835px) {
  .character__line {
    height: 120px;
    top: 200px;
  }
}
.-hitori .character__line {
  background-color: #ff2291;
}
.-nijika .character__line {
  background-color: #ffb400;
}
.-ryo .character__line {
  background-color: #02d1e0;
}
.-ikuyo .character__line {
  background-color: #ff4637;
}
.-ready .character__line {
  width: 100%;
}

.character__main {
  position: relative;
}
@media (max-width: 834px) {
  .character__main {
    overflow: hidden;
  }
}
@media (min-width: 835px) {
  .character__main {
    margin: 0 auto;
    padding-top: 145px;
    width: min(1060px, 55.2vw);
  }
}

.-hitori .character__upboxex {
  aspect-ratio: 340/414;
  background: url(/omnibus/assets/img/page/character/hitori/ph_face_1.png) no-repeat 0 0/100% auto;
  content: "";
  opacity: 0;
  transform: translate(0, 20px);
  transition: all 0.7s 0.2s cubic-bezier(0.23, 1, 0.32, 1);
  width: 22.13vw;
  z-index: 1;
  position: absolute;
  top: 52.08vw;
  left: 57.42vw;
}
@media (min-width: 835px) {
  .-hitori .character__upboxex {
    display: none;
  }
}
.-ready .character__upboxex {
  opacity: 1;
  transform: translate(0, 0);
}

.character__upbox {
  opacity: 0;
  position: relative;
  transform: translate(0, 20px);
  transition: all 0.7s 0.2s cubic-bezier(0.23, 1, 0.32, 1);
}
@media (max-width: 834px) {
  .-hitori .character__upbox {
    left: 28.64vw;
    width: 83.07vw;
  }
}
@media (min-width: 835px) {
  .-hitori .character__upbox {
    width: min(34.89vw, 670px);
  }
}
@media (max-width: 834px) {
  .-nijika .character__upbox {
    left: 5.2vw;
    top: -1.57vw;
    width: 97.65vw;
  }
}
@media (min-width: 835px) {
  .-nijika .character__upbox {
    width: min(32.13vw, 617px);
  }
}
@media (max-width: 834px) {
  .-ryo .character__upbox {
    left: 28.64vw;
    width: 94.66vw;
  }
}
@media (min-width: 835px) {
  .-ryo .character__upbox {
    width: min(38.95vw, 748px);
  }
}
@media (max-width: 834px) {
  .-ikuyo .character__upbox {
    left: 7.55vw;
    width: 92.44vw;
  }
}
@media (min-width: 835px) {
  .-ikuyo .character__upbox {
    width: min(67.7vw, 1300px);
  }
}
.-ready .character__upbox {
  opacity: 1;
  transform: translate(0, 0);
}

.character__role {
  display: block;
}
@media (min-width: 835px) {
  .-ikuyo .character__role {
    transform: translate(max(-25vw, -480px), 0);
  }
}

.character__txt span {
  animation: chara_serifshow 5s 0s ease infinite;
  display: block;
  opacity: 0;
}
.character__txt.-txt2 span {
  animation-delay: 2.5s;
}
@media (min-width: 835px) {
  .-hitori .character__txt.-txt1 {
    position: absolute;
    top: -18px;
    right: 172px;
    width: min(3.12vw, 60px);
  }
}
@media (min-width: 835px) {
  .-hitori .character__txt.-txt2 {
    position: absolute;
    left: 20px;
    bottom: 65px;
    width: min(4.42vw, 85px);
  }
}
@media (min-width: 835px) {
  .-nijika .character__txt.-txt1 {
    position: absolute;
    top: -25px;
    right: 265px;
    width: min(2.08vw, 40px);
  }
}
@media (min-width: 835px) {
  .-nijika .character__txt.-txt2 {
    position: absolute;
    left: 52px;
    bottom: 95px;
    width: min(4.37vw, 84px);
  }
}
@media (min-width: 835px) {
  .-ryo .character__txt.-txt1 {
    position: absolute;
    top: -15px;
    right: 245px;
    width: min(3.22vw, 62px);
  }
}
@media (min-width: 835px) {
  .-ryo .character__txt.-txt2 {
    position: absolute;
    left: 52px;
    bottom: 105px;
    width: min(3.28vw, 63px);
  }
}
@media (min-width: 835px) {
  .-ikuyo .character__txt.-txt1 {
    position: absolute;
    top: min(17.44vw, 335px);
    left: min(6.25vw, 120px);
    width: min(3.22vw, 62px);
  }
}
@media (min-width: 835px) {
  .-ikuyo .character__txt.-txt2 {
    position: absolute;
    top: -15px;
    left: 3.38vw;
    width: min(2.08vw, 40px);
  }
}

.character__profile {
  color: #fff;
  opacity: 0;
  position: relative;
  transform: translate(0, 20px);
  transition: all 0.7s 0.35s cubic-bezier(0.23, 1, 0.32, 1);
  z-index: 1;
}
@media (max-width: 834px) {
  .character__profile {
    margin: -5.21vw 0 0 45.57vw;
    width: 41.92vw;
  }
}
@media (min-width: 835px) {
  .character__profile {
    margin: -25px 0 0 70px;
    width: 400px;
  }
}
@media (max-width: 834px) {
  .-ikuyo .character__profile {
    margin: -22.14vw 0 0 12.76vw;
  }
}
@media (max-width: 834px) {
  .-nijika .character__profile {
    margin: -5.21vw 0 0 12.76vw;
  }
}
.-ready .character__profile {
  opacity: 1;
  transform: translate(0, 0);
}

.character__profile__cv {
  align-items: center;
  display: flex;
}
.character__profile__cv dt {
  align-items: center;
  border-radius: 50%;
  color: #000;
  display: flex;
  justify-content: center;
}
@media (max-width: 834px) {
  .character__profile__cv dt {
    font-size: 0.625rem;
    height: 20px;
    width: 20px;
  }
}
@media (min-width: 835px) {
  .character__profile__cv dt {
    font-size: 0.8125rem;
    height: 28px;
    width: 28px;
  }
}
.-hitori .character__profile__cv dt {
  background-color: #ff2291;
}
.-nijika .character__profile__cv dt {
  background-color: #ffb400;
}
.-ryo .character__profile__cv dt {
  background-color: #02d1e0;
}
.-ikuyo .character__profile__cv dt {
  background-color: #ff4637;
}
.character__profile__cv dd {
  font-weight: bold;
  padding-left: 5px;
}
@media (max-width: 834px) {
  .character__profile__cv dd {
    font-size: 0.875rem;
  }
}
@media (min-width: 835px) {
  .character__profile__cv dd {
    font-size: 1.25rem;
  }
}
@media (max-width: 834px) {
  .character__profile__cv dd span {
    font-size: 0.875rem;
  }
}
@media (min-width: 835px) {
  .character__profile__cv dd span {
    font-size: 1.25rem;
  }
}
@media (max-width: 834px) {
  .-ikuyo .character__profile__cv dd span {
    display: block;
  }
}

.character__profile__name {
  font-weight: 900;
}
@media (max-width: 834px) {
  .character__profile__name {
    font-size: 1.6875rem;
  }
}
@media (min-width: 835px) {
  .character__profile__name {
    font-size: 2.375rem;
  }
}
.-hitori .character__profile__name {
  color: #ff2291;
}
.-nijika .character__profile__name {
  color: #ffb400;
}
.-ryo .character__profile__name {
  color: #02d1e0;
}
.-ikuyo .character__profile__name {
  color: #ff4637;
}

.character__profile__txt {
  font-weight: 400;
}
@media (max-width: 834px) {
  .character__profile__txt {
    font-size: 0.8125rem;
    line-height: 1.6923076923;
    margin-top: 0.75em;
  }
}
@media (min-width: 835px) {
  .character__profile__txt {
    font-size: 1rem;
    line-height: 1.75;
    margin-top: 12px;
  }
}

.character__image {
  opacity: 0;
  transform: translate(0, 20px);
  transition: all 0.7s 0.4s cubic-bezier(0.23, 1, 0.32, 1);
}
@media (max-width: 834px) {
  .character__image {
    position: absolute;
    top: 3.9vw;
    left: 0vw;
    width: 75.52vw;
  }
}
@media (min-width: 835px) {
  .-hitori .character__image {
    position: absolute;
    top: -45px;
    left: calc(50% - 80px);
    width: min(526px, 27.39vw);
  }
}
@media (max-width: 834px) {
  .-nijika .character__image {
    position: absolute;
    top: 3.9vw;
    left: auto;
    right: -9.12vw;
  }
}
@media (min-width: 835px) {
  .-nijika .character__image {
    position: absolute;
    top: -45px;
    left: calc(50% - 100px);
    width: min(478px, 24.89vw);
  }
}
@media (max-width: 834px) {
  .-ryo .character__image {
    position: absolute;
    top: 3.9vw;
    left: -5.86vw;
  }
}
@media (min-width: 835px) {
  .-ryo .character__image {
    position: absolute;
    top: -45px;
    left: calc(50% - 130px);
    width: min(520px, 27.08vw);
  }
}
@media (max-width: 834px) {
  .-ikuyo .character__image {
    position: absolute;
    top: 3.9vw;
    left: auto;
    right: -8.21vw;
  }
}
@media (min-width: 835px) {
  .-ikuyo .character__image {
    position: absolute;
    top: -45px;
    left: calc(50% - 150px);
    width: min(523px, 27.23vw);
  }
}
.-ready .character__image {
  opacity: 1;
  transform: translate(0, 0);
}

@media (max-width: 834px) {
  .character__catch {
    position: absolute;
    top: 10.41vw;
    left: 0;
    width: 20.83vw;
  }
}
@media (min-width: 835px) {
  .character__catch {
    position: absolute;
    top: 55px;
    left: calc(50% + min(320px, 16.66vw));
    width: min(128px, 6.66vw);
  }
}

.character__catch__name {
  clip-path: inset(0 0 70% 0);
  display: block;
  opacity: 0;
  position: relative;
  transition: all 0.7s 0.3s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  width: 100%;
}
@media (max-width: 834px) {
  .character__catch__name {
    left: -1.31vw;
    z-index: -1;
  }
}
@media (min-width: 835px) {
  .character__catch__name {
    z-index: -1;
  }
}
.-ready .character__catch__name {
  clip-path: inset(0 0 0 0);
  opacity: 0.4;
}

.character__catch__txt {
  opacity: 0;
  transition: opacity 0.7s 0.7s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}
@media (max-width: 834px) {
  .character__catch__txt {
    position: absolute;
    top: -1.31vw;
    left: 3.9vw;
    width: 11.84vw;
  }
}
@media (min-width: 835px) {
  .character__catch__txt {
    position: absolute;
    top: min(-10px, -0.53vw);
    left: min(22px, 1.14vw);
    width: min(83px, 4.32vw);
  }
}
.-ready .character__catch__txt {
  opacity: 1;
}
.-ready .character__catch__txt img {
  animation: chara_catch 0.35s 1s ease-out;
  display: block;
}

.character__prevNext {
  transform: translate(0, -50%);
  transition: all 0.15s ease-out;
}
@media (max-width: 834px) {
  .character__prevNext {
    position: fixed;
    top: 74vh;
    width: 5.46vw;
  }
}
@media (min-width: 835px) {
  .character__prevNext {
    position: fixed;
    top: calc(50% + 140px);
    width: 40px;
  }
}
@media (max-width: 834px) {
  .character__prevNext.-prev {
    left: 15px;
  }
}
@media (min-width: 835px) {
  .character__prevNext.-prev {
    left: 100px;
  }
  .character__prevNext.-prev:hover {
    left: 95px;
  }
}
@media (max-width: 834px) {
  .character__prevNext.-next {
    right: 15px;
  }
}
@media (min-width: 835px) {
  .character__prevNext.-next {
    right: 100px;
  }
  .character__prevNext.-next:hover {
    right: 95px;
  }
}

@media (min-width: 835px) {
  .character__tab {
    padding-top: 7px;
  }
}

.character__tab__inner {
  align-items: flex-start;
  color: #fff;
  display: flex;
  position: relative;
  z-index: 1;
}
@media (max-width: 834px) {
  .character__tab__inner {
    justify-content: space-between;
    margin: 0 30px 0 30px;
  }
}
@media (min-width: 835px) {
  .character__tab__inner {
    gap: 40px;
    margin: 30px 0 0 0;
  }
}

.character__tab__item {
  clip-path: inset(0 100% 0 0);
  line-height: 1;
  position: relative;
  transition: all 0.4s 0.5s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}
@media (max-width: 834px) {
  .character__tab__item {
    font-size: 0.9375rem;
  }
}
@media (min-width: 835px) {
  .character__tab__item {
    font-size: 1.125rem;
  }
}
.character__tab__item a {
  display: block;
  padding-bottom: 6px;
  position: relative;
}
@media (min-width: 835px) {
  .character__tab__item a {
    padding-bottom: 10px;
  }
}
.character__tab__item a::after {
  position: absolute;
  left: 50%;
  bottom: 0;
  background-color: #C45AFF;
  content: "";
  display: block;
  transform: translate(-50%, 0);
  transform-origin: 50% 0;
  transition: width 0.25s ease-out;
  width: 0;
}
@media (max-width: 834px) {
  .character__tab__item a::after {
    height: 2px;
  }
}
@media (min-width: 835px) {
  .character__tab__item a::after {
    height: 4px;
  }
}
.character__tab__item a:hover::after, .character__tab__item.-active a::after {
  width: 130%;
}
.-ready .character__tab__item {
  clip-path: inset(0 0 0 0);
}