@charset "UTF-8";
/* _setting CSS */
@keyframes flicker {
  0%, 10%, 30%, 50%, 70%, 90% {
    opacity: 1;
  }
  5%, 15%, 35%, 55%, 75%, 95% {
    opacity: 0.2;
  }
}
@keyframes showHide {
  0% {
    opacity: 0;
  }
  11% {
    opacity: 1;
  }
  66% {
    opacity: 1;
  }
  67% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes removeFilterAfterDelay {
  0% {
    filter: blur(1px);
  }
  100% {
    filter: blur(0px);
  }
}
.flicker_path {
  animation: flicker 8s infinite;
}
.flicker_path:nth-child(2) {
  animation: flicker 4s infinite;
}
.flicker_path:nth-child(3) {
  animation: flicker 2.5s infinite;
}
.flicker_path:nth-child(4) {
  animation: flicker 6.4s infinite;
}
.flicker_path:nth-child(5) {
  animation: flicker 4.8s infinite;
}
.flicker_path:nth-child(6) {
  animation: flicker 8s infinite;
}

.svg_on svg .svg_on path {
  opacity: 0 !important;
  transition-delay: 0s;
}

@media all and (min-width: 1001px) {
  .modal_link:hover {
    opacity: 0.85;
    cursor: pointer;
  }
}

.svg_on_start svg .svg_on path {
  opacity: 1 !important;
}
.svg_on_start svg .svg_on path:nth-child(2) {
  transition-delay: 0.07s;
}
.svg_on_start svg .svg_on path:nth-child(3) {
  transition-delay: 0.14s;
}
.svg_on_start svg .svg_on path:nth-child(4) {
  transition-delay: 0.21s;
}
.svg_on_start svg .svg_on path:nth-child(5) {
  transition-delay: 0.28s;
}
.svg_on_start svg .svg_on path:nth-child(6) {
  transition-delay: 0.35s;
}
.svg_on_start svg .svg_on path:nth-child(7) {
  transition-delay: 0.42s;
}
.svg_on_start svg .svg_on path:nth-child(8) {
  transition-delay: 0.49s;
}
.svg_on_start svg .svg_on path:nth-child(9) {
  transition-delay: 0.56s;
}
.svg_on_start svg .svg_on path:nth-child(10) {
  transition-delay: 0.63s;
}
.svg_on_start svg .svg_on path:nth-child(11) {
  transition-delay: 0.7s;
}
.svg_on_start svg .svg_on path:nth-child(12) {
  transition-delay: 0.77s;
}
.svg_on_start svg .svg_on path:nth-child(13) {
  transition-delay: 0.84s;
}
.svg_on_start svg .svg_on path:nth-child(14) {
  transition-delay: 0.91s;
}
.svg_on_start svg .svg_on path:nth-child(15) {
  transition-delay: 0.98s;
}
.svg_on_start svg .svg_on path:nth-child(16) {
  transition-delay: 1.05s;
}
.svg_on_start svg .svg_on path:nth-child(17) {
  transition-delay: 1.12s;
}
.svg_on_start svg .svg_on path:nth-child(18) {
  transition-delay: 1.19s;
}
.svg_on_start svg .svg_on path:nth-child(19) {
  transition-delay: 1.26s;
}
.svg_on_start svg .svg_on path:nth-child(20) {
  transition-delay: 1.33s;
}
.svg_on_start svg .svg_on path:nth-child(21) {
  transition-delay: 1.4s;
}
.svg_on_start svg .svg_on path:nth-child(22) {
  transition-delay: 1.47s;
}
.svg_on_start svg .svg_on path:nth-child(23) {
  transition-delay: 1.54s;
}
.svg_on_start svg .svg_on path:nth-child(24) {
  transition-delay: 1.61s;
}
.svg_on_start svg .svg_on path:nth-child(25) {
  transition-delay: 1.68s;
}
.svg_on_start svg .svg_on path:nth-child(26) {
  transition-delay: 1.75s;
}
.svg_on_start svg .svg_on path:nth-child(27) {
  transition-delay: 1.82s;
}
.svg_on_start svg .svg_on path:nth-child(28) {
  transition-delay: 1.89s;
}
.svg_on_start svg .svg_on path:nth-child(29) {
  transition-delay: 1.96s;
}
.svg_on_start svg .svg_on path:nth-child(30) {
  transition-delay: 2.03s;
}
.svg_on_start svg .svg_on path:nth-child(31) {
  transition-delay: 2.1s;
}
.svg_on_start svg .svg_on path:nth-child(32) {
  transition-delay: 2.17s;
}
.svg_on_start svg .svg_on path:nth-child(33) {
  transition-delay: 2.24s;
}
.svg_on_start svg .svg_on path:nth-child(34) {
  transition-delay: 2.31s;
}
.svg_on_start svg .svg_on path:nth-child(35) {
  transition-delay: 2.38s;
}
.svg_on_start svg .svg_on path:nth-child(36) {
  transition-delay: 2.45s;
}
.svg_on_start svg .svg_on path:nth-child(37) {
  transition-delay: 2.52s;
}
.svg_on_start svg .svg_on path:nth-child(38) {
  transition-delay: 2.59s;
}
.svg_on_start svg .svg_on path:nth-child(39) {
  transition-delay: 2.66s;
}
.svg_on_start svg .svg_on path:nth-child(40) {
  transition-delay: 2.73s;
}
.svg_on_start svg .svg_on path:nth-child(41) {
  transition-delay: 2.8s;
}
.svg_on_start svg .svg_on path:nth-child(42) {
  transition-delay: 2.87s;
}
.svg_on_start svg .svg_on path:nth-child(43) {
  transition-delay: 2.94s;
}
.svg_on_start svg .svg_on path:nth-child(44) {
  transition-delay: 3.01s;
}
.svg_on_start svg .svg_on path:nth-child(45) {
  transition-delay: 3.08s;
}
.svg_on_start svg .svg_on path:nth-child(46) {
  transition-delay: 3.15s;
}
.svg_on_start svg .svg_on path:nth-child(47) {
  transition-delay: 3.22s;
}
.svg_on_start svg .svg_on path:nth-child(48) {
  transition-delay: 3.29s;
}
.svg_on_start svg .svg_on path:nth-child(49) {
  transition-delay: 3.36s;
}
.svg_on_start svg .svg_on path:nth-child(50) {
  transition-delay: 3.43s;
}

@media print {
  body {
    zoom: 80%;
  }
}
@media screen and (max-width: 1000px) {
  #wrapper {
    background: url("../images/rc/sp_mv_bg1.webp") no-repeat center 0/100%;
  }
}

