.s1{background-color: yellow}
.s2{background-color:#ddd;}
.s3{background-color:#bbb;}
.s4{background-color:green}
.s5{background-color:#444;}

.title-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 36px;
    margin-bottom: 100px;
}
.title-box h1 {
    font-size: 48px;
    color: #D71819;
}
.title-box p {
    font-size: 28px;
    line-height: 1.4;
}
.text-gr {
    background: linear-gradient(to right, rgba(288,117,82,0.87), #00FBFF) !important;
    color: transparent !important;
    -webkit-background-clip: text !important;
}
.bg-gr {
    background: linear-gradient(to right, #4F5299, #DA4643);
}
.box_gr {
    background: linear-gradient(150deg, rgba(255,255,255,0.3) 0%, rgba(248,250,255,0.8) 33%, rgba(245,248,255,0.9) 58%, rgba(248,251,255,0.65) 73%, rgba(255,255,255,0.2) 100%);
}
.gr-02 {
    background: linear-gradient(to right, #E47552, #DA4643);
}
.text-gr-02 {
    background: linear-gradient(to right, #E47552, #DA4643);
    color: transparent !important;
    -webkit-background-clip: text !important;
}
.text-gr-03 {
    background: linear-gradient(to right, #E47552, #A33B56);
    color: transparent !important;
    -webkit-background-clip: text !important;
}
.text-gr-04 {
    background: linear-gradient(#CF3C4D, #EC6A5B);
    color: transparent !important;
    -webkit-background-clip: text !important;
}

/********** floating-btn **********/
.floating-btn {
    border-radius: 0;
    z-index: 40;
    color: #fff;
    bottom: 0;
    height: 60px;
    font-size: 17px;
    font-weight: 600;
    display: none;
}


/********** header **********/
header {
    height: 100px;
    position: fixed;
    width: 100%;
    z-index: 50;
    transition: .3s;
}
header.active {
    background-color: #fff;
}
header ul li a {
    font-size: 19px;
    font-weight: 500;
    color: #999;
}
header ul li a.active {
    color: #D71819;
}
header ul li .apply-btn {
    background-color: #D71819;
    color: #fff;
    padding: 10px 20px;
    border-radius: 12px 12px 12px 4px;
}
header ul li .apply-btn:hover {
    background: #DA4643;
}
/* side-menu */
.side-menu {
    left: 100%;
}
.side-menu .header,
.side-menu .middle-box {
display: none;
}

/* 반응형 */
@media (max-width: 1280px) {
    header, .header {
        height: 64px;
    }
    header .header-wrap ul {
        display: none;
    }
    header .header-wrap .menu-btn {
        display: block !important;
    }
    .title-box {
        gap: 28px;
        margin-bottom: 68px;
    }
    .title-box h1 {
        font-size: 40px;
    }
    .title-box p {
        font-size: 24px;
    }
    .side-menu {
        z-index: 1000;
        top: 0;
        left: 100%;
        width: 100%;
        height: 100%;
        background-color: #fff;
        position: fixed;
        transition: all .3s;
      }
      .side-menu.active {
        left: 0;
      }
      .side-menu .header {
        position: relative;
        display: flex;
      }
      .side-menu .middle-box {
        display: block;
        margin-top: 140px;
      }
      .side-menu ul {
        gap: 40px 0;
      }
      .side-menu ul li a {
        font-size: 18px;
        font-weight: 700;
      }
      .side-menu ul li a.active {
        color: #D71819;
      }
      /* .side-menu .apply-btn {
        background-color: #D71819;
        color: #fff;
        padding: 10px 20px;
        border-radius: 12px 12px 12px 4px;
      } */
      .main-visual .kv-text .apply-btn {
        display: none;
    }
    .floating-btn {
        display: flex;
    }
}
@media (max-width: 767px) {
    header, .header {
        height: 60px;
    }
    header .header-wrap .logo {
        width: 76px;
    }
    header .header-wrap .menu-btn {
        width: 24px;
        height: 24px;
    }
    .title-box {
        gap: 20px;
        margin-bottom: 40px;
    }
    .title-box h1 {
        font-size: 22px;
    }
    .title-box p {
        font-size: 16px;
    }
}


/********** 메인 비주얼 **********/
.main-visual {
    height: 100vh;
    overflow: hidden;
    background: url(../img/kv-bg.svg)no-repeat center/cover;
}
.main-visual .kv-text {
    top: 18%;
}
.main-visual .kv-text .img-box {
    width: 45vh;;
}
.main-visual .kv-text p {
    font-size: 44px;
    margin-top: 64px;
    margin-bottom: 36px;
    line-height: 1.4;
    font-weight: 600;
}
.main-visual .kv-text p span {
    color: #D71819;
}
.main-visual .kv-text .apply-btn {
    color: #fff;
    font-weight: 600;
    font-size: 22px;
    border-radius: 12px 12px 12px 6px;
    background: linear-gradient(to right, #4F5299, #DA4643);
    max-width: 247px;
    height: 60px;
}
.main-visual .kv-text .apply-btn:hover{
    background: linear-gradient(to right, #E47552, #DA4643);
}
.kv-visual {
    height: 100%;
    top: 0;
    right: 0;
    width: 945px;
}
.kv-visual .kv-main-box {
    height: 380px;
    right: 13vw;
    top: 30vh;
    width: 384px;
}
.kv-visual .kv-main-box span {
    width: 100%;
}
.kv-visual .kv-main-box .kv-main-1-1 {
    top: -60px;
}
.kv-visual .kv-main-box .kv-main-1-2 {
    bottom: -60px;
}
.kv-visual .kv-main-1 {
    width: 220px;
    top: 654px;
    right: 567px;
}
.kv-visual .kv-main-2 {
    width: 487px;
    top: 80px;
    right: -148px;
}
.kv-visual .kv-main-3 {
    width: 270px;
    top: 373px;
    right: 40px;
}
.kv-visual .kv-main-4 {
    width: 400px;
    top: 570px;
    right: -128px;
}
.kv-visual .kv-main-box .kv-main-1-1 img {
    animation-name: moving_1-2;
    animation-duration: 2.5s;
    animation-delay: 0.3s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.kv-visual .kv-main-box .kv-main-1-2 img {
    animation-name: moving_1-2;
    animation-duration: 2.5s;
    animation-delay: 0.5s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.kv-visual .kv-main-box .kv-main-1-3 img {
    animation-name: moving_1-2;
    animation-duration: 2.5s;
    animation-delay: 0.7s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.kv-visual .kv-main-1 img {
    animation-name: moving_1;
    animation-duration: 2.5s;
    animation-delay: 0.9s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.kv-visual .kv-main-2 img {
    animation-name: moving_1-2;
    animation-duration: 2.5s;
    animation-delay: 1.1s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.kv-visual .kv-main-3 img {
    transform: rotate(80deg);
    animation-name: moving_1-1;
    animation-duration: 2.5s;
    animation-delay: 1.3s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.kv-visual .kv-main-4 img {
    animation-name: moving_1-2;
    animation-duration: 2.5s;
    animation-delay: 1.5s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}

/* 반응형 */
@media (max-width: 1280px) {
    .main-visual .kv-text {
        top: 16%;
    }
    .main-visual .kv-text .img-box {
        width: 34vh;
    }
    .main-visual .kv-text p {
        margin-top: 40px;
        margin-bottom: 24px;
        font-size: 26px;
        line-height: 1.6;
    }
    .main-visual .kv-text .apply-btn {
        height: 48px;
        max-width: 160px;
        border-radius: 8px 8px 8px 4px;
        font-size: 18px;
    }
    .kv-visual {
        transform: scale(0.75);
        right: -140px;
    }
}

@media (max-width: 767px) {
    .main-visual .kv-text {
        top: 12%;
    }
    .main-visual .kv-text .img-box {
        width: 28vh;
    }
    .main-visual .kv-text p {
        margin-top: 20px;
        margin-bottom: 12px;
        font-size: 18px;
    }
    .main-visual .kv-text .apply-btn {
        height: 36px;
        max-width: 120px;
        border-radius: 6px 6px 6px 3px;
        font-size: 15px;
    }
    .kv-visual {
        transform: scale(0.5);
        bottom: -100px;
        top: auto;
        right: -180px;
    }
    .kv-visual .kv-main-1 {
        right: 367px;
    }
}


/********** 스크롤 sec-1 **********/
.sec-1 {
    background: url(../img/sec-bg-1.svg)no-repeat center/cover;
    width: 100%;
    height: 100vh;
}
.sec-1 .text-box {
    margin-top: 56px;
}
.sec-1 .text-box h1 {
    font-size: 52px;
    line-height: 1.6;
    text-align: center;
}
.sec-1 .img-box img {
    animation-name: moving_1;
    animation-duration: 2.5s;
    animation-delay: 0.5s;
    animation-iteration-count: infinite;
}

/* 반응형 */
@media (max-width: 1280px) {
    .sec-1 .img-box {
        max-width: 160px;
    }
    .sec-1 .text-box {
        margin-top: 68px;
    }
    .sec-1 .text-box h1 {
        font-size: 40px;
    }
}

@media (max-width: 767px) {
    .sec-1 .img-box {
        max-width: 80px;
    }
    .sec-1 .text-box {
        margin-top: 32px;
    }
    .sec-1 .text-box h1 {
        font-size: 26px;
    }
    .sec-1 .text-box h1 br {
        display: block !important;
    }
}


/********** 스크롤 sec-2 **********/
.sec-2 {
    background: url(../img/sec-bg-1.svg)no-repeat center/cover;
    width: 100%;
    height: 100vh;
}
.sec-2 .bg-obj {
    position: absolute;
    bottom: 0;
    z-index: 2;
    left: 0;
    /* background: url(../img/sec2-obj.svg)no-repeat center/cover; */
    width: 3000px;
    height: 300px;
    transform: translateX(0);
    animation-name: moving_2;
    animation-duration: 6s;
    /* animation-delay: 0.5s; */
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.sec-2 .text-box {
    margin-top: -150px;
}
.sec-2 .text-box h1 {
    font-size: 52px;
    line-height: 1.6;
}

/* 반응형 */
@media (max-width: 1280px) {
    .sec-2 .text-box h1 {
        font-size: 40px;
    }
    .sec-2 .bg-obj {
        width: 2000px;
    }
}

@media (max-width: 767px) {
    .sec-2 .text-box h1 {
        font-size: 26px;
    }
    .sec-2 .text-box h1 br {
        display: block;
    }
    .sec-2 .bg-obj {
        width: 1100px;
        bottom: -100px;
    }
}


/********** 스크롤 sec-3 **********/
.sec-3 {
    background: linear-gradient(to right, #4F5299, #DA4643);
    width: 100%;
    height: 100vh;
}
.sec-3 .text-box h1 {
    font-size: 52px;
    background: linear-gradient(to right, rgba(288,117,82,0.87), #00FBFF);
    color: transparent;
    -webkit-background-clip: text;
}
.sec-3 .text-box p {
    color: #fff;
    font-size: 40px;
    margin-top: 36px;
    font-weight: 600;
}
.sec-3 .bg-obj {
    position: absolute;
    z-index: 2;
    width: 130vh;
}
.sec-3 .bg-obj-1 {
    left: -900px;
    top: -50%;
}
.sec-3 .bg-obj-2 {
    right: -900px;
    bottom: -50%;
}

/* 반응형 */
@media (max-width: 1280px) {
    .sec-3 .text-box h1 {
        font-size: 40px;
    }
    .sec-3 .text-box p {
        font-size: 30px;
    }
    .sec-3 .text-box p br {
        display: block;
    }
    .sec-3 .bg-obj {
        width: 60vh;
    }
    .sec-3 .bg-obj-1 {
        left: -300px;
        top: -15%;
    }
    .sec-3 .bg-obj-2 {
        right: -300px;
        bottom: -15%;
    }
}

@media (max-width: 1024px) {
    .sec-3 .bg-obj-1 {
        left: -500px;
    }
    .sec-3 .bg-obj-2 {
        right: -500px;
    }
}
@media (max-width: 920px) {
    .sec-3 .bg-obj-1 {
        left: -350px;
    }
    .sec-3 .bg-obj-2 {
        right: -350px;
    }
}

@media (max-width: 767px) {
    .sec-3 .text-box h1 {
        font-size: 26px;
    }
    .sec-3 .text-box h1 br {
        display: block;
    }
    .sec-3 .text-box p {
        font-size: 16px;
        margin: 20px 0;
    }
    .sec-3 .bg-obj {
        width: 250px;
    }
    .sec-3 .bg-obj-1 {
        left: -150px!important;
        top: -50px;
    }
    .sec-3 .bg-obj-2 {
        right: -150px!important;
        bottom: -50px;
    }
}




/********** sec-4 **********/
.sec-4 {
    background: url(../img/sec-bg-4.svg)no-repeat center/cover;
    width: 100%;
}
.sec-4 .title-box {
    margin-bottom: 68px;
}
.sec-4 .tab-area li a {
    font-size: 28px;
    line-height: 1.4;
    padding: 0 60px;
    height: 68px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #000;
    border-radius: 68px;
    white-space: nowrap;
}
.sec-4 .tab-area li a:hover{
    border: 1px solid #DA4643;
    color: #DA4643;
}
.sec-4 .tab-area li:first-child.active a {
    background: linear-gradient(to right, #E47552, #DA4643);
    color: #fff;
    border: 1px solid transparent;
    box-shadow: 0px 4px 12px #FFB7B7;
}
.sec-4 .tab-area li:nth-child(2).active a {
    background: linear-gradient(to right, #E47552, #A33B56);
    color: #fff;
    border: 1px solid transparent;
    box-shadow: 0px 4px 12px #FFB7B7;
}
.sec-4 .tab-area li:last-child.active a {
    background: linear-gradient(to right, #4F5299, #DA4643);
    color: #fff;
    border: 1px solid transparent;
    box-shadow: 0px 4px 12px #FFB7B7;
}
.sec-4 .tab-cnt-box-1 .box h2 {
    font-size: 32px;
    position: relative;
    padding-bottom: 10px;
}
.sec-4 .tab-cnt-box-1 .box h2::before {
    content: '';
    position: absolute;
    height: 2px;
    width: 100%;
    bottom: 0;
    left: 0;
    background-color: #000;
}
.sec-4 .tab-cnt-box-1 .box .coming-soon {
    display: none;
    background: linear-gradient(150deg, rgba(255,255,255,0.3) 0%, rgba(248,250,255,0.8) 33%, rgba(245,248,255,0.9) 58%, rgba(248,251,255,0.65) 73%, rgba(255,255,255,0.2) 100%);
    padding: 60px;
    border-radius: 20px 40px 40px 40px;
    text-align: center;
    width: 100%;
    max-width: 800px;
}
.sec-4 .tab-cnt-box-1 .box .coming-soon h3 {
    font-size: 40px;
    font-weight: 600;
    color: #D71819;
    line-height: 1.4;
}
.sec-4 .tab-cnt-box-1 .box-1 {
    margin-top: 100px;
    margin-bottom: 180px;
    gap: 84px;
}
.sec-4 .tab-cnt-box-1 .box-1 span {
    color: #999;
    line-height: 1.4;
    font-size: 20px;
    text-align: center;
    margin-top:  -2.4vw;
}
.sec-4 .tab-cnt-box-1 .box-2 h2 {
    margin-bottom: 72px;
}
.sec-4 .obj {
    position: absolute;
    width: 380px;
}
.sec-4 .obj-1 img,
.sec-4 .obj-2 img {
    transform: rotate(45deg);
}
.sec-4 .obj-1 {
    top: 200px;
    right: -190px;
}
.sec-4 .obj-2 {
    bottom: 500px;
    left: -190px;
}
.sec-4 .obj-3 {
    bottom: -260px;
    right: -560px;
    width: 916px;
}

/* 반응형 */
@media (max-width: 1280px) {
    .sec-4 .title-box {
        margin-bottom: 68px;
    }
    .sec-4 .tab-area {
        gap: 12px;
    }
    .sec-4 .tab-area li a {
        font-size: 24px;
    }
    .sec-4 .tab-cnt-box-1 .box-1 {
        gap: 64px;
    }
    .sec-4 .tab-cnt-box-1 .box-1 {
        margin-top: 60px;
        margin-bottom: 160px;
    }
    .sec-4 .tab-cnt-box-1 .box h2 {
        font-size: 28px;
    }
    .sec-4 .tab-cnt-box-1 #tab1-2 .pr-img {
        content: url(../img/default-pr-t.svg);
    }
    .sec-4 .tab-cnt-box-1 #tab1-3 .pr-img {
        content: url(../img/im-pr-t.svg);
    }
    .sec-4 .obj-1 {
        width: 260px;
        top: 50px;
        right: -157px;
    }
    .sec-4 .obj-2 {
        width: 260px;
        top: 900px;
        bottom: auto;
        left: -152px;
    }
    .sec-4 .obj-3 {
        bottom: -165px;
        right: -364px;
        width: 590px;
    }
    .sec-4 .tab-cnt-box-1 .box .coming-soon {
        gap: 40px;
    }
    .sec-4 .tab-cnt-box-1 .box .coming-soon h3 {
        font-size: 28px;
    }
    .sec-4 .tab-cnt-box-1 .box .coming-soon p {
        font-size: 20px;
    }
}


@media (max-width: 767px) {

    .sec-4 .title-box {
        margin-bottom: 48px;
    }
    .sec-4 .tab-area {
        gap: 8px;
    }
    .sec-4 .tab-area li a {
        font-size: 16px;
        height: 40px;
        padding: 0 20px;
    }
    .sec-4 .tab-cnt-box-1 .box-1 {
        gap: 32px;
        margin-top: 46px;
        margin-bottom: 88px;
    }
    .sec-4 .tab-cnt-box-1 .box h2 {
        font-size: 20px;
    }
    .sec-4 .tab-cnt-box-1 .box-1 .pr-img {
        max-width: 300px;
    }
    .sec-4 .tab-cnt-box-1 #tab1-1 .box-1 .pr-img {
        content: url(../img/intern-pr-t.svg);
    }
    .sec-4 .tab-cnt-box-1 #tab1-2 .pr-img {
        content: url(../img/default-pr-t.svg);
    }
    .sec-4 .tab-cnt-box-1 #tab1-3 .pr-img {
        content: url(../img/im-pr-t.svg);
    }
    .sec-4 .tab-cnt-box-1 .box-1 span {
        font-size: 15px;
    }
    .sec-4 .tab-cnt-box-1 .box-1 span br {
        display: block;
    }
    .sec-4 .tab-cnt-box-1 .box-2 h2 {
        margin-bottom: 40px;
    }
    .sec-4 .obj-1 {
        width: 172px;
        top: 40px;
        right: -92px;
    }
    .sec-4 .obj-2 {
        width: 172px;
        top: 1000px;
        left: -92px;
    }
    .sec-4 .obj-3 {
        bottom: -78px;
        right: -170px;
        width: 277px;
    }
    .sec-4 .tab-cnt-box-1 .box .coming-soon {
        padding: 20px;
        gap: 24px;
        border-radius: 10px 20px 20px 20px;
    }
    .sec-4 .tab-cnt-box-1 .box .coming-soon h3 {
        font-size: 18px;
    }
    .sec-4 .tab-cnt-box-1 .box .coming-soon p {
        font-size: 15px;
    }
}


@media (max-width: 560px) {
    .sec-4 .obj-1 {
        width: 114px;
        top: 30px;
        right: -68px;
    }
    .sec-4 .obj-2 {
        width: 112px;
        left: -64px;
    }
}


/********** sec-5 **********/
.sec-5 .title-box p {
    color: #fff;
}
.sec-5 .box {
    width: 100%;
    max-width: 800px;
    height: 580px;
    border-radius: 20px 40px 40px;
    border: 1px solid #CCCCCC;
    overflow: hidden;
    box-shadow: inset -1px -2px 9px 0px #fff, 0px 0px 8px 4px rgba(255, 223, 220, 0.13);
}
.sec-5 .box::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 20px 40px 40px;
    filter: blur(40px);
    background: linear-gradient(150deg, rgba(255,255,255,0.3) 0%, rgba(248,250,255,0.8) 33%, rgba(245,248,255,0.9) 58%, rgba(248,251,255,0.65) 73%, rgba(255,255,255,0.2) 100%);
}
.sec-5 .box h2 {
    font-size: 32px;
    font-weight: 600;
    z-index: 2;
}
.sec-5 .box h2 span {
    font-size: 40px;
    color: #D71819;
    font-weight: 700;
}
.sec-5 .box .line {
    background-color: #000;
    height: 3px;
    width: 56px;
    z-index: 2;
}
.sec-5 .box ul {
    z-index: 2;
}
.sec-5 .box ul li {
    font-size: 24px;
    line-height: 1.4;
}
.sec-5 .box ul p {
    font-size: 20px;
    line-height: 1.4;
}
.sec-5 .obj-1 {
    left: 0;
    top: 100px;
}
.sec-5 .obj-1 img {
    animation-name: fadeInOut;
    animation-duration: 3s;
    /* animation-delay: 0.5s; */
    animation-iteration-count: infinite;
}

/* 반응형 */
@media (max-width: 1280px) {
    .sec-5 .box {
        max-width: 600px;
        height: 486px;
    }
    .sec-5 .box h2 {
        font-size: 24px;
    }
    .sec-5 .box h2 span {
        font-size: 32px;
    }
    .sec-5 .box ul li {
        font-size: 20px;
    }
    .sec-5 .box ul p {
        font-size: 18px;
    }
    .sec-5 .obj-1 {
        width: 240px;
        left: -60px;
        top: 80px;
    }
}

@media (max-width: 767px) {
    .sec-5 .box {
        max-width: 313px;
        height: 472px;
        border-radius: 10px 20px 20px;
        gap: 32px;
    }
    .sec-5 .box .line {
        width: 26px;
    }
    .sec-5 .box h2 {
        font-size: 18px;
    }
    .sec-5 .box h2 span {
        font-size: 20px;
    }
    .sec-5 .box ul {
        gap: 20px;
    }
    .sec-5 .box ul li {
        font-size: 17px;
    }
    .sec-5 .box ul p {
        font-size: 15px;
    }
    .sec-5 .box .m-br {
        display: block;
    }
    .sec-5 .obj-1 {
        width: 112px;
        left: -30px;
        top: 60px;
    }
}


/********** sec-6 **********/
.sec-6 {
    background: url(../img/sec-bg-3.svg)no-repeat center/cover;
}
.sec-6 .box-wrap .box {
    width: 100%;
    overflow: hidden;
    border-radius: 20px;
    box-shadow: 0 30px 50px rgba(0, 0, 0, 0.04);
}
.sec-6 .box-wrap .box h2 {
    color: #fff;
    padding: 16px 0;
    font-size: 22px;
    font-weight: 600;
    text-align: center;
}
.sec-6 .box-wrap .box .cont-box {
    gap: 4px;
}
.sec-6 .box-wrap .box .cont {
    background: linear-gradient(90deg, rgba(255,255,255,0.2) 0%, rgba(255,255,255,1) 20%, rgba(255,255,255,1) 80%, rgba(255,255,255,0.2) 100%);
    border: 1px solid #fff;
    border-radius: 0 0 20px 20px;
    height: 160px;
    cursor: pointer;
}
.sec-6 .box-wrap .box .cont.border {
    border-radius: 0;
}
.sec-6 .box-wrap .box .cont h3 {
    font-size: 28px;
    font-weight: 600;
}
.sec-6 .box-wrap .box .cont p {
    font-size: 20px;
}
.sec-6 .i-map {
    background: url(../img/ico_map-pin.svg)no-repeat center/cover;
    width: 20px;
    height: 20px;
}
.sec-6 .i-time {
    background: url(../img/ico_clock.svg)no-repeat center/cover;
    width: 20px;
    height: 20px;
}
.sec-6 .obj-1 {
    width: 224px;
    top: 130px;
    left: 130px;    
}
.sec-6 .obj-1 img {
    animation-name: moving_1;
    animation-duration: 3s;
    /* animation-delay: 0.5s; */
    animation-iteration-count: infinite;
}

/* 반응형 */
@media (max-width: 1280px) {
    .sec-6 .con > div.flex {
        flex-direction: column;
        gap: 16px;
        max-width: 580px;
    }
    .sec-6 .box-wrap {
        gap: 16px;
    }
    .sec-6 .box-wrap .box h2 {
        padding: 13px 0;
    }
    .sec-6 .obj-1 {
        width: 130px;
        left: 40px;
        top: 76px;
    }
}

@media (max-width: 767px) {
    .sec-6 .title-box p br {
        display: block;
    }
    .sec-6 .con > div.flex {
        gap: 8px;
        max-width: 300px;
    }
    .sec-6 .box-wrap .box {
        border-radius: 10px;
    }
    .sec-6 .box-wrap .box .cont-box {
        gap: 2px;
    }
    .sec-6 .box-wrap .box .cont {
        border-radius: 0 0 10px 10px;
        height: 76px;
        gap: 12px;
    }
    .sec-6 .box-wrap {
        gap: 8px;
    }
    .sec-6 .box-wrap .box h2 {
        padding: 10px 0;
        font-size: 16px;
    }
    .sec-6 .box-wrap .box .cont .info-box {
        gap: 12px;
    }
    .sec-6 .box-wrap .box .cont h3,
    .sec-6 .box-wrap .box .cont h3 span {
        font-size: 16px;
    }
    .sec-6 .box-wrap .box .cont p {
        font-size: 13px;
        gap: 3px;
    }
    .sec-6 .box-wrap .box .cont p i {
        width: 12px;
        height: 12px;
    }
    .sec-6 .obj-1 {
        width: 62px;
        left: 20px;
        top: 30px;
    }
}


/********** sec-7 **********/
.sec-7 .title-box p {
    color: #fff;
}
.sec-7 .box {
    width: 100%;
    border-radius: 20px 40px 40px;
    border: 1px solid #CCCCCC;
    overflow: hidden;
    box-shadow: inset -1px -2px 9px 0px #fff, 0px 0px 8px 4px rgba(255, 223, 220, 0.13);
    padding: 20px 30px;
    height: 540px;
    cursor: pointer;
}
.sec-7 .box::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 20px 40px 40px;
    filter: blur(40px);
    background: linear-gradient(150deg, rgba(255,255,255,0.3) 0%, rgba(248,250,255,0.8) 33%, rgba(245,248,255,0.9) 58%, rgba(248,251,255,0.65) 73%, rgba(255,255,255,0.2) 100%);
}
.sec-7 .box span {
    border-radius: 6px;
    background: #fff;
    border: 1px solid #DA4643;
    color: #DA4643;
    padding: 10px;
    font-size: 24px;
    font-weight: 700;
    position: relative;
    display: inline-block;
}
.sec-7 .box .gift-img {
    width: 314px;
    height: 465px;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
.sec-7 .box .gift-img > .img-box {
    width: 100%;
}
.sec-7 .box .gift-img .img-1 {
    bottom: 0;
}
.sec-7 #event_btn_1 .gift-img .img-box {
    animation-name: moving_1-2;
    animation-duration: 3s;
    animation-iteration-count: infinite;
}
.sec-7 #event_btn_2 .gift-img .img-box {
    animation-name: moving_1-2;
    animation-duration: 3s;
    animation-iteration-count: infinite;
    animation-delay: 0.3s;
}
.sec-7 #event_btn_2 .gift-img .img-2 img {
    transform: rotate(20deg);
}
.sec-7 #event_btn_1 .gift-img .img-2 {
    left: -20px;
    top: 20px;
}
.sec-7 #event_btn_2 .gift-img .img-2 {
    right: -10px;
    top: 20px;
}
.sec-7 .obj-1 {
    width: 490px;
    top: 60px;
    right: 0;
}
.sec-7 .obj-1 img {
    animation-name: moving_1;
    animation-duration: 3s;
    /* animation-delay: 0.5s; */
    animation-iteration-count: infinite;
}

/* 반응형 */
@media (max-width: 1280px) {
    .sec-7 .box-wrap {
        gap: 24px;
    }
    .sec-7 .box {
        padding: 16px 24px;
        border-radius: 12px 22px 22px 22px;
        height: 306px;
    }
    .sec-7 .box span {
        border-radius: 4px;
        padding: 8px;
        font-size: 16px;
    }
    .sec-7 .box .gift-img {
        width: 172px;
        height: 254px;
    }
    .sec-7 .obj-1 {
        width: 310px;
        top: 16px;
        right: -60px;
    }
    .sec-7 #event_btn_2 .gift-img .img-2 {
        right: -10px;
        top: 10px;
    }
    .sec-7 #event_btn_1 .gift-img .img-2 {
        left: -10px;
        top: 10px;
    }
}

@media (max-width: 767px) {
    .sec-7 .title-box p br {
        display: block;
    }
    .sec-7 .box-wrap {
        gap: 16px;
    }
    .sec-7 .box {
        padding: 10px;
        border-radius: 5px 10px 10px 10px;
        height: 160px;
    }
    .sec-7 .box span {
        border-radius: 2px;
        padding: 4px 8px;
        font-size: 12px;
    }
    .sec-7 .box .gift-img {
        width: 80px;
        height: 100px;
    }
    .sec-7 .obj-1 {
        width: 145px;
        top: 9px;
        right: -27px;
    }
    .sec-7 #event_btn_1 .gift-img .img-2 {
        left: -5px;
        top: -10px;
    }
    .sec-7 #event_btn_2 .gift-img .img-2 {
        right: -5px;
        top: -10px;
    }
}


/********** sec-8 **********/
.sec-8 {
    background: url(../img/sec-bg-1.svg)no-repeat center/cover;
}
.sec-8 .con {
    max-width: 1300px;
}
.swiper-cont {
    width: 100%;
    padding: 0 60px
}
.swiper-1, .swiper-2 {
    width: 100%;
    overflow: hidden;
}
.swiper-button-next:after, .swiper-button-prev:after {
    display: none;
}
.swiper-button-prev {
    background: url(../img/chevron-left.svg)no-repeat center/cover;
    width: 48px;
    height: 48px;
}
.swiper-button-next {
    background: url(../img/chevron-right.svg)no-repeat center/cover;
    width: 48px;
    height: 48px;
}
.swiper-1 .swiper-slide {
    height: 180px;
    cursor: default;
    transition: .3s;
}
.swiper-1 .swiper-slide > div {
    width: 100%;
    height: 100%;
    border-radius: 12px 20px 20px;
}
.swiper-1 .swiper-slide .slide-box {
    background: linear-gradient(150deg, rgba(255,255,255,0.3) 0%, rgba(248,250,255,0.8) 33%, rgba(245,248,255,0.9) 58%, rgba(248,251,255,0.65) 73%, rgba(255,255,255,0.2) 100%);
    box-shadow: inset -3px -3px 7px rgba(255, 255, 255, 0.25),
    inset 3px 3px 7px rgba(255, 255, 255, 0.1);
    gap: 20px;
    display: flex;
    justify-content: flex-start;
    padding-top: 36px;
    opacity: 1;
}
.swiper-1 .swiper-slide .slide-box h2 {
    font-size: 26px;
    line-height: 1.4;
}
.swiper-1 .swiper-slide .slide-box p {
    font-size: 20px;
    line-height: 1.4;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 52px;
}
.swiper-1 .swiper-slide .slide-hover-box {
    line-height: 1.4;
    font-size: 22px;
    font-weight: 600;
    opacity: 0;
    transition: .3s;
    z-index: 2;
    display: flex;
}
.swiper-1 .swiper-slide:hover .slide-hover-box {
    opacity: 1;
}
.swiper-1 .swiper-slide .hover-bg {
    background: linear-gradient(to right, #E47552, #DA4643);
    width: 0px;
    height: 0px;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    opacity: 0;
    transition: .3s;
}
.swiper-1 .swiper-slide:hover .hover-bg {
    width: 100%;
    height: 100%;
    opacity: 1;
}
.sec-8 .q-list {
    margin-top: 180px;
    gap: 48px;
}
.sec-8 .q-list a {
    border: 1px solid #DA4643;
    border-radius: 12px 12px 12px 6px;
    color: #DA4643;
    padding: 0 48px;
    height: 80px;
}
.sec-8 .q-list a:hover{
    background: #fff;
}
.sec-8 .obj-1 {
    width: 420px;
    top: -210px;
    left: 100px;
}
.sec-8 .obj-1 img {
    transform: rotate(-45deg);
}
.sec-8 .obj-2 {
    bottom: -260px;
    right: -560px;
    width: 916px;
}

/* 반응형 */
@media (max-width: 1280px) {
    .swiper-1 .swiper-slide {
        height: 160px;
    }
    .swiper-1 .swiper-slide .slide-box {
        padding-top: 28px;
    }
    .swiper-1 .swiper-slide .slide-box h2 {
        font-size: 22px;
    }
    .swiper-1 .swiper-slide .slide-box p {
        font-size: 16px;
    }
    .swiper-1 .swiper-slide .slide-hover-box {
        font-size: 18px;
    }
    .sec-8 .q-list {
        margin-top: 140px;
    }
    .sec-8 .q-list p {
        font-size: 26px;
    }
    .sec-8 .q-list a {
        font-size: 22px;
    }
    .sec-8 .obj-1 {
        width: 260px;
        top: -167px;
        left: -10px;
    }
    .sec-8 .obj-2 {
        width: 503px;
        bottom: -188px;
        right: -324px;
    }
}

@media (max-width: 767px) {
    .title-box p br {
        display: block;
    }
    .swiper-cont {
        padding: 0;
    }
    .swiper-button-prev,
    .swiper-button-next {
        width: 32px;
        height: 32px;
        transform: translateY(20%);
    }
    .swiper-1 .swiper-slide {
        height: 132px;
        display: flex;
        justify-content: center;
    }
    .swiper-1 .swiper-slide .slide-box {
        width: 88%;
        padding-top: 24px;
        gap: 16px;
    }
    .swiper-1 .swiper-slide .slide-box h2 {
        font-size: 18px;
    }
    .swiper-1 .swiper-slide .slide-box p {
        font-size: 14px;
    }
    .swiper-1 .swiper-slide .slide-hover-box {
        font-size: 16px;
        width: 88%;
    }
    .swiper-1 .swiper-slide:hover .hover-bg {
        width: 88%;
    }
    .sec-8 .q-list {
        margin-top: 60px;
        gap: 18px;
    }
    .sec-8 .q-list p {
        font-size: 18px;
    }
    .sec-8 .q-list a {
        font-size: 16px;
        border: 6px 6px 6px 3px;
        padding: 0 22px;
        height: 38px;
        gap: 10px;
    }
    .sec-8 .q-list a img {
        width: 20px;
        height: 20px;
    }
    .sec-8 .obj-1 {
        width: 147px;
        top: -5px;
        left: -84px;
    }
    .sec-8 .obj-2 {
        width: 236px;
        bottom: -87px;
        right: -152px;
    }
}
@media (max-width: 560px) {
    .sec-8 .obj-1 {
        width: 112px;
        top: -5px;
        left: -71px;
    }
}

/********** sec-9 **********/
.sec-9 {
    background: url(../img/sec-bg-1.svg)no-repeat center/cover;
}
.more-about {
    gap: 100px;
    margin-top: 260px;
}
.more-about .sns-box {
    grid-template-columns: 1fr 1fr 1fr 1fr;
}
.sec-9 .obj-1 {
    width: 476px;
    top: 85px;
    left: -245px;
}
.sec-9 .obj-2 {
    width: 342px;
    top: 680px;
    right: 70px;
}

/* 복지영역 슬라이드 */
.welfare-box {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 252px;
    border-radius: 999px;
    background: var(--box_GR, linear-gradient(137deg, rgba(255, 255, 255, 0.30) 11.08%, rgba(248, 250, 255, 0.80) 39.07%, rgba(245, 248, 255, 0.90) 60.7%, rgba(255, 255, 255, 0.20) 95.9%));
    /* inner */
    box-shadow: -3px -3px 7px 0px rgba(255, 255, 255, 0.25) inset, 3px 3px 7px 0px rgba(255, 255, 255, 0.10) inset;
}
.welfare-box .welfare-box-in {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 24px;
}
.welfare-box .welfare-box-in img {
    height: 100px;
}
.welfare-box .welfare-box-in span {
    font-size: 18px;
    text-align: center;
    line-height: 1.3;
}

/* 반응형 */
@media (max-width: 1280px) {
    .welfare-box {
        height: 26vw; 
    }
    .more-about {
        margin-top: 140px;
        gap: 68px;
    }
    .more-about h2 {
        font-size: 32px;
    }
    .more-about .sns-box {
        grid-template-columns: 1fr 1fr;
    }
    .sec-9 .obj-1 {
        width: 292px;
        top: 85px;
        left: -153px;
    }
    .sec-9 .obj-2 {
        width: 183px;
        top: 496px;
        right: 20px;
    }
}
@media (max-width: 768px) {
    .welfare-box {
        height: 24vw; 
    }
    .welfare-box .welfare-box-in img {
        height: 60px
    }
    .welfare-box .welfare-box-in span {
        font-size: 16px;
    }
}
@media (max-width: 767px) {
    .more-about {
        margin-top: 60px;
        gap: 40px;
    }
    .more-about h2 {
        font-size: 20px;
    }
    .more-about .sns-box {
        gap: 10px;
    }
    .sec-9 .obj-1 {
        width: 138px;
        top: 25px;
        left: -72px;
    }
    .sec-9 .obj-2 {
        width: 98px;
        top: 285px;
        right: -26px;
    }

    .welfare-box {
        width: 240px;
        height: 240px;
    }
    .welfare-box .welfare-box-in {
        gap: 20px;
    }


}

@media (max-width: 640px) {
    .welfare-box {
        height: 200px;
    }
    .welfare-box .welfare-box-in {
        gap: 16px;
    }
    .welfare-box .welfare-box-in img {
        height: 80px
    }
    .welfare-box .welfare-box-in span {
        font-size: 15px;
    }
}
@media (max-width: 490px) {
    .welfare-box {
        height: 221px;
    }
}
@media (max-width: 420px) {
    .welfare-box {
        height: 160px;
    }
    .welfare-box .welfare-box-in img {
        height: 48px;
    }
    .welfare-box .welfare-box-in {
        gap: 12px;
    }
}
/********** footer **********/
footer {
    padding: 24px;
    background-color: #000;
}
footer img {
    width: 102px;
}
/* 반응형 */
@media (max-width: 1280px) {
    footer {
        padding: 18px;
    }
    footer img {
        width: 78px;
    }
}


/********** 채용 박람회 모달 **********/
.modal-area {
    background: rgb(0, 0, 0, 50%);
    width: 100%;
    height: 100%;
    display: none;
    word-break: keep-all;
    z-index: 500;
    top: 0;
    left: 0;
}
.modal-area.active {
    display: block;
}
.modal-area .modal {
    display: none;
}
.modal-area .modal.active {
    display: block;
}
.modal-area .close-btn {
    top: 20px;
    right: 20px;
    cursor: pointer;
    z-index: 10;
}
.modal-area .close-btn:hover {
    content: url(../img/ico_close-hover.svg);
}
.modal-area .modal {
    padding: 48px 40px;
    border-radius: 40px 24px 40px 40px;
    z-index: 1;
    /* height: 90vh; */
}
.modal-area .modal::before {
    content: '';
    position: fixed;
    border-radius: 40px 24px 40px 40px;
    width: calc(100% - 6px);
    height: calc(100% - 6px);
    top: 0;
    left: 0;
    z-index: -1;
    border: 3px solid transparent;
    background-image: linear-gradient(#fff, #fff),linear-gradient(#CF3C4D, #EC6A5B);
    background-origin: border-box;
    background-clip: content-box, border-box;
}
.fair-modal {
    width: 100%;
    max-width: 410px;
}
.fair-modal h2 {
    padding-bottom: 8px;
    border-bottom: 1px solid #D71819;
}
.fair-modal .tag {
    gap: 8px;
    margin-top: 28px;
}
.fair-modal .tag span {
    border-radius: 30px;
    padding: 6px 16px;
    border: 1px solid #5A5A5A;
    font-size: 18px;
    line-height: 1.4;
}
.modal-area .event-modal {
    overflow: hidden;
    padding-top: 130px;
    width: 100%;
    max-width: 580px;
}

/* event-modal */
.event-modal h2 {
    top: 0;
    left: 0;
    height: 90px;
}
.event-modal h2 span {
    color: #EBE7B7;
}
.event-modal .cont {
    gap: 40px;
}
.event-modal .cont .img-box {
    max-width: 440px;
}
.event-modal .cont p {
    font-size: 20px;
    line-height: 1.4;
}
.event-modal .cont p span {
    color: #D71819;
}
/* 반응형 */
@media (max-width: 767px) {
    .modal-area .event-modal {
        padding: 40px 10px;
        padding-top: 100px;
    }
    .event-modal h2 {
        height: 68px;
        font-size: 20px;
    }
    .event-modal .cont {
        gap: 20px;
    }
    .event-modal .cont p {
        font-size: 16px;
        line-height: 1.6;
    }
}

/* q-modal */
.modal-area .q-modal {
    width: 100%;
    max-width: 600px;
}
.q-modal h2 {
    color: #D71819;
}
.q-modal ul {
    margin: 32px 0;
    gap: 12px;
}
.q-modal ul li {
    font-size: 18px;
    line-height: 1.4;
    display: flex;
    gap: 8px;
    padding-bottom: 12px;
    border-bottom: 1px solid #eee;
}
.q-modal ul li span {
    color: #D71819;
    font-size: 18px;
    line-height: 1.4;
}
.q-modal p {
    color: #CF3C4D;
    font-size: 18px;
    line-height: 1.6;
    padding: 10px;
    border-radius: 40px;
    background-color: #FEF3F5;
}
/* 반응형 */
@media (max-width: 767px) {
    .modal-area .q-modal {
        height: 100%;
        padding: 48px 20px;
    }
}

/* 애니메이션 추가 */
@keyframes moving_1 {
    50% {
        transform: translateY(15%);
    }
}
@keyframes moving_1-1 {
    50% {
        transform: translateY(10%) rotate(80deg);
    }
}
@keyframes moving_1-2 {
    50% {
        transform: translateY(10%);
    }
}
@keyframes moving_2 {
    0% {
        transform: translateX(-30%);
    }
    50% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-30%);
    }
}
@keyframes zoomInOut {
    0% {
        opacity: 0;
        transform: scale(0.5);
    }
    50% {
        transform: scale(1.2);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}
.zoomInOut {
    animation-name: zoomInOut;
    animation-timing-function: cubic-bezier(0.32, 0.32, 0.27, 1.5);
}
@keyframes fadeInOut {
    0% {
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}
.fadeInOut {
    animation-name: fadeInOut;
}




/* 직무 리스트 */
.jd-wrap {
    width: 1200px;
}
.jd-wrap .w200px {
    width: 220px;
}
.jd-head { 
    display: flex;
    justify-content: space-between;
    gap: 8px;
    padding: 16px 20px;
    background: #000;
    border-radius: 8px;
    box-sizing: border-box;
    margin-bottom: 6px;
}
.jd-head span { color: #fff;}
.jd-head span:nth-child(1) { width: 300px }
.jd-head span:nth-child(2) { width: 100%;}
.jd-head span:nth-child(3) { width: 280px}
.jd-head span:nth-child(4) { width: 280px}
.jd-head span:nth-child(5) { width: 280px}

.jd-list-wrap {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.jd-list-box {
    font-size: 20px;
    text-align: center;
    border-radius: 8px;
    background: linear-gradient(137deg, rgba(255, 255, 255, 0.30) 11.08%, rgba(248, 250, 255, 0.80) 39.07%, rgba(245, 248, 255, 0.90) 60.7%, rgba(255, 255, 255, 0.20) 95.9%);
    width: 100%;
    padding: 12px 20px;
    gap: 8px;
    line-height: 1.4;
}
.jd-list-box .jd-company {
    color: #D71819;
    font-weight: 700;
}
.jd-list-box .jd-cont {
    color: #000;
}
.jd-list-box .jd-cont .jd-tit  {
    display: none;
}
.jd-list-box .jd-cont .jd-subtext {
    word-break: keep-all;
    line-height: 1.4;
}
.jd-more a {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
    
    width: 136px;
    padding: 12px 8px;
    border-radius: 12px 12px 12px 6px;
    background: linear-gradient(270deg, #EC6A5B 16%, #CF3C4D 91%);
    color: #fff;
}
.jd-more a:hover {
    background: #DA4643;

}

@media (max-width: 1280px){
    .jd-wrap {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        gap: 20px;
    }
    .jd-head {display: none;}
    /* .jd-list-wrap{
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    } */
    .jd-list-box {
        flex-direction: column;
        align-items: start;
    }
    .jd-list-box .jd-company {
        width: 100%;
        text-align: left;
        font-size: 20px;
    }
    .jd-list-box {
        padding: 20px;
    }
    .jd-list-box .jd-cont {
        width: 100%;
        font-size: 18px;
        flex-direction: column;
        align-items: start;
        gap: 8px;
    }
    .jd-list-box .jd-cont .jd-cont-in {
        width: 100%;
        display: flex;
        align-items: flex-start;
        gap: 8px
    }
    .jd-list-box .jd-company {
        margin-bottom: 6px;
    }
    .jd-list-box .jd-cont .jd-tit {
        width: 80px;
        display: block!important;
        background:  #FEF3F5;
        padding: 4px 8px;
        display: flex;
        border-radius: 999px;
        justify-content: center;
        align-items: center;
        gap: 10px;
        color: #CF3C4D;
    }
    .jd-list-box .jd-cont .jd-subtext {
        width: 100%;
        text-align: left;
        margin-top: 2px;
    }
    .jd-more {
        width: 100%;
    }
    .jd-more a {
        width: 100%;
        border: 1px solid #CF3C4D;
        background: transparent;
        color: #CF3C4D;
        font-size: 16px;
    }
    .jd-more a:hover {
        color: #fff;
    }
}

@media (max-width: 768px){
    .jd-list-wrap{
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        gap: 20px; /* 간격 조절 */
    }
    .jd-list-box .jd-company {
        font-size: 18px;
    }
    .jd-list-box {
        padding: 20px;
    }
    .jd-list-box .jd-cont {
        font-size: 16px;
    }
}
@media (max-width: 480px){
    .jd-list-box .jd-cont {
        gap: 6px
    }
    .jd-list-box .jd-company {
        font-size: 17px;
    }
    .jd-list-box .jd-cont {
        font-size: 15px;
    }
}


/* 250228 im전형 추가 */
.highlight-marker {
    background-color: rgba(255, 255, 0, 0.6);
    padding: 2px 4px;
    border-radius: 4px;
}

.im-text-box-1 {
    border-radius: 20px 40px 40px 40px;
    border: 1px solid #CCC;
    background: var(--box_GR, linear-gradient(137deg, rgba(255, 255, 255, 0.30) 11.08%, rgba(248, 250, 255, 0.80) 39.07%, rgba(245, 248, 255, 0.90) 60.7%, rgba(255, 255, 255, 0.20) 95.9%));
    box-shadow: -1px -2px 9px 0px #FFF inset, 0px 0px 8px 4px rgba(255, 223, 220, 0.13);
    backdrop-filter: blur(20px);
    padding:60px 80px;
    box-sizing: border-box;
}
.im-text-box-1 p { 
    font-size: 2.4rem;
}
.im-text-box-1 span {
    margin-top: auto;
    font-size: 2.0rem;

}
.im-text-box-1 span.im-desc {
    margin-top: 20px!important;
    text-align: center;
    color: #222!important;
    line-height: 1.6 !important;
    word-break: keep-all;
}
.im-text-box-1 span.im-point{
    color: #222!important
}

.im-text-box-2 {
    margin: 0 auto;
    width: 100%;
    max-width: 800px;
    background: rgb(255, 255, 255, 0.3);
    padding: 40px;
    border-radius: 20px 40px 40px 40px;
    text-align: center;
    gap: 20px;
    margin-top: -7vw;
    margin-bottom: 180px;
    box-sizing: border-box;
}
.im-text-box-2 .im-box-in {
    align-items: flex-start;
    gap: 20px;
}
.im-text-box-2 .im-box-in p{
    font-size: 18px;
}
.im-text-box-2 .im-box-in .im-desc-2 {
    gap: 20px;
}
.im-text-box-2 .im-box-in .im-desc-2 .im-sub-desc{
    color: 222;
    font-size: 18px;
    text-align: center;
    line-height: 1.4;
}

@media (max-width: 1280px) {
    .im-text-box-1 {
       padding: 40px 60px
    }
    .im-text-box-1 p { 
        font-size: 22px
    }
    .im-text-box-1 span {
        font-size: 18px
    }
    .im-text-box-2 {
        margin-top: -8vw;
        padding: 24px;
        margin-bottom: 160px;
    }
    .im-text-box-2 .im-box-in  {
        flex-direction: column;
        align-items: center;
        gap: 12px;
    }
    .im-text-box-2 .im-box-in p{
        font-size: 19px;
    }
    .im-text-box-1 br.mb-ver {
        display: block;
    } 
    .im-text-box-2 .im-box-in .im-desc-2 {
        gap: 0px;
        flex-direction: column;
        justify-content: center;
    }
    .im-text-box-2 .im-box-in .im-desc-2 .im-sub-desc {
        text-align: center;
        font-size: 17px;

    }
}

@media (max-width: 768px) {
    
    .im-text-box-1 {
        padding: 24px 20px;
    }
    .im-text-box-2 {
        width: 80%;
        padding: 20px;
        margin-bottom: 88px;
        margin-top: -5vw;
    }
    .im-text-box-2 .im-box-in p{
        font-size: 17px;
    }
    .im-text-box-2 .im-box-in .im-desc-2 .im-sub-desc {
        font-size: 15px;
    }
}

@media (max-width: 600px) {
}
