/*
base-color
*/
/*
academy-color
*/
/*
brakepoint
*/
/*
main
*/
#main.common_content {
  padding-top: 75px; }
  @media screen and (max-width: 1060px) {
    #main.common_content {
      padding-top: 60px; } }

h2::after {
  background: #D80C18; }

/*
stage
*/
#academy {
  padding: 1% 0 0;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }
  #academy .cbox {
    max-width: 1200px; }

#stage {
  position: relative;
  width: 100%;
  height: 72.8vw;
  max-height: 995px;
  overflow: hidden; }
  @media screen and (max-width: 768px) {
    #stage {
      height: 135vw; } }

#academy_area {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 96.5%;
  z-index: 1;
  opacity: 0; }
  #academy_area.scrollin {
    animation: academy_area 1s ease 0s forwards; }
    @media screen and (max-width: 768px) {
      #academy_area.scrollin {
        animation: academy_area_sp 1s ease 0s forwards; } }
  @media screen and (max-width: 768px) {
    #academy_area {
      width: 148%; } }

#academy_chara {
  width: 59.4%;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  opacity: 0; }
  #academy_chara.scrollin {
    animation: academy_chara 1s ease 0.5s forwards; }
    @media screen and (max-width: 768px) {
      #academy_chara.scrollin {
        animation: academy_chara_sp 1s ease 0.5s forwards; } }
  @media screen and (max-width: 768px) {
    #academy_chara {
      width: 95.4%; } }

#academy_name {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-42.4%, -86%);
  width: 71.1%;
  z-index: 3;
  opacity: 0; }
  #academy_name.scrollin {
    animation: academy_name 1.5s ease-in-out 1.1s forwards; }
  @media screen and (max-width: 768px) {
    #academy_name {
      display: none; } }

#stage1,
#stage2,
#stage3,
#stage4 {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0;
  z-index: 4;
  opacity: 0; }
  #stage1 a,
  #stage2 a,
  #stage3 a,
  #stage4 a {
    display: block;
    position: relative;
    width: 100%;
    height: 100%; }
    #stage1 a::before,
    #stage2 a::before,
    #stage3 a::before,
    #stage4 a::before {
      position: absolute;
      right: -12px;
      bottom: 3px;
      content: "";
      width: 24px;
      height: 20px;
      background: url(../img/academy_arrow.png) left top no-repeat;
      background-size: 24px 20px;
      animation: academy_arrow 0.3s ease 3.5s infinite alternate; }
      @media screen and (max-width: 768px) {
        #stage1 a::before,
        #stage2 a::before,
        #stage3 a::before,
        #stage4 a::before {
          width: 11px;
          height: 9px;
          right: -6px;
          background: url(../img/academy_arrow.png) left top no-repeat;
          background-size: 11px 9px;
          animation: academy_arrow 0.3s ease 2.9s infinite alternate; } }
    #stage1 a:hover img,
    #stage2 a:hover img,
    #stage3 a:hover img,
    #stage4 a:hover img {
      opacity: 1; }

#stage1.scrollin {
  width: 12.8%;
  animation: stage1 0.8s ease 1.8s forwards; }
  @media screen and (max-width: 768px) {
    #stage1.scrollin {
      width: 21.6%;
      animation: stage1_sp 0.8s ease 1.2s forwards; } }

#stage2.scrollin {
  width: 12.8%;
  animation: stage2 0.8s ease 2.1s forwards; }
  @media screen and (max-width: 768px) {
    #stage2.scrollin {
      width: 21.6%;
      animation: stage2_sp 0.8s ease 1.5s forwards; } }

#stage3.scrollin {
  width: 12.8%;
  animation: stage3 0.8s ease 2.4s forwards; }
  @media screen and (max-width: 768px) {
    #stage3.scrollin {
      width: 21.6%;
      animation: stage3_sp 0.8s ease 1.8s forwards; } }

#stage4.scrollin {
  width: 12.8%;
  animation: stage4 0.8s ease 2.7s forwards; }
  @media screen and (max-width: 768px) {
    #stage4.scrollin {
      width: 21.6%;
      animation: stage4_sp 0.8s ease 2.1s forwards; } }

@keyframes academy_area {
  0% {
    opacity: 0;
    transform: translate(-50%, -65%); }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%); } }
@keyframes academy_area_sp {
  0% {
    opacity: 0;
    transform: translate(-50%, -65%); }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%); } }
@keyframes academy_chara {
  0% {
    opacity: 0;
    transform: translate(-42.2%, -89.8%); }
  100% {
    opacity: 1;
    transform: translate(-42.2%, -74.8%); } }
@keyframes academy_chara_sp {
  0% {
    opacity: 0;
    transform: translate(-42.2%, -87.8%); }
  100% {
    opacity: 1;
    transform: translate(-42.2%, -72.8%); } }
@keyframes academy_name {
  0% {
    opacity: 0;
    transform: translate(-42.4%, -81%); }
  20% {
    opacity: 1;
    transform: translate(-42.4%, -88%); }
  30% {
    opacity: 1;
    transform: translate(-42.4%, -88.5%); }
  40% {
    opacity: 1;
    transform: translate(-42.4%, -89%); }
  50% {
    opacity: 1;
    transform: translate(-42.4%, -84%); }
  60% {
    opacity: 1;
    transform: translate(-42.4%, -87%); }
  70% {
    opacity: 1;
    transform: translate(-42.4%, -86%); }
  100% {
    opacity: 1;
    transform: translate(-42.4%, -86%); } }
@keyframes stage1 {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%); }
  100% {
    opacity: 1;
    transform: translate(-337%, -266%); } }
@keyframes stage1_sp {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%); }
  100% {
    opacity: 1;
    transform: translate(-210%, -340%); } }