#mv {
  position: relative;
  padding: 240px 0 75px;
}
@media screen and (max-width: 1000px) {
  #mv {
    padding: 12.5333333333vw 0 6.1333333333vw;
    background: none;
  }
}
@media print {
  #mv {
    background: url("../images/rc/print_mv.webp") repeat-x 0 0/100%;
  }
}
#mv::after {
  top: 68px;
  left: 0;
  width: 100%;
  height: 550px;
  background: url("../images/rc/mv_bg_img1.webp") no-repeat center/1648px;
  transform: translateX(0);
}
@media screen and (max-width: 1000px) {
  #mv::after {
    display: none;
  }
}
#mv .bg {
  background: url("../images/rc/mv_bg1_r.webp") repeat-x 0 0/auto 230px;
}
#mv .bg::before {
  background: url("../images/rc/mv_bg1.webp") no-repeat center 0/auto 264px;
}
@media print {
  #mv .bg {
    display: none;
  }
}
@media screen and (max-width: 1000px) {
  #mv .hd {
    padding: 0 11.3333333333vw 0 10.4vw;
  }
}

.sec1 {
  position: relative;
  width: 1120px;
  margin: 0 auto;
  height: 2050px;
}
@media screen and (max-width: 1000px) {
  .sec1 {
    width: 100%;
    height: 744vw;
  }
}
.sec1 .box1 {
  width: 558px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box1 {
    width: 100%;
  }
}
.sec1 .box1 .hd {
  position: relative;
  margin: 0 0 12px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box1 .hd {
    margin: 0 0 4vw;
    padding: 0 0 0 4vw;
    text-align: left;
  }
}
.sec1 .box1 .hd svg {
  width: 518px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box1 .hd svg {
    width: 86.5333333333vw;
  }
}
.sec1 .box1 .hd::before, .sec1 .box1 .hd::after {
  content: "";
  position: absolute;
  top: 29px;
  right: 0;
  width: 100vw;
  height: 110px;
  background: #5032af;
}
@media screen and (max-width: 1000px) {
  .sec1 .box1 .hd::before, .sec1 .box1 .hd::after {
    top: 6.9333333333vw;
    left: 0;
    right: auto;
    width: 96.2666666667vw;
    height: 16.4vw;
  }
}
.sec1 .box1 .hd::after {
  top: 139px;
  height: 50px;
  background: linear-gradient(to right, #0fc3c8 49%, #0fc1c7 70%, #12bac6 78%, #18aec4 83%, #1f9dc1 88%, #2987bd 92%, #356cb9 95%, #434cb3 98%, #5032af 100%);
}
@media screen and (max-width: 1000px) {
  .sec1 .box1 .hd::after {
    top: 22.9333333333vw;
    height: 9.3333333333vw;
  }
}
.sec1 .box1 .hd * {
  position: relative;
  z-index: 1;
}
.sec1 .box1 .text {
  font-size: 1.6rem;
}
@media screen and (max-width: 1000px) {
  .sec1 .box1 .text {
    line-height: 2.1;
    font-size: 2.6rem;
    padding: 0 4vw;
  }
}
.sec1 .box {
  position: absolute;
  top: 0;
  width: 500px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box {
    width: 100%;
    padding: 0 4vw;
  }
}
@media all and (min-width: 1001px) {
  .sec1 .box._right {
    right: 0;
  }
  .sec1 .box._left {
    left: 0;
  }
}
.sec1 .box .hd {
  position: relative;
  z-index: 1;
  width: 100%;
  text-align: left;
}
.sec1 .box img {
  opacity: 0;
  transition: opacity 0.4s;
  transition-delay: 0.5s;
}
.sec1 .box svg path {
  opacity: 0;
}
.sec1 .box svg path:nth-child(2) {
  transition-delay: 0.07s;
}
.sec1 .box svg path:nth-child(3) {
  transition-delay: 0.14s;
}
.sec1 .box svg path:nth-child(4) {
  transition-delay: 0.21s;
}
.sec1 .box svg path:nth-child(5) {
  transition-delay: 0.28s;
}
.sec1 .box svg path:nth-child(6) {
  transition-delay: 0.35s;
}
.sec1 .box svg path:nth-child(7) {
  transition-delay: 0.42s;
}
.sec1 .box svg path:nth-child(8) {
  transition-delay: 0.49s;
}
.sec1 .box svg path:nth-child(9) {
  transition-delay: 0.56s;
}
.sec1 .box svg path:nth-child(10) {
  transition-delay: 0.63s;
}
.sec1 .box svg path:nth-child(11) {
  transition-delay: 0.7s;
}
.sec1 .box svg path:nth-child(12) {
  transition-delay: 0.77s;
}
.sec1 .box svg path:nth-child(13) {
  transition-delay: 0.84s;
}
.sec1 .box svg path:nth-child(14) {
  transition-delay: 0.91s;
}
.sec1 .box svg path:nth-child(15) {
  transition-delay: 0.98s;
}
.sec1 .box svg path:nth-child(16) {
  transition-delay: 1.05s;
}
.sec1 .box svg path:nth-child(17) {
  transition-delay: 1.12s;
}
.sec1 .box svg path:nth-child(18) {
  transition-delay: 1.19s;
}
.sec1 .box svg path:nth-child(19) {
  transition-delay: 1.26s;
}
.sec1 .box svg path:nth-child(20) {
  transition-delay: 1.33s;
}
.sec1 .box svg path:nth-child(21) {
  transition-delay: 1.4s;
}
.sec1 .box svg path:nth-child(22) {
  transition-delay: 1.47s;
}
.sec1 .box svg path:nth-child(23) {
  transition-delay: 1.54s;
}
.sec1 .box svg path:nth-child(24) {
  transition-delay: 1.61s;
}
.sec1 .box svg path:nth-child(25) {
  transition-delay: 1.68s;
}
.sec1 .box svg path:nth-child(26) {
  transition-delay: 1.75s;
}
.sec1 .box svg path:nth-child(27) {
  transition-delay: 1.82s;
}
.sec1 .box svg path:nth-child(28) {
  transition-delay: 1.89s;
}
.sec1 .box svg path:nth-child(29) {
  transition-delay: 1.96s;
}
.sec1 .box svg path:nth-child(30) {
  transition-delay: 2.03s;
}
.sec1 .box svg path:nth-child(31) {
  transition-delay: 2.1s;
}
.sec1 .box svg path:nth-child(32) {
  transition-delay: 2.17s;
}
.sec1 .box svg path:nth-child(33) {
  transition-delay: 2.24s;
}
.sec1 .box svg path:nth-child(34) {
  transition-delay: 2.31s;
}
.sec1 .box svg path:nth-child(35) {
  transition-delay: 2.38s;
}
.sec1 .box svg path:nth-child(36) {
  transition-delay: 2.45s;
}
.sec1 .box svg path:nth-child(37) {
  transition-delay: 2.52s;
}
.sec1 .box svg path:nth-child(38) {
  transition-delay: 2.59s;
}
.sec1 .box svg path:nth-child(39) {
  transition-delay: 2.66s;
}
.sec1 .box svg path:nth-child(40) {
  transition-delay: 2.73s;
}
.sec1 .box svg path:nth-child(41) {
  transition-delay: 2.8s;
}
.sec1 .box svg path:nth-child(42) {
  transition-delay: 2.87s;
}
.sec1 .box svg path:nth-child(43) {
  transition-delay: 2.94s;
}
.sec1 .box svg path:nth-child(44) {
  transition-delay: 3.01s;
}
.sec1 .box svg path:nth-child(45) {
  transition-delay: 3.08s;
}
.sec1 .box svg path:nth-child(46) {
  transition-delay: 3.15s;
}
.sec1 .box svg path:nth-child(47) {
  transition-delay: 3.22s;
}
.sec1 .box svg path:nth-child(48) {
  transition-delay: 3.29s;
}
.sec1 .box svg path:nth-child(49) {
  transition-delay: 3.36s;
}
.sec1 .box svg path:nth-child(50) {
  transition-delay: 3.43s;
}
.sec1 .box.sf_on img {
  opacity: 1;
}
.sec1 .box.sf_on svg path {
  opacity: 1;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box2 {
    top: 99.6vw;
  }
}
.sec1 .box.box2 .hd {
  position: absolute;
  top: 0;
  right: 0;
  width: 200px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box2 .hd {
    right: 4vw;
    width: 37.3333333333vw;
  }
}
.sec1 .box.box2 .img {
  padding: 24px 0 0;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box2 .img {
    padding: 5.7333333333vw 0 0;
  }
}
.sec1 .box.box2 .img img {
  display: block;
  margin: 0 0 10px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box2 .img img {
    width: 64vw;
    margin: 0 0 2vw;
  }
  .sec1 .box.box2 .img img:nth-child(1) {
    width: 40.4vw;
    margin-left: 3.0666666667vw;
  }
}
.sec1 .box.box3 {
  top: 465px;
  width: 260px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box3 {
    left: 0;
    top: 244vw;
    width: 49.3333333333vw;
    padding: 0 0 0 9.3333333333vw;
  }
}
.sec1 .box.box3 .img {
  position: absolute;
  bottom: -61px;
  right: 88px;
  width: 255px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box3 .img {
    bottom: -10.4vw;
    right: 11.0666666667vw;
    width: 39.2vw;
  }
}
.sec1 .box.box4 {
  top: 465px;
  left: 319px;
  width: 202px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box4 {
    top: 244vw;
    left: 56.1333333333vw;
    width: 30.1333333333vw;
    padding: 0;
  }
  .sec1 .box.box4 img {
    width: 100%;
  }
}
.sec1 .box.box4 .hd {
  position: absolute;
  top: 127px;
  left: 0;
  width: 200px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box4 .hd {
    top: 18.4vw;
    left: 0;
    width: 100%;
  }
}
.sec1 .box.box5 {
  top: 414px;
  width: 538px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box5 {
    top: 177.3333333333vw;
    width: 97.3333333333vw;
  }
}
.sec1 .box.box5 .img {
  position: absolute;
  top: 55px;
  right: 0;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box5 .img {
    top: 9.2vw;
    right: 2.6666666667vw;
    width: 29.3333333333vw;
  }
}
.sec1 .box.box6 {
  top: 842px;
  width: 555px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box6 {
    top: 351.3333333333vw;
    width: 100%;
  }
}
.sec1 .box.box6 .img {
  position: absolute;
  top: -58px;
  right: -3px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box6 .img {
    top: -5.3333333333vw;
    right: 0;
    width: 22.6666666667vw;
  }
}
.sec1 .box.box7 {
  top: 1117px;
  width: 537px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box7 {
    top: 459.6vw;
    width: 100%;
  }
}
.sec1 .box.box7 .img {
  position: absolute;
  top: 172px;
  left: 381px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box7 .img {
    top: 31.3333333333vw;
    left: 70.6666666667vw;
    width: 23.4666666667vw;
  }
}
.sec1 .box.box8 {
  top: 1050px;
  width: 550px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box8 {
    top: 384.1333333333vw;
    width: 100%;
    padding: 0 0 26.6666666667vw 4vw;
    overflow: hidden;
  }
  .sec1 .box.box8 svg {
    width: 89.3333333333vw;
  }
}
.sec1 .box.box8 .img {
  position: absolute;
  top: 70px;
  right: -88px;
  z-index: 2;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box8 .img {
    top: 12vw;
    left: 4.6666666667vw;
    width: 116.9333333333vw;
  }
}
.sec1 .box.box9 {
  top: 1474px;
  width: 507px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box9 {
    top: 520.6666666667vw;
    width: 100%;
    padding: 0 0 0 4vw;
  }
}
.sec1 .box.box9 .img {
  position: absolute;
  top: -48px;
  right: 0;
  z-index: 2;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box9 .img {
    top: -7.3333333333vw;
    left: 73.0666666667vw;
    width: 22.6666666667vw;
  }
}
.sec1 .box.box10 {
  top: 1840px;
  width: 511px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box10 {
    top: 582.8vw;
    width: 100%;
  }
}
.sec1 .box.box10 .img {
  position: absolute;
  top: -48px;
  right: 0;
  z-index: 2;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box10 .img {
    top: -7.4666666667vw;
    right: 6.9333333333vw;
    width: 23.3333333333vw;
  }
}
.sec1 .box.box11 {
  top: 1458px;
  width: 564px;
  padding: 294px 0 0 163px;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box11 {
    top: 636.5333333333vw;
    width: 100%;
    padding: 42.4vw 4vw 0 36.1333333333vw;
  }
}
.sec1 .box.box11 .hd {
  z-index: 10;
}
@media all and (min-width: 1001px) {
  .sec1 .box.box11 .hd svg {
    position: relative;
    width: 277px;
  }
  .sec1 .box.box11 .hd::before {
    content: "";
    position: absolute;
    top: -33px;
    left: 129px;
    width: 360px;
    height: 86px;
    background: linear-gradient(to right, #0fc3c8 49%, #0fc1c7 70%, #12bac6 78%, #18aec4 83%, #1f9dc1 88%, #2987bd 92%, #356cb9 95%, #434cb3 98%, #5032af 100%);
  }
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box11 .hd svg {
    position: absolute;
    top: -52.2666666667vw;
    left: -33.3333333333vw;
    width: 56.5333333333vw;
  }
  .sec1 .box.box11 .hd::before {
    content: "";
    position: absolute;
    top: -46.5333333333vw;
    left: -37.3333333333vw;
    width: 90.6666666667vw;
    height: 10.6666666667vw;
    background: linear-gradient(to right, #0fc3c8 49%, #0fc1c7 70%, #12bac6 78%, #18aec4 83%, #1f9dc1 88%, #2987bd 92%, #356cb9 95%, #434cb3 98%, #5032af 100%);
  }
}
.sec1 .box.box11 .hd p {
  padding: 5px 0 0;
  font-size: 1.5rem;
  line-height: 1.65;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box11 .hd p {
    font-size: 2.4rem;
  }
}
.sec1 .box.box11 .img._1 {
  position: absolute;
  top: 297px;
  left: 0;
  z-index: 2;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box11 .img._1 {
    top: 41.4666666667vw;
    left: 1.2vw;
    width: 32vw;
  }
}
.sec1 .box.box11 .img._2 {
  position: absolute;
  top: 0;
  left: 13px;
  width: 640px;
  z-index: 2;
}
@media screen and (max-width: 1000px) {
  .sec1 .box.box11 .img._2 {
    width: 100%;
    left: 0;
  }
}

.sec2 {
  width: 1100px;
  margin: 60px auto 100px;
}
@media screen and (max-width: 1000px) {
  .sec2 {
    width: 100%;
    padding: 0 4vw 6.6666666667vw;
    margin: 0;
  }
}
.sec2 h3 {
  margin: 0 0 42px;
  line-height: 1.4;
  padding: 6px 0 9px;
  border-top: 1px solid #1d2088;
  border-bottom: 1px solid #1d2088;
  color: #1d2088;
  font-size: 2.6rem;
  text-align: center;
  letter-spacing: 0.22em;
}
@media screen and (max-width: 1000px) {
  .sec2 h3 {
    margin: 0 0 7.7333333333vw;
    padding: 1.3333333333vw 0 2vw;
    font-size: 3.8rem;
  }
}
.sec2 ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1000px) {
  .sec2 ul {
    justify-content: space-between;
  }
}
.sec2 ul li {
  width: 220px;
  margin: 0 5px 40px;
  text-align: center;
}
.sec2 ul li:nth-child(5) {
  width: 140px;
}
@media screen and (max-width: 1000px) {
  .sec2 ul li {
    width: 50% !important;
    margin: 0 0 7.4666666667vw;
  }
  .sec2 ul li:nth-child(1) img {
    width: 37.3333333333vw;
  }
  .sec2 ul li:nth-child(2) img {
    width: 28vw;
  }
  .sec2 ul li:nth-child(3) img {
    width: 31.7333333333vw;
  }
  .sec2 ul li:nth-child(4) img {
    width: 14.9333333333vw;
  }
  .sec2 ul li:nth-child(5) img {
    width: 26.6666666667vw;
  }
  .sec2 ul li:nth-child(6) img {
    width: 26.1333333333vw;
  }
  .sec2 ul li:nth-child(7) img {
    width: 29.8666666667vw;
  }
  .sec2 ul li:nth-child(8) img {
    width: 37.3333333333vw;
  }
  .sec2 ul li:nth-child(9) img {
    width: 18.6666666667vw;
  }
}

.sec3 {
  position: relative;
  padding: 100px 0 110px;
}
@media screen and (max-width: 1000px) {
  .sec3 {
    padding: 13.3333333333vw 4vw;
  }
}
.sec3::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(176deg, #ffffac 0%, #b5ecb1 11%, #74dbb6 22%, #42ceba 32%, #1ec5bc 41%, #08c0be 48%, #00bebf 52%, #6146b7 100%);
  transform: skewY(-5deg);
}
.sec3 .inner {
  position: relative;
  width: 800px;
  margin: 0 auto;
}
@media screen and (max-width: 1000px) {
  .sec3 .inner {
    width: 100%;
  }
}
.sec3 .inner h3 {
  margin: 0 0 30px;
  text-align: center;
}
@media screen and (max-width: 1000px) {
  .sec3 .inner h3 {
    width: 36.1333333333vw;
    margin: 0 auto 4.4vw;
  }
}
.sec3 .inner .video {
  width: 800px;
  height: 450px;
  background: #bebebe;
}
.sec3 .inner .video iframe {
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1000px) {
  .sec3 .inner .video {
    width: 100%;
    height: 51.7333333333vw;
  }
}

.sec5 {
  width: 1050px;
  margin: 0 auto;
  padding: 100px 0;
}
@media screen and (max-width: 1000px) {
  .sec5 {
    width: 100%;
    padding: 13.3333333333vw 4vw;
  }
}
.sec5 h3 {
  margin: 0 0 40px;
  text-align: center;
}
@media screen and (max-width: 1000px) {
  .sec5 h3 {
    width: 68vw;
    margin: 0 auto 6.2666666667vw;
  }
}
.sec5 .inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.sec5 .inner * {
  order: 10;
}
.sec5 .inner h4 {
  width: 100%;
  margin: 0 0 15px;
  color: #5032af;
  font-size: 2.7rem;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1000px) {
  .sec5 .inner h4 {
    order: 2;
    margin: 0 0 1.3333333333vw;
    line-height: 1.6;
    font-size: 3.6rem;
  }
}
.sec5 .inner h5 {
  position: relative;
  margin: 10px 0 5px;
  color: #5032af;
  font-weight: 400;
  font-size: 2rem;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 1000px) {
  .sec5 .inner h5 {
    margin: 2.6666666667vw 0 1.3333333333vw;
    font-size: 3rem;
  }
}
.sec5 .inner h5::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background: #5032af;
}
.sec5 .inner h5 span {
  display: inline-block;
  position: relative;
  z-index: 1;
  padding: 0 18px 0 0;
  background: #fff;
}
@media screen and (max-width: 1000px) {
  .sec5 .inner h5 span {
    padding: 0 3.2vw 0 0;
  }
}
@media screen and (max-width: 1000px) {
  .sec5 .inner .img._1 {
    order: 1;
    width: 66.6666666667vw;
    margin: 0 auto 6vw;
  }
  .sec5 .inner .img._2 {
    order: 4;
    width: 25.3333333333vw;
    margin: 0 auto 2.6666666667vw;
  }
}
.sec5 .inner .text_wrap p {
  line-height: 2;
  font-size: 1.5rem;
}
@media screen and (max-width: 1000px) {
  .sec5 .inner .text_wrap p {
    font-size: 2.4rem;
    line-height: 1.8;
  }
}
.sec5 .inner .text_wrap._1 {
  width: 610px;
  margin: 0 0 5px;
  padding: 10px 0 0;
}
@media screen and (max-width: 1000px) {
  .sec5 .inner .text_wrap._1 {
    order: 3;
    width: 100%;
    padding: 0;
    margin: 0 0 4vw;
  }
}
.sec5 .inner .text_wrap._2 {
  width: 890px;
}
.sec5 .inner .text_wrap._2 p {
  font-size: 1.3rem;
}
@media screen and (max-width: 1000px) {
  .sec5 .inner .text_wrap._2 p {
    font-size: 2.4rem;
  }
}
.sec5 .inner .text_wrap._2 .name {
  margin: 0 0 5px;
  font-size: 1.7rem;
}
@media screen and (max-width: 1000px) {
  .sec5 .inner .text_wrap._2 .name {
    margin: 0 0 2vw;
    font-size: 3rem;
    text-align: center;
  }
}
.sec5 .inner .text_wrap._2 .link {
  margin: 6px 0 0;
  color: #5032af;
  font-size: 1.6rem;
}
.sec5 .inner .text_wrap._2 .link a {
  text-decoration: underline;
}
@media screen and (max-width: 1000px) {
  .sec5 .inner .text_wrap._2 .link {
    margin: 1.3333333333vw 0 0;
    font-size: 2.4rem;
  }
}
.sec5 .inner .mhd2 {
  width: 100%;
}
@media screen and (max-width: 1000px) {
  .sec5 .inner .mhd2 {
    order: 4;
  }
}

.sec6 {
  position: relative;
  padding: 100px 0 110px;
}
@media screen and (max-width: 1000px) {
  .sec6 {
    padding: 13.3333333333vw 4vw;
  }
}
.sec6::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #5032af;
  transform: skewY(-5deg);
}
.sec6 .inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
  z-index: 1;
  width: 1050px;
  margin: 0 auto;
  color: #fff;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner {
    width: 100%;
  }
}
.sec6 .inner h3 {
  width: 100%;
  margin: 0 0 36px;
  text-align: center;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner h3 {
    width: 75.2vw;
    margin: 0 auto 4vw;
  }
}
.sec6 .inner h4 {
  width: 100%;
  margin: 0 0 10px;
  line-height: 1.8;
  font-size: 2.7rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner h4 {
    line-height: 1.6;
    font-size: 3.4rem;
  }
  .sec6 .inner h4 span {
    display: block;
    font-size: 3.2rem;
    text-align: center;
  }
}
.sec6 .inner .text_wrap {
  width: 600px;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .text_wrap {
    width: 100%;
  }
}
.sec6 .inner .text_wrap p {
  line-height: 2;
  margin: 0 0 23px;
  font-size: 1.5rem;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .text_wrap p {
    line-height: 1.8;
    font-size: 2.4rem;
  }
}
.sec6 .inner .text_wrap ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 35px 0 0;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .text_wrap ul {
    margin: 5.3333333333vw 0 0;
  }
}
.sec6 .inner .text_wrap ul li {
  width: 190px;
  margin: 0 0 15px;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .text_wrap ul li {
    width: 44.4vw;
    margin: 0 0 3.2vw;
  }
}
.sec6 .inner .text_wrap ul li a {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 54px;
  padding: 0 0 5px 12px;
  border: 1px solid #fff;
  border-radius: 100px;
  font-size: 1.7rem;
  font-weight: 400;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .text_wrap ul li a {
    height: 12.6666666667vw;
    padding: 0 0 0.6666666667vw 1.6vw;
    font-size: 3rem;
  }
}
.sec6 .inner .text_wrap ul li a::after {
  content: "";
  position: relative;
  top: 1px;
  width: 6px;
  height: 14px;
  margin: 0 0 0 17px;
  background: url("../images/rc/arrow.svg") no-repeat center/100%;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .text_wrap ul li a::after {
    width: 1.6vw;
    height: 3.7333333333vw;
  }
}
.sec6 .inner .img {
  width: 400px;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .img {
    width: 80vw;
    margin: 0 auto !important;
  }
}
.sec6 .inner .img img {
  display: block;
  margin: 0 0 20px;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .img img {
    margin: 0 0 4vw;
  }
}
.sec6 .inner .link {
  width: 100%;
  padding: 5px 0 0;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .link {
    padding: 8.8vw 0 0;
  }
}
.sec6 .inner .link a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 400px;
  height: 66px;
  padding: 0 0 2px;
  margin: 0 auto;
  background: #64e1fa;
  border-radius: 100px;
  color: #5032af;
  font-size: 2rem;
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .link a {
    width: 80vw;
    height: 12vw;
    padding: 0;
    font-size: 3rem;
  }
}
.sec6 .inner .link a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 20px;
  width: 14px;
  height: 14px;
  background: url("../images/common/tab_blue.svg") no-repeat center/100%;
  translate: 0 -50%;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .link a::after {
    right: 3.3333333333vw;
    width: 3.7333333333vw;
    height: 3.7333333333vw;
  }
}
.sec6 .inner .link + .link {
  padding: 20px 0 0;
}
@media screen and (max-width: 1000px) {
  .sec6 .inner .link + .link {
    padding: 4vw 0 0;
  }
}

