.visual {
    position: relative;
}
.visual .main_video {
    position: relative;
    width: 100%;
    height: 832px;
    overflow: hidden;
}
.visual .main_video::after {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.16);
    content: "";
}
.visual .main_video::before {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(-90deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.4)), linear-gradient(-90deg, rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0));
    content: "";
}
.visual .main_video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.visual .visial_title {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    position: absolute;
    left: 50%;
    bottom: 100px;
    width: 1200px;
    transform: translate(-50%, 0);
    color: var(--white);
}
.visual .visial_title .video_play {
    display: none;
}
.visual .visial_title .video_play button {
    position: absolute;
    left: 50%;
    transform: translate(-50%, 0);
    top: -100px;
    z-index: 10;
    width: 68px;
    height: 68px;
}
.visual .visial_title .video_play button img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.visual .visial_title .video_play button.pause_btn {
    display: none;
}
.visual .visial_title .video_play.pause button.paly_btn {
    display: none;
}
.visual .visial_title .video_play.pause button.pause_btn{
    display: block;
}
.visual .visial_title h2 {
    font-size: 51px;
    margin-bottom: 45px;
}
.visual .visial_title p {
    position: relative;
    font-size: 18px;
    width: 30%;
    line-height: 1.55;
    padding-top: 15px;
}
.visual .visial_title p::before {
    position: absolute;
    left: 0;
    top: 0;
    width: 38px;
    height: 1px;
    background-color: var(--white);
    content: "";
}
.visual .visial_title .visual_btn {
    font-size: 17px;
    font-weight: 600;
    min-width: 174px;
    border-radius: 100px;
    padding: 15px 24px 17px 24px;
    background-color: var(--mainorange);
}
.visual .visial_title .visual_btn:hover {
    background-color: var(--hoverorange);
}

.effect {
    position: relative;
    color: #4C4C4C;
    padding: 150px 0 160px;
    overflow: hidden;
}
.effect::before {
    position: absolute;
    left: 0;
    top: 0;
    z-index: -10;
    width: 100%;
    height: 100%;
    background-color: var(--bgorange);
    content: "";
}
.effect > ul > li {
    display: flex;
    align-items: center;
    /* justify-content: space-between; */
    margin-bottom: 215px;
}
.effect > ul > li:last-child {
    margin-bottom: 0;
}
.effect > ul > li:nth-child(1) {
    margin-left: calc(50% - 600px);
}
.effect ul li .detail {
    width: 600px;
}
.effect ul li .detail .e_ico {
   width: 53px;
   height: 53px;
   margin-bottom: 25px;
}
.effect ul li .detail .e_ico img {
    width: 100%;
    height: 100%;object-fit: contain;
}
.effect ul li .detail h2 {
    font-size: 39px;
    line-height: 1.33;
    color: var(--mainbrown);
    margin-bottom: 25px;
}
.effect ul li .detail h2 em {
    color: var(--mainorange);
}
.effect > ul > li .detail p {
    font-size: 18px;
    line-height: 1.5;
    margin-bottom: 25px;
}
.effect ul li .detail ul li {
    margin-bottom: 15px;
}
.effect ul li .detail ul li:last-child {
    margin-bottom: 0;
}
.effect ul li .detail ul li span {
    position: relative;
    display: block;
    font-size: 18px;
    line-height: 1.5;
    padding-left: 29px;
    margin-bottom: 4px;
}
.effect ul li .detail ul li p {
    font-size: 16px;
    line-height: 1.37;
}
.effect ul li .detail ul li span:last-child {
    margin-bottom: 0;
}
.effect ul li .detail ul li span::before {
    position: absolute;
    left: 0;
    top: 8px;
    width: 13px;
    height: 9px;
    background: url(../img/icon/check_lco.svg) no-repeat center center / contain;
    content: "";
}
.effect ul li .photo_r {
    position: relative;
    margin-left: 120px;
    min-height: 530px;
    width: 50%;
    padding: 54px 0 54px 30px;
}
.effect ul li .photo_r::before {
    position: absolute;
    left: 0;
    top: 50%;
    width: 300%;
    height: 530px;
    transform: translate(0, -50%);
    border-radius: 40px 0 0 40px;
    z-index: -10;
    background: radial-gradient( circle at 0 50%, rgba(255, 236, 218,1) , rgba(255, 209, 165,1));
    content: "";
}
.effect ul li .photo_l {
    position: relative;
    margin-right: 120px;
    min-height: 530px;
    width: calc(50% - 120px);
    padding: 54px 30px 54px 0;
}
.effect ul li .photo_l::before {
    position: absolute;
    right: 0;
    top: 50%;
    width: 300%;
    height: 530px;
    transform: translate(0, -50%);
    border-radius: 0 40px 40px 0;
    z-index: -10;
    background: linear-gradient( 181deg, rgba(255, 236, 218, 1), rgba(255, 209, 165, 1));
    content: "";
}
.effect ul li .photo_r .effect01_p {
    width: 700px;
    height: 530px;
}
.effect ul li .photo_l .effect02_p {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 764px;
    height: 530px;
}
.effect ul li .photo_r .effect01_p img,
.effect ul li .photo_l .effect02_p img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.effect ul li .detail_r {
    width: 600px;
}

