@media screen and (min-width: 769px), print {
  .visions {
    text-align: center;
    padding: 80px 0;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  }
  .visions h2 {
    font-size: 3.5rem;
    line-height: 5.8rem;
    color: #15126F;
    margin-bottom: 50px;
    font-weight: 600;
    letter-spacing: 5px;
    overflow: hidden;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto 50px;

  }
  .visions h2 em {
    font-style: normal;
  }
  .visions h3 {
    font-size: 2.2rem;
    line-height: 4.8rem;
    color: #15126F;
    margin-bottom: 50px;
    font-weight: 600;
  }
  .visions p {
    font-size: 1.5rem;
    line-height: 3.3rem;
    color: #333;
    margin-bottom: 50px;
  }
  .visions p span {
    color: #15126F;
  }
  .visions hr {
    width: 80px;
    margin: 90px auto;
    border-color: #15126F;
  }
  .visions picture {
    margin-bottom: 50px;
  }
  .visions picture img {
    width: 100%;
  }
  .visions figure {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
  }
  .visions .btn_blue {
    width: 100%;
    text-align: center;
  }
  .visions .btn_blue a {
    font-size: 1.5rem;
    line-height: 1;
    padding: 15px;
    background: #15126F;
    display: inline-block;
    min-width: 300px;
    text-align: center;
    position: relative;
    color: #fff;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
    -webkit-transition: all 0.3s ease-out;
    -moz-transition: all 0.3s ease-out;
    transition: all 0.3s ease-out;
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  }
  .visions .btn_blue a:after {
    content: '';
    background: #000;
    width: 100%;
    height: 100%;
    display: block;
    -webkit-transform-origin: top right;
       -moz-transform-origin: top right;
        -ms-transform-origin: top right;
            transform-origin: top right;
    -webkit-transform: scale(0, 1);
       -moz-transform: scale(0, 1);
        -ms-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transition: -webkit-transform 0.25s cubic-bezier(1, 0, 0, 1);
    transition: -webkit-transform 0.25s cubic-bezier(1, 0, 0, 1);
    -moz-transition: transform 0.25s cubic-bezier(1, 0, 0, 1), -moz-transform 0.25s cubic-bezier(1, 0, 0, 1);
    transition: transform 0.25s cubic-bezier(1, 0, 0, 1);
    transition: transform 0.25s cubic-bezier(1, 0, 0, 1), -webkit-transform 0.25s cubic-bezier(1, 0, 0, 1), -moz-transform 0.25s cubic-bezier(1, 0, 0, 1);
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
  }
  .visions .btn_blue a:hover:after {
    -webkit-transform-origin: top left;
       -moz-transform-origin: top left;
        -ms-transform-origin: top left;
            transform-origin: top left;
    -webkit-transform: scale(1, 1);
       -moz-transform: scale(1, 1);
        -ms-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .visions .btn_blue a span {
    position: relative;
    display: block;
  }
  .visions .btn_blue a span:after {
    content: "";
    background: url(../images/ic_white.png) no-repeat;
    -moz-background-size: contain;
         background-size: contain;
    width: 16px;
    height: 4px;
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    z-index: 1;
    padding-top: 4px;
  }
  .maskToRight:before {
    background: #15126F;
  }
  figure.maskToRight:before {
    background: #fff;
  }
  em.maskToRight:before {
    background: #fff;
  }
  .voice {
    background: #15126f;
    padding-bottom: 140px;
  }
  .voice > h2 {
    color: #fff;
  }
  .voice > h2 .maskToRight::before {
    background: #15126f;
  }
  .voice_wrap {
    max-width: 1080px;
    width: 100%;
    margin: 0 auto;
  }
  .voice_wrap article {
    position: relative;
  }
  .voice_wrap article > figure {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 248px;
    z-index: 10;
  }
  .voice_wrap article > figure img {
    max-width: 100%;
    width: auto;
    height: auto;
  }
  .voice_wrap article .voice_ar {
    background: #fff;
    padding-top: 43px;
    padding-bottom: 43px;
    text-align: left;
  }
  .voice_wrap article .voice_ar h3 {
    font-size: 2.2rem;
    line-height: 3.2rem;
    font-weight: 600;
    color: #15126f;
    padding-bottom: 15px;
    border-bottom: 1px solid #15126f;
    margin-bottom: 20px;
  }
  .voice_wrap article .voice_ar p {
    font-size: 1.5rem;
    line-height: 26px;
    font-weight: 500;
  }
  .voice_wrap article:not(:first-child) {
    margin-top: 40px;
  }
  .voice_wrap article:nth-child(odd) {
    padding-left: 79px;
  }
  .voice_wrap article:nth-child(odd) figure {
    left: 0;
  }
  .voice_wrap article:nth-child(odd) .voice_ar {
    padding-left: 200px;
    padding-right: 57px;
  }
  .voice_wrap article:nth-child(even) {
    padding-right: 79px;
  }
  .voice_wrap article:nth-child(even) figure {
    right: 0;
  }
  .voice_wrap article:nth-child(even) .voice_ar {
    padding-right: 200px;
    padding-left: 57px;
  }
}

@media screen and (max-width: 768px) {
  .visions {
    text-align: center;
    padding: 10.66667vw 5.33333vw;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  }
  .visions h2 {
    font-size: 5.33333vw;
    line-height: 8.66667vw;
    color: #15126F;
    margin-bottom: 5.6vw;
    font-weight: 600;
    letter-spacing: 2px;
  }
  .visions h2 em {
    font-style: normal;
  }
  .visions h3 {
    font-size: 4vw;
    line-height: 6.66667vw;
    color: #15126F;
    margin-bottom: 6.66667vw;
    font-weight: 600;
  }
  .visions p {
    font-size: 3.73333vw;
    line-height: 6.66667vw;
    color: #333;
    margin-bottom: 6.66667vw;
    text-align: left;
  }
  .visions p span {
    color: #15126F;
  }
  .visions hr {
    width: 10.66667vw;
    margin: 8vw auto 13.33333vw;
    border-color: #15126F;
  }
  .visions figure img {
    width: 82.13333vw;
    height: auto;
  }
  .visions picture {
    margin-bottom: 6.66667vw;
    margin-right: -5.33333vw;
    margin-left: -5.33333vw;
  }
  .visions picture img {
    width: 100%;
    height: auto;
  }
  .visions .btn_blue {
    width: 100%;
    text-align: center;
  }
  .visions .btn_blue a {
    font-size: 3.46667vw;
    line-height: 1;
    padding: 4.93333vw 2.66667vw;
    background: #15126F;
    display: block;
    text-align: center;
    position: relative;
    color: #fff;
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  }
  .visions .btn_blue a span {
    position: relative;
    display: block;
  }
  .visions .btn_blue a span:after {
    content: "";
    background: url(../images/ic_white.png) no-repeat;
    -moz-background-size: contain;
         background-size: contain;
    width: 4.26667vw;
    height: 1.06667vw;
    position: absolute;
    top: 50%;
    right: 10.66667vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    z-index: 1;
    padding-top: 0.53333vw;
  }
  .maskToRight:before {
    background: #15126F;
  }
  figure.maskToRight:before {
    background: #fff;
  }
  em.maskToRight:before {
    background: #fff;
  }
  .voice {
    background: #15126f;
    padding-bottom: 140px;
  }
  .voice > h2 {
    color: #fff;
  }
  .voice > h2 .maskToRight::before {
    background: #15126f;
  }
  .voice_wrap {
  }
  .voice_wrap article {
    position: relative;
    padding: 0 5.208vw 7.8125vw 5.208vw;
    -webkit-transform: translateZ(0);
    -ms-transform: translateZ(0);
    transform: translateZ(0);
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-align-items: center;
    align-items: center;
  }
  .voice_wrap article::after {
    position: absolute;
    content: "";
    width: 100%;
    height: calc(100% - 7.8125vw);
    height: -webkit-calc(100% - 7.8125vw);
    height: -moz-calc(100% - 7.8125vw);
    height: -o-calc(100% - 7.8125vw);
    background: #fff;
    z-index: -1;
    left: 0;
    top: 7.8125vw;
  }
  .voice_wrap article > figure {
    z-index: 10;
    text-align: center;
  }
  .voice_wrap article > figure img {
    width: 32.29vw;
    height: auto;
  }
  .voice_wrap article .voice_ar {
    text-align: center;
  }
  .voice_wrap article .voice_ar h3 {
    font-size: 3.90625vw;
    line-height: 6.25vw;
    font-weight: 600;
    color: #15126f;
    padding-bottom: 1.82vw;
    border-bottom: 1px solid #15126f;
    margin-bottom: 1.82vw;
    margin-top: 5.33vw;
    text-align: center;
  }
  .voice_wrap article .voice_ar p {
    font-size: 3.645vw;
    line-height: 6.5vw;
    font-weight: 500;
    margin-bottom: 0;
    overflow: hidden;
    max-height: 45.5vw;
    -webkit-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
    text-align: left;
  }
  .voice_wrap article .voice_ar p.open {
    max-height: 5000px;
  }
  .voice_wrap article:not(:first-child) {
    margin-top: 8.203125vw;
  }
  .voice_wrap article .voice_ar span {
    display: inline-block;
    font-size: 3.90625vw;
    line-height: 6.25vw;
    font-weight: 600;
    color: #15126f;
    margin-top: 2.6vw;
    cursor: pointer;
  }
  .voice_wrap article .voice_ar span.hide {
    display: none;
  }
}