.sec4 {
  position: relative;
  padding: 100px 0 110px;
}
@media screen and (max-width: 1000px) {
  .sec4 {
    padding: 13.3333333333vw 0;
  }
}
.sec4::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(100% + 14.6666666667vw);
  background: #ebf0f0;
  transform: skewY(-5deg);
}
.sec4 h3 {
  position: relative;
  margin: 0 0 75px;
  text-align: center;
}
@media screen and (max-width: 1000px) {
  .sec4 h3 {
    margin: 0 0 10.6666666667vw;
    padding: 0 36.8vw 0 35.0666666667vw;
  }
}
.sec4 .list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
  max-width: 1040px;
  margin: 0 auto;
}
@media screen and (max-width: 1040px) {
  .sec4 .list {
    padding: 0 20px;
  }
}
@media screen and (max-width: 1000px) {
  .sec4 .list {
    padding: 0 4vw;
  }
}
@media print {
  .sec4 .list {
    width: 100%;
    padding: 0 20px;
  }
}
.sec4 .list::before, .sec4 .list::after {
  content: "";
  order: 100;
  width: 22.116%;
}
@media screen and (max-width: 1000px) {
  .sec4 .list::before, .sec4 .list::after {
    display: none;
  }
}
.sec4 .list li {
  width: 22.116%;
  margin: 0 0 65px;
}
@media screen and (max-width: 1000px) {
  .sec4 .list li {
    width: 44vw;
    margin: 0 0 10.6666666667vw;
  }
}
@media print {
  .sec4 .list li {
    width: 23%;
    margin: 0 0 40px;
  }
}
.sec4 .list li a {
  display: block;
}
@media print {
  .sec4 .list li a {
    line-height: 1.6;
  }
}
.sec4 .list li a .img {
  position: relative;
  height: 153px;
  margin: 0 0 10px;
  border-radius: 10px;
  overflow: hidden;
}
@media screen and (max-width: 1000px) {
  .sec4 .list li a .img {
    height: 29.3333333333vw;
    margin: 0 0 1.3333333333vw;
    border-radius: 1.3333333333vw;
  }
}
@media print {
  .sec4 .list li a .img {
    height: 140px;
  }
}
.sec4 .list li a .img img {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: auto;
  transform: translateY(-50%);
}
.sec4 .list li a .date_wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 3px 1px;
}
@media screen and (max-width: 1000px) {
  .sec4 .list li a .date_wrap {
    padding: 0 0.9333333333vw 0.4vw;
  }
}
.sec4 .list li a .date_wrap .cat {
  letter-spacing: 0.08em;
}
@media print {
  .sec4 .list li a .date_wrap .cat {
    line-height: 1.4;
  }
}
@media screen and (max-width: 1000px) {
  .sec4 .list li a .date_wrap .cat {
    font-size: 2rem;
    letter-spacing: 0;
  }
}
.sec4 .list li a .date_wrap .cat::before {
  content: "●";
  margin: 0 7px 0 0;
}
@media screen and (max-width: 1000px) {
  .sec4 .list li a .date_wrap .cat::before {
    margin: 0 0.1333333333vw 0 0;
  }
}
.sec4 .list li a .text {
  display: block;
  line-height: 1.75;
  margin: 0 0 11px;
  font-size: 1.8rem;
}
@media screen and (max-width: 1000px) {
  .sec4 .list li a .text {
    line-height: 1.8;
    margin: 0 0 2.6666666667vw;
    font-size: 2.5rem;
  }
}
@media print {
  .sec4 .list li a .text {
    font-size: 1.6rem;
  }
}
.sec4 .list li a .date {
  display: block;
  color: #5032af;
  font-size: 1.5rem;
  letter-spacing: 0.13em;
}
@media screen and (max-width: 1000px) {
  .sec4 .list li a .date {
    font-size: 2.2rem;
  }
}
.sec4 .list .new {
  position: relative;
}
.sec4 .list .new::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 60px;
  height: 60px;
  background: url("../images/common/new.png") no-repeat 0/100%;
}
@media screen and (max-width: 1000px) {
  .sec4 .list .new::after {
    top: -1px;
    width: 10.1333333333vw;
    height: 10.1333333333vw;
  }
}
.sec4 .btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 290px;
  height: 66px;
  margin: 0 auto;
  border-radius: 1000px;
  background: #fff;
  border: 1px solid #5032af;
  color: #5032af;
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1000px) {
  .sec4 .btn a {
    width: 80vw;
    height: 12vw;
    padding: 0 0 0 2.2666666667vw;
    font-size: 3rem;
    letter-spacing: 0.13em;
  }
}
.sec4 .btn a::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 20px;
  width: 9px;
  height: 22px;
  transform: translateY(-50%);
  background: url("../images/common/arrow_r_skew.svg") no-repeat center/100%;
}
@media screen and (max-width: 1000px) {
  .sec4 .btn a::before {
    width: 1.4666666667vw;
    height: 4.1333333333vw;
  }
}