.success {
    position: relative;
    /* background-color: var(--bgorange); */
    text-align: center;
    min-height: 861px;
    padding: 190px 0 130px 0;
    overflow: hidden;
}
.success::before {
    position: absolute;
    left: 0;
    top: 0;
    z-index: -20;
    width: 100%;
    height: 100%;
    background-color: var(--bgorange);
    content: "";
}
.success::after {
    position: absolute;
    left: calc(50% - 20px);
    top: 0;
    transform: translate(-50%, 0);
    z-index: -10;
    width: 1681px;
    height: 1034px;
    background: url(../img/program/success_bg.png) no-repeat center center / contain;
    content: "";
}
.success .wrapper h2 {
    position: relative;
    font-size: 49px;
    /* line-height: 1.2; */
    color: var(--mainbrown);
    padding-bottom: 30px;
    margin-bottom: 85px;
}
.success .wrapper h2 em {
    font-size: 100px;
    color: var(--mainorange);
}
.success .wrapper h2 span.rate {
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 0);
    font-size: 21px;
    color: var(--mainorange);
}
.success .wrapper .list {
    display: flex;
    justify-content: space-between;
}
.success .wrapper .list li {
    display: flex;
    flex-direction: column;
    justify-content: space-evenly;
    align-items: center;
    width: 33.33%;
    min-height: 285px;
    padding: 25px;
    border-radius: 24px;
    margin-right: 16px;
    background-color: rgba(255, 255, 255, 0.1);
    color: #685D52;
    box-shadow: inset 2px -3px 11px rgba(0, 0, 0, 0.1);
}
.success .wrapper .list li:last-child {
    margin-right: 0;
}
.success .wrapper .list li .success_ico {
    width: 126px;
    height: 124px;
    /* margin-bottom: 8px; */
}
.success .wrapper .list li.list01 .success_ico {
    width: 103.65px;
    height: 102px;
    /* margin-bottom: 14px; */
}
.success .wrapper .list li .success_ico img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.success .wrapper .list p {
    font-size: 15px;
    line-height: 1.6;
}

.videos {
    position: relative;
    width: 100%;
    padding: 104px 0 119px;
    min-height: 1383px;
    text-align: center;
    color: var(--white);
    overflow: hidden;
}
.videos::before {
    position: absolute;
    left: 0;
    top: 0;
    z-index: -10;
    width: 100%;
    height: 100%;
    background-color: var(--mainorange);
    content: "";
}
.videos .wrapper .center {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 130px;
}
.videos .wrapper .center h2 {
    font-size: 45px;
}
.videos .wrapper .center .v_main {
    position: relative;
    width: 751px;
    height: 471px;
    border-radius: 30px;
    overflow: hidden;
    margin: 35px 0;
}
.videos .wrapper .center .v_main video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.videos .wrapper .center .v_bg_ico {
    position: absolute;
    left: 0;
    top: 450px;
    z-index: -5;
    display: flex;
    align-items: center;
    width: 5216px;
    height: 77.6px;
    white-space:nowrap;
    animation:move_bg_ico;
    animation-duration: 30s;
    animation-timing-function:linear;
    animation-iteration-count:infinite;
}
.videos .wrapper .center .v_bg_ico img {
    width: 2608px;
    height: 77.6px;
}
@keyframes move_bg_ico {
	0% { transform:translate(0, 0) }
	100% { transform:translate(-50%, 0) }
}
.videos .wrapper .center span {
    font-size: 28px;
    margin-bottom: 8px;
}
.videos .wrapper .center p {
    font-size: 17px;
    color: #FFE3CF;
}
.videos .wrapper .videos_sub .swiper {
    position: relative;
    width: 100%;
}
.videos .wrapper .videos_sub .swiper::before {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 20;
    width: 135px;
    height: 100%;
    background: linear-gradient(-90deg, rgba(255, 130, 4, 0), rgba(255, 130, 4, 1));
    content: "";
}
.videos .wrapper .videos_sub .swiper::after {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 20;
    width: 135px;
    height: 100%;
    background: linear-gradient(90deg, rgba(255, 130, 4, 0), rgba(255, 130, 4, 1));
    content: "";
}
.videos .wrapper .videos_sub .swiper .swiper-wrapper {
    transition-timing-function: linear;
}
.videos .wrapper .videos_sub ul li {
    position: relative;
    width: 298.32px;
    height: 155.1px;
}
.videos .wrapper .videos_sub ul li .photo {
    width: 298.32px;
    height: 155.1px;
}
.videos .wrapper .videos_sub ul li .photo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.videos .wrapper .videos_sub ul li span {
    position: absolute;
    display: block;
    left: 22px;
    bottom: 14px;
    display: block;
    font-size: 15px;
    line-height: 1.4;
    color: var(--white);
    text-align: left;
}
.videos .wrapper .videos_sub .swiper.videos_sub01 {
    margin-bottom: 25px;
}

