@charset "utf-8";
  /* mv */
  .sub_mv {
    height: 250px;
    margin-top: 95px;
    position: relative;
  }
  #program .sub_mv {
    background: url(../img/program/mv.jpg) no-repeat center /cover;
  }
  #voice .sub_mv {
    background: url(../img/voice/mv.jpg) no-repeat center /cover;
  }
  #example .sub_mv {
    background: url(../img/example/mv.jpg) no-repeat center /cover;
  }
  .sub_mv::after {
    content: '';
    display: inline-block;
    background: url(../img/submv_ill.png) no-repeat top center / 100% auto;
    width: 110px;
    height: 167px;
    position: absolute;
    right: 0;
    bottom: -10px;
  }
  .sub_mvTxt {
    display: inline-block;
    background-color: #fff;
    -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.2);
            box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.2);
    padding: 12px 10px 8px;
    position: absolute;
    left: 5%;
    top: 50%;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .sub_mvTxt h2 {
    font-size: 42px;
    display: inline-block;
    font-weight: 500;
    margin-right: 30px;
  }
  .sub_mvTxt h2 span {
    color: #0e73b4;
  }
  .sub_mvTxt p {
    font-size: 16px;
    display: inline-block;
    color: #2d83ca;
  }
  /* program */
  #program .pro_about {
    background: url(../img/program/program_bg.jpg) repeat center top / 100% auto;
    padding: 55px 0;
  }
  #program .pro_about h2 {
    font-weight: 500;
    text-align: center;
    font-size: 18px;
    line-height: 1.5;
    margin: 0 auto 50px;
  }
  #program .pro_about ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  #program .pro_about ul li {
    width: 30%;
  }
  #program .pro_about ul li figure {
    position: relative;
    margin: 0 auto 15px;
    z-index: 1;
  }
  #program .pro_about ul li figure::after {
    content: '';
    display: inline-block;
    background: url(../img/img_ill.png) no-repeat top center / 100% auto;
    width: 81.5px;
    height: 231px;
    position: absolute;
    z-index: -1;
  }
  #program .pro_about ul li:first-child figure::after {
    left: -10px;
    top: -10px;
  }
  #program .pro_about ul li:nth-child(2) figure::after {
    background: url(../img/program/program_ill.png) no-repeat top center / 100% auto;
    right: -10px;
    bottom: -10px;
  }
  #program .pro_about ul li:last-child figure::after {
    right: -10px;
    top: -10px;
    -webkit-transform: scale(-1, 1);
        -ms-transform: scale(-1, 1);
            transform: scale(-1, 1);
  }
  #program .pro_about ul li h3 {
    font-size: 18px;
    color: #0e73b4;
    margin: 0 auto 10px;
  }
  #program .pro_about ul li p {
    line-height: 2;
  }
  #program .pro_about_btn {
    margin: 30px auto 0;
    max-width: 400px;
  }
  #program .pro_about_btn a {
    display: block;
    width: 100%;
    background: -o-linear-gradient(left, #106cb9, #3c9ff2);
    background: -webkit-gradient(linear, left top, right top, from(#106cb9), to(#3c9ff2));
    background: linear-gradient(90deg, #106cb9, #3c9ff2);
    text-align: center;
    color: #fff;
    font-size: 18px;
    padding: 25px 10px;
    position: relative;
  }
  #program .pro_about_btn a::after {
    content: '';
    display: inline-block;
    width: 0;
  height: 0;
  border-style: solid;
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
  border-left: 10px solid #fff;
  border-right: 0;
  position: absolute;
  top: 50%;
  right: 5%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  }
  #program .step {
    background: url(../img/program/step_bg.jpg) no-repeat center/cover;
    padding: 55px 0;
  }
  #program .step .ttl span {
    color: #fff;
  }
  #program .step .ttl h2 {
    background: unset;
    -webkit-text-fill-color: unset;
    color: #fff;
  }
  #program .step ul {
    max-width: 1000px;
    margin: 30px auto 0;
  }
  #program .step ul li {
    background-color: #fff;
    -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.2);
            box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.2);
    margin:0 auto 45px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
  }
  #program .step ul li:last-child {
    margin-bottom: 0;
  }
  #program .step ul li::after {
    content: '';
    display: inline-block;
    width: 0;
  height: 0;
  border-style: solid;
  border-right: 25px solid transparent;
  border-left: 25px solid transparent;
  border-top: 18px solid #f5c5c5;
  border-bottom: 0;
    position: absolute;
    left: 50%;
    bottom: -30px;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  #program .step ul li:last-child::after {
    content: none;
  }
  #program .step ul li span {
    background: url(../img/program/step_bg.png) no-repeat top right /cover;
    max-width: 145px;
    padding: 20px 15px;
    width: 17%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #program .step ul li span img {
    display: block;
    max-width: 80px;
    margin: 0 auto 0 0;
  }
  #program .step ul li .step_txt {
    width: 80%;
    padding: 30px 0;
  }
  #program .step ul li .step_txt h3 {
    font-size: 22px;
    font-weight: 600;
    color: #2d83ca;
    margin: 0 auto 15px;
  }
  #program .step ul li .step_txt p {
    line-height: 2;
  }
  #program .facility {
    background: url(../img/program/facility_bg.jpg) no-repeat top center/cover;
    padding: 55px 0 80px;
  }
  #program .facility ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 50px;
    margin: 30px auto 0;
  }
  #program .facility ul li {
    width: 30%;
  }
  #program .facility ul li figure {
    -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.2);
            box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.2);
  }
  #program .facility ul li h3 {
    font-size: 20px;
    color: #2d83ca;
    margin: 15px auto 10px;
  }
  #program .facility ul li p {
    line-height: 2;
  }
  /* voice */
  #voice .voice {
    background-image: url(../img/voice/voice_bg.png), -o-linear-gradient(top , #e1f5fe, #b3d7e7);
    background-image: url(../img/voice/voice_bg.png), -webkit-gradient(linear , left top, left bottom , from(#e1f5fe), to(#b3d7e7));
    background-image: url(../img/voice/voice_bg.png), linear-gradient(to bottom , #e1f5fe, #b3d7e7);
	background-position:0 0, 0 0;
	background-repeat: no-repeat , no-repeat;
  background-size: cover, auto;
    padding: 40px 0 80px;
  }
  #voice .voice ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  #voice .voice ul li {
    width: 48%;
    position: relative;
    padding-top: 45px;
    margin: 0 auto 40px;
  }
  #voice .voice ul li .voice_ttl {
    position: absolute;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    top: 0;
    left: 0;
  }
  #voice .voice ul li .voice_ttl figure {
    max-width: 87px;
    z-index: 1;
    position: relative;
  }
  #voice .voice ul li .voice_ttl h3 {
    background: -o-linear-gradient(left, #70beff, #2c8fe2);
    background: -webkit-gradient(linear, left top, right top, from(#70beff), to(#2c8fe2));
    background: linear-gradient(90deg, #70beff, #2c8fe2);
    font-weight: 500;
    color: #fff;
    padding: 8px 25px;
    margin-left: -5px;
  }
  #voice .voice ul li .voice_txt {
    width: 93%;
    margin: 0 0 0 auto;
    background-color: #fff;
    padding: 40px 5% 20px;
    -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.2);
            box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.2);
  }
  #voice .voice ul li .voice_txt p {
    line-height: 2;
  }
  /* example */
  #example .pro_example {
    background: url(../img/bg_dot.jpg) repeat top center/100% auto;
    padding: 55px 0 40px;
    position: relative;
    z-index: 0;
  }
  #example .pro_example::before {
    content: '';
    display: inline-block;
    background: url(../img/example/example_bg01.png) no-repeat top center / 100% auto;
    width: 30vw;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    mix-blend-mode:multiply;
    z-index: -1;
  }
  #example .pro_example::after {
    content: '';
    display: inline-block;
    background: url(../img/example/example_bg02.png) no-repeat bottom center / 100% auto;
    width: 48vw;
    height: 100%;
    position: absolute;
    right: 0;
    bottom: 0;
    mix-blend-mode:multiply;
    z-index: -1;
  }
  #example .pro_example .pro_example_img {
    margin: 40px auto 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
            -ms-flex-wrap: wrap;
                flex-wrap: wrap;
  }
  #example .pro_example .pro_example_img figure {
    width: 31.5%;
    margin-bottom: 20px;
  }
  #example .pro_example ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 30px auto 0;
  }
  #example .pro_example ul li {
    width: 31.5%;
    margin-bottom: 20px;
    background: -o-linear-gradient(25deg, #d1eefa, #bae8fc);
    background: linear-gradient(65deg, #d1eefa, #bae8fc);
    padding: 15px 20px 20px;
    -webkit-box-shadow: 0px 0px 7px 0px rgba(0, 0, 0, 0.2);
            box-shadow: 0px 0px 7px 0px rgba(0, 0, 0, 0.2);
  }
  #example .pro_example ul li h3 {
    font-size: 18px;
    color: #2d83ca;
    font-weight: 600;
    text-align: center;
    line-height: 1.5;
  }
  #example .pro_example ul li p {
    line-height: 1.5;
    margin: 10px auto 0;
  }
  #example .t_voice {
    background: url(../img/example/voice_bg.jpg) no-repeat top center/cover;
    padding: 55px 0 85px;
  }
  #example .t_voice .ttl span {
    color: #fff;
  }
  #example .t_voice .ttl h2 {
    background: unset;
    -webkit-text-fill-color: unset;
    color: #fff;
  }
  #example .t_voice .t_voice_cont {
    background-color: #fff;
    -webkit-box-shadow: 0px 0px 7px 0px rgba(0, 0, 0, 0.2);
            box-shadow: 0px 0px 7px 0px rgba(0, 0, 0, 0.2);
    padding: 25px 50px 30px;
    margin: 30px auto 0;
  }
  #example .t_voice .t_voice_cont .t_voice_contTtl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #example .t_voice .t_voice_cont .t_voice_contTtl figure {
    max-width: 108px;
    margin-right: 20px;
  }
  #example .t_voice .t_voice_cont .t_voice_contTtl h3 {
    display: inline-block;
    color: #fff;
    background: -o-linear-gradient(left, #2d83ca, #56aef8);
    background: -webkit-gradient(linear, left top, right top, from(#2d83ca), to(#56aef8));
    background: linear-gradient(90deg, #2d83ca, #56aef8);
    font-size: 24px;
    padding: 10px 10px 8px 10px;
    font-weight: 600;
    margin-right: 20px;
  }
  #example .t_voice .t_voice_cont .t_voice_contTtl span {
    display: inline-block;
    color: #2d83ca;
    font-size: 18px;
    font-weight: 600;
  }
  #example .t_voice .t_voice_cont p {
    line-height: 2;
    margin: 10px auto 0;
  }
@media only screen and (max-width: 1024px) {
   /* mv */
   .sub_mv {
    height: 200px;
    margin-top: 80px;
  }
  #program .sub_mv {
    background: url(../img/program/mv_sp.jpg) no-repeat center /cover;
  }
  #voice .sub_mv {
    background: url(../img/voice/mv_sp.jpg) no-repeat center /cover;
  }
  #example .sub_mv {
    background: url(../img/example/mv_sp.jpg) no-repeat center /cover;
  }
  .sub_mv::after {
    width: 90px;
    height: 137px;
  }
  .sub_mvTxt h2 {
    font-size: 22px;
    margin-right: 15px;
  }
  .sub_mvTxt p {
    font-size: 14px;
  }
  /* program */
  #program .pro_about {
    padding: 50px 0;
  }
  #program .pro_about h2 {
    font-size: 16px;
    margin: 0 auto 30px;
  }
  #program .pro_about ul {
    display: block;
    max-width: 600px;
    margin: 0 auto;
  }
  #program .pro_about ul li {
    width: 100%;
    margin-bottom: 30px;
  }
  #program .pro_about ul li:last-child {
    margin-bottom: 0;
  }
  #program .pro_about ul li figure::after {
    width: 60px;
    height: 170px;
  }
  #program .pro_about ul li h3 {
    font-size: 16px;
  }
  #program .pro_about_btn {
    margin: 20px auto 0;
    max-width: 300px;
  }
  #program .pro_about_btn a {
    font-size: 16px;
    padding: 20px 10px;
  }
  #program .pro_about_btn a::after {
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid #fff;
  right: 3%;
  }
  #program .step {
    padding: 50px 0;
  }
  #program .step ul {
    margin: 20px auto 0;
    max-width: 600px;
  }
  #program .step ul li {
    margin:0 auto 30px;
    display: block;
  }
  #program .step ul li::after {
    border-right: 20px solid transparent;
    border-left: 20px solid transparent;
    border-top: 15px solid #f5c5c5;
    bottom: -25px;
  }
  #program .step ul li span {
    background: url(../img/program/step_sp_bg.png) no-repeat top right / cover;
    max-width: 100%;
    padding: 15px 15px 20px;
    width: 100%;
  }
  #program .step ul li span img {
    max-width: 80px;
    margin: 0 auto;
  }
  #program .step ul li .step_txt {
    width: 100%;
    padding: 20px 5%;
  }
  #program .step ul li .step_txt h3 {
    font-size: 18px;
    line-height: 1.5;
  }
  #program .facility {
    background: url(../img/program/facility_bg_sp.jpg) repeat center top / 100% auto;
    padding: 50px 0;
  }
  #program .facility ul {
    display: block;
    margin: 20px auto 0;
    max-width: 600px;
  }
  #program .facility ul li {
    width: 100%;
    margin: 0 auto 30px;
  }
  #program .facility ul li:last-child {
    margin-bottom: 0;
  }
  #program .facility ul li h3 {
    font-size: 18px;
  }
    /* voice */
    #voice .voice {
      background-image: url(../img/voice/voice_bg_sp.png), -o-linear-gradient(top , #e1f5fe, #b3d7e7);
      background-image: url(../img/voice/voice_bg_sp.png), -webkit-gradient(linear , left top, left bottom , from(#e1f5fe), to(#b3d7e7));
      background-image: url(../img/voice/voice_bg_sp.png), linear-gradient(to bottom , #e1f5fe, #b3d7e7);
    background-position: center top, 0 0;
    background-repeat: repeat , no-repeat;
    background-size: 100% auto, auto;
      padding: 40px 0 50px;
    }
    #voice .voice ul {
      display: block;
      max-width: 600px;
      margin: 0 auto;
    }
    #voice .voice ul li {
      width: 100%;
      padding-top: 30px;
      margin: 0 auto 30px;
    }
    #voice .voice ul li .voice_ttl figure {
      max-width: 65px;
    }
    #voice .voice ul li .voice_txt {
      width: 98%;
    }
    /* example */
  #example .pro_example {
    padding: 50px 0 30px;
  }
  #example .pro_example .pro_example_img {
    margin: 20px auto 0;
    max-width: 600px;
    display: block;
  }
  #example .pro_example .pro_example_img figure {
    width: 100%;
    margin-bottom: 15px;
  }
  #example .pro_example ul {
    display: block;
    margin: 20px auto 0;
    max-width: 600px;
  }
  #example .pro_example ul li {
    width: 100%;
    padding: 15px 5% 20px;
  }
  #example .pro_example ul li h3 {
    font-size: 16px;
  }
  #example .pro_example ul li p {
    margin: 5px auto 0;
  }
  #example .t_voice {
    background: url(../img/example/voice_bg_sp.jpg) no-repeat top center/cover;
    padding: 50px 0;
  }
  #example .t_voice .t_voice_cont {
    padding: 25px 5%;
    margin: 20px auto 0;
    max-width: 600px;
  }
  #example .t_voice .t_voice_cont .t_voice_contTtl {
    display: block;
  }
  #example .t_voice .t_voice_cont .t_voice_contTtl figure {
    max-width: 108px;
    margin:0 auto 10px;
  }
  #example .t_voice .t_voice_cont .t_voice_contTtl h3 {
    display: block;
    font-size: 18px;
    line-height: 1.5;
    margin: 0 auto 10px;
  }
  #example .t_voice .t_voice_cont .t_voice_contTtl span {
    display: block;
    font-size: 16px;
  }
}