@keyframes stage2 {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%); }
  100% {
    opacity: 1;
    transform: translate(224%, -266%); } }
@keyframes stage2_sp {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%); }
  100% {
    opacity: 1;
    transform: translate(92.6%, -340%); } }
@keyframes stage3 {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%); }
  100% {
    opacity: 1;
    transform: translate(224%, 80%); } }
@keyframes stage3_sp {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%); }
  100% {
    opacity: 1;
    transform: translate(92.6%, 266%); } }
@keyframes stage4 {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%); }
  100% {
    opacity: 1;
    transform: translate(-337%, 80%); } }
@keyframes stage4_sp {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%); }
  100% {
    opacity: 1;
    transform: translate(-210%, 266%); } }
@keyframes academy_arrow {
  0% {
    transform: translateX(0px); }
  100% {
    transform: translateX(10px); } }
.stagebox {
  position: relative;
  width: 100%;
  max-width: 1200px;
  background: #3B3B3B;
  padding: 85px 135px;
  color: #fff;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  overflow: auto; }
  @media screen and (max-width: 768px) {
    .stagebox {
      padding: 50px 30px 40px; } }
  .stagebox .btn_lityclose {
    position: absolute;
    top: 30px;
    right: 30px;
    content: "";
    width: 40px;
    height: 40px;
    background: url(../img/close_stage.png) left top no-repeat;
    background-size: 40px 40px;
    cursor: pointer; }
    @media screen and (max-width: 768px) {
      .stagebox .btn_lityclose {
        display: none; } }
  .stagebox h3 {
    width: 100%;
    max-width: 271px;
    margin: 0 auto 55px;
    padding: 0;
    line-height: 1; }
    @media screen and (max-width: 768px) {
      .stagebox h3 {
        max-width: 338px;
        margin: 0 auto 25px; } }
  .stagebox .read_stage {
    font-size: 32px;
    margin: 0 auto 45px;
    text-align: center; }
    @media screen and (max-width: 768px) {
      .stagebox .read_stage {
        font-size: 28px;
        margin: 0 auto 35px; } }
    .stagebox .read_stage span {
      font-weight: bold; }
      @media screen and (max-width: 768px) {
        .stagebox .read_stage span {
          display: block;
          font-size: 20px; } }
  .stagebox .stage_shosai {
    display: flex;
    justify-content: center; }
    @media screen and (max-width: 768px) {
      .stagebox .stage_shosai {
        display: block; } }
    .stagebox .stage_shosai h4 {
      font-size: 18px;
      font-weight: bold;
      line-height: 1.5;
      text-align: center;
      padding: 0;
      margin: 0 0 20px; }
      @media screen and (max-width: 768px) {
        .stagebox .stage_shosai h4 {
          font-size: 16px; } }
      .stagebox .stage_shosai h4 span {
        font-family: 'Oswald', sans-serif;
        font-size: 60px;
        font-weight: 400; }
        @media screen and (max-width: 768px) {
          .stagebox .stage_shosai h4 span {
            font-size: 45px; } }
    .stagebox .stage_shosai p {
      margin: 0; }
    .stagebox .stage_shosai ul {
      margin-bottom: 0;
      padding-bottom: 0; }
      @media screen and (max-width: 768px) {
        .stagebox .stage_shosai ul {
          margin-bottom: 35px; } }
      .stagebox .stage_shosai ul li {
        position: relative;
        margin: 0 0 10px 1.2em;
        padding: 0; }
        .stagebox .stage_shosai ul li::before {
          position: absolute;
          left: 0;
          top: 6px;
          width: 10px;
          height: 10px;
          content: "";
          background: #fff;
          margin-left: -1.2em; }
    .stagebox .stage_shosai .do,
    .stagebox .stage_shosai .growth {
      width: 360px;
      max-width: 360px; }
      @media screen and (max-width: 768px) {
        .stagebox .stage_shosai .do,
        .stagebox .stage_shosai .growth {
          width: 100%;
          max-width: 767px; } }
    @media screen and (max-width: 768px) {
      .stagebox .stage_shosai .growth {
        padding-bottom: 100px; } }
    .stagebox .stage_shosai .stage_img {
      width: 100%;
      max-width: 140px;
      margin: 0 25px;
      padding-top: 80px; }
      @media screen and (max-width: 768px) {
        .stagebox .stage_shosai .stage_img {
          display: none; } }
  .stagebox .stagenav {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    transform: translate(-50%, -50%);
    display: flex;
    justify-content: space-between; }
    @media screen and (max-width: 768px) {
      .stagebox .stagenav {
        position: relative; } }
    .stagebox .stagenav .btn_lityclose {
      display: none; }
      @media screen and (max-width: 768px) {
        .stagebox .stagenav .btn_lityclose {
          display: block;
          position: relative;
          top: auto;
          right: auto;
          color: #fff;
          font-size: 14px;
          content: "";
          width: 56px;
          height: auto;
          padding-top: 40px;
          text-align: center;
          background: url(../img/close_stage.png) center top no-repeat;
          background-size: 30px 30px; } }
  .stagebox .prev_stage,
  .stagebox .next_stage {
    width: 30px; }
    @media screen and (max-width: 768px) {
      .stagebox .prev_stage,
      .stagebox .next_stage {
        width: 20px; } }
  .stagebox .prev_stage {
    transform: translateX(40px); }
    @media screen and (max-width: 768px) {
      .stagebox .prev_stage {
        transform: translateX(0); } }
  .stagebox .next_stage {
    transform: translateX(-40px); }
    @media screen and (max-width: 768px) {
      .stagebox .next_stage {
        transform: translateX(0); } }

.lity-close {
  display: none; }