.modal_wrap {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 1000;
  background: rgba(80, 50, 175, 0.85);
  opacity: 0;
  transition: 0.3s;
  transition-property: opacity;
  pointer-events: none;
}
.modal_wrap.show {
  opacity: 1;
  pointer-events: all;
}
.modal_wrap .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.modal_wrap .modal {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 840px;
  max-height: 92vh;
  padding: 70px 50px 124px;
  background: #fff;
  translate: -50% -50%;
}
@media screen and (max-width: 900px) {
  .modal_wrap .modal {
    width: 92vw;
    max-height: 96vh;
    padding: 6vw 4.6666666667vw 18.6666666667vw;
    translate: -50% calc(-55.2% + 11.2vw);
  }
}
.modal_wrap .modal .modal_close {
  position: absolute;
  top: 0;
  right: -96px;
}
@media screen and (max-width: 900px) {
  .modal_wrap .modal .modal_close {
    top: 10px;
    right: 10px;
    scale: 0.7;
  }
}
@media screen and (max-width: 900px) and (max-width: 1000px) {
  .modal_wrap .modal .modal_close {
    top: -10.4vw;
    right: 0;
    width: 9.3333333333vw;
  }
}
.modal_wrap .modal .modal_box {
  display: none;
  height: calc(92vh - 194px);
}
@media screen and (max-width: 1000px) {
  .modal_wrap .modal .modal_box {
    max-height: calc(92vh - 24.6666666667vw);
  }
}
.modal_wrap .modal .modal_box.show {
  display: block;
}
.modal_wrap .modal .modal_box .inner {
  max-height: 100%;
  overflow: scroll;
}
.modal_wrap .modal .modal_box .inner .img {
  margin: 0 0 35px;
}
@media screen and (max-width: 1000px) {
  .modal_wrap .modal .modal_box .inner .img {
    margin: 0 0 2vw;
  }
}
.modal_wrap .modal .modal_box .inner h3 {
  line-height: 1.6;
  padding: 0 0 12px;
  border-bottom: 1px solid #5032af;
  font-size: 3rem;
}
@media screen and (max-width: 1000px) {
  .modal_wrap .modal .modal_box .inner h3 {
    font-size: 3.4rem;
    padding: 0 0 2.6666666667vw;
  }
}
.modal_wrap .modal .modal_box .inner .company {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 1.6rem;
  font-weight: 500;
  padding: 15px 0;
}
@media screen and (max-width: 1000px) {
  .modal_wrap .modal .modal_box .inner .company {
    padding: 2.6666666667vw 0 2.6666666667vw;
    font-size: 2rem;
  }
  .modal_wrap .modal .modal_box .inner .company .img290 {
    width: 38.6666666667vw;
  }
  .modal_wrap .modal .modal_box .inner .company .img240 {
    width: 32vw;
  }
  .modal_wrap .modal .modal_box .inner .company .img212 {
    width: 28.2666666667vw;
  }
  .modal_wrap .modal .modal_box .inner .company .img192 {
    width: 25.6vw;
  }
  .modal_wrap .modal .modal_box .inner .company .img166 {
    width: 22.1333333333vw;
  }
  .modal_wrap .modal .modal_box .inner .company .img115 {
    width: 15.3333333333vw;
  }
  .modal_wrap .modal .modal_box .inner .company .img88 {
    width: 11.7333333333vw;
  }
}
.modal_wrap .modal .modal_box .inner .text {
  line-height: 2;
  padding: 0 0 20px;
  font-size: 1.6rem;
}
@media screen and (max-width: 1000px) {
  .modal_wrap .modal .modal_box .inner .text {
    padding: 0 0 4vw;
    font-size: 2.6rem;
  }
}
.modal_wrap .modal .modal_box .inner .link {
  position: absolute;
  bottom: 40px;
  left: 50%;
  translate: -50%;
  margin-top: 75px;
}
@media screen and (max-width: 1000px) {
  .modal_wrap .modal .modal_box .inner .link {
    margin-top: 6.6666666667vw;
    bottom: 4vw;
  }
}
.modal_wrap .modal .modal_box .inner .link a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 290px;
  height: 66px;
  padding: 0 0 3px;
  margin: 0 auto;
  border-radius: 100px;
  background: #3cc8eb;
  color: #fff;
  font-size: 2rem;
  font-weight: 500;
}
@media screen and (max-width: 1000px) {
  .modal_wrap .modal .modal_box .inner .link a {
    width: 53.3333333333vw;
    height: 12vw;
    padding: 0 0 0.4vw;
    font-size: 3rem;
  }
}
.modal_wrap .modal .modal_box .inner .link a::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 23px;
  width: 12px;
  height: 12px;
  translate: 0 -50%;
  background: url("../images/rc/tab.svg") no-repeat center/100%;
}

/*# sourceMappingURL=rc.css.map */