@media screen and (max-width: 1280px) {
    .visual .visial_title {
        width: 100%;
        padding: 0 60px;
    }
    .effect {
        padding: 80px 0;
    }
    .effect > ul > li {
        flex-direction: column;
        margin-bottom: 100px;
        padding: 0 60px;
    }
    .effect > ul > li:nth-child(1) {
        margin-left: 0;
    }
    .effect ul li .detail {
        width: 100%;
    }
    .effect ul li .photo_r {
        position: relative;
        margin-left: 0;
        min-height: 530px;
        width: 100%;
        padding: 54px 0;
        overflow: hidden;
    }
    .effect ul li .photo_r::before {
        width: 100%;
        height: 450px;
        border-radius: 40px;
    }
    .effect ul li .photo_l {
        position: absolute;
        bottom: 0;
        margin-right: 0;
        min-height: 450px;
        width: 100%;
        padding: 54px 0;
        overflow: hidden;
    }
    .effect ul li .photo_l::before {
        left: 60px;
        width: calc(100% - 120px);
        height: 450px;
        transform: translate(0, -50%);
        border-radius: 40px;
    }
    .effect ul li .detail_r {
        padding-bottom: 450px;
        width: 100%;
    }
    .effect ul li .photo_r {
        margin-top: 100px;
    }
    .effect ul li .photo_r .effect01_p {
        position: absolute;
        left: 50%;
        top: 30px;
        width: 600px;
        height: 450px;
        transform: translate(-50%, 0);

    }
    .effect ul li .photo_l .effect02_p {
        position: absolute;
        right: 50%;
        transform: translate(50%, 0);
        bottom: 0;
        width: 650px;
        height: 450px;
    }
    .effect ul li .detail_r {
        width: 100%;
    }

}
@media screen and (max-width: 768px) {
    .visual .main_video {
        height: 600px;
    }
    .visual .visial_title {
        bottom: 100px;
        width: 100%;
        padding: 0 20px;
    }
    .visual .inner .visial_title {
        padding-bottom: 80px;
    }
    .visual .visial_title h2 {
        font-size: 31px;
        margin-bottom: 10px;
        padding-bottom: 172px;
        width: 100%;
    }
    .visual .visial_title {
        padding: 0 20px;
        left: 0;
        transform: translate(0, 0);
        justify-content: flex-start;
    }
    .visual .visial_title .video_play {
        display: block;
    }
    .visual .visial_title .visual_btn {
        position: absolute;
        bottom: 0;
    }
    .visual .visial_title p {
        position: absolute;
        bottom: 80px;
        width: fit-content;
    }
    .visual .visial_title p::before {
        display: none;
    }
    .visual .visial_title .visual_btn {
        font-size: 17px;
        font-weight: 600;
        min-width: 174px;
        border-radius: 100px;
        padding: 15px 24px 17px 24px;
        background-color: var(--mainorange);
    }
    .effect > ul > li {
        padding: 0 20px;
    }
    .effect ul li .detail .e_ico {
        width: 37px;
        height: 37px;
        margin-bottom: 21px;
    }
    .effect ul li .detail h2 {
        font-size: 26px;
        margin-bottom: 36px;
    }
    .effect > ul > li .detail p {
        font-size: 16px;
        margin-bottom: 16px;
    }
    .effect ul li .detail ul li {
        margin-bottom: 16px;
    }
    .effect ul li .detail ul li span {
        font-size: 16px;
        padding-left: 24px;
        margin-bottom: 16px;
    }
    .effect ul li .detail ul li span::before {
        top: 8px;
        width: 10px;
        height: 7px;
        background: url(../img/icon/check_lco_orange.svg) no-repeat center center / contain;
    }
    .effect ul li .photo_r {
        min-height: 295px;
        padding: 0;
        margin-top: 40px;
    }
    .effect ul li .photo_r::before {
        height: 295px;
        border-radius: 25px;
    }
    .effect ul li .photo_l {
        position: absolute;
        bottom: 0;
        margin-right: 0;
        min-height: 295px;
        height: 295px;
        width: 100%;
        padding: 0;
        overflow: hidden;
    }
    .effect ul li .photo_l::before {
        left: 20px;
        width: calc(100% - 40px);
        height: 295px;
        border-radius: 25px;
    }
    .effect ul li .detail_r {
        padding-bottom: 480px;
        width: 100%;
    }
    .effect ul li .photo_r {
        margin-top: 40px;
    }
    .effect ul li .photo_r .effect01_p {
        position: absolute;
        left: calc(50% + 20px);
        top: 0;
        width: 390px;
        height: 295px;
        transform: translate(-50%, 0);
    }
    .effect ul li .photo_l .effect02_p {
        position: absolute;
        right: 50%;
        transform: translate(50%, 0);
        bottom: 0;
        width: 426px;
        height: 295px;
    }
    .effect ul li .detail_r {
        padding-bottom: 295px;
    }

    .success {
        min-height: auto;
        padding: 160px 0 90px 0;
    }
    .success::after {
        left: calc(50% - 20px);
        top: 80px;
        transform: translate(-50%, 0);
        width: 490px;
        height: 320px;
    }
    .success .wrapper h2 {
        font-size: 32px;
        padding-bottom: 0;
        margin-bottom: 40px;
    }
    .success .wrapper h2 em {
        font-size: 66px;
    }
    .success .wrapper h2 span.rate {
        position: relative;
        left: 0%;
        transform: translate(0, 0);
        font-size: 18px;
    }
    .success .wrapper .list {
        flex-direction: column;
    }
    .success .wrapper .list li {
        width: 100%;
        min-height: 216px;
        padding: 25px;
        border-radius: 25px;
        margin-right: 0;
        margin-bottom: 20px;
        background: linear-gradient( 45deg , rgba(255, 255, 255, 0.2) 0 , rgba(255, 214, 172, 0.2) 100% );
        backdrop-filter: blur(30px);
        -webkit-backdrop-filter: blur(30px);
        box-shadow: inset 2px -3px 8px rgba(116, 58, 0, 0.2);
    }
    .success .wrapper .list li:last-child {
        margin-bottom: 0;
    }
    .success .wrapper .list li .success_ico {
        width: 77px;
        height: 71px;
        margin-bottom: 10px;
    }
    .success .wrapper .list li.list01 .success_ico {
        width: 80px;
        height: 78px;
        margin-bottom: 10px;
    }
    .videos {
      padding: 80px 0;
      min-height: auto;
    }
    .videos::before {
      background: linear-gradient( 180deg , #FF8204 , rgba(255, 255, 255, 0) );
    }
    .videos .wrapper {
      width: 100%;
      padding: 0;
    }
    .videos .wrapper .center {
        margin-bottom: 38px;
    }
    .videos .wrapper .center h2 {
      font-size: 27px;
    }
    .videos .wrapper .center .v_main {
      width: 316px;
      height: 218px;
      border-radius: 23px;
      margin: 38px 0 80px 0;
    }
    .videos .wrapper .center .v_bg_ico {
      top: 260px;
      width: 4838px;
      height: 72px;
      animation-duration: 30s;
    }
    .videos .wrapper .center .v_bg_ico img {
      width: 2419px;
      height: 72px;
    }
    .videos .wrapper .center span {
      font-size: 20px;
      margin-bottom: 4px;
      color: var(--mainorange);
    }
    .videos .wrapper .center p {
      font-size: 15px;
      color: #C2A28E;
    }
    .videos .wrapper .videos_sub .swiper {
      position: relative;
    }
    .videos .wrapper .videos_sub .swiper::before,
    .videos .wrapper .videos_sub .swiper::after  {
      display: none;
    }
    .videos .wrapper .videos_sub ul li {
      position: relative;
      width: 168px;
      height: 98px;
      border-radius: 13px;
      overflow: hidden;
    }
    .videos .wrapper .videos_sub ul li .photo {
      width: 168px;
      height: 98px;
    }
    .videos .wrapper .videos_sub ul li .photo img {
      object-fit: cover;
    }
    .videos .wrapper .videos_sub ul li span {
      display: none;
    }
    .videos .wrapper .videos_sub .swiper.videos_sub01 {
      margin-bottom: 15px;
    }

}
@media screen and (max-width: 400px) { 
   
    .effect ul li .photo_r {
        height: 250px;
    }
    .effect ul li .photo_r::before {
        height: 250px;
    }
    .effect ul li .photo_r .effect01_p {
        width: 300px;
        height: 226px;
        top: 30px;
    }
    .effect ul li .photo_l  {
        height: 250px;
        min-height: 250px;
    }
    .effect ul li .photo_l::before {
        height: 250px;
    }
    .effect ul li .photo_l .effect02_p {
        width: 300px;
        height: 207px;
    }
    .effect ul li .detail_r {
        padding-bottom: 210px;
    }
    .videos .wrapper .center h2 {
        padding: 0 20px;
    }
    .videos .wrapper .center .v_main {
        width: 290px;
        height: 200px;
    }
}
