.bg>div {
    position: fixed;
    width: 306px;
    height: 298px;
    border-radius: 50%;
    animation: mainVb_word1 both linear infinite 4s
}

.bg>div.bg1 {
    top: 100px;
    left: 8%;
    background: #ba49ff;
    opacity: .5;
    filter: blur(100px)
}

.bg>div.bg2 {
    top: 45%;
    right: 15%;
    background: #ba49ff;
    opacity: .5;
    filter: blur(100px)
}

@keyframes mainVb_word1 {
    0% {
        transform: translate(0%,0%)
    }

    20% {
        transform: translate(-10%,4%)
    }

    50% {
        transform: translate(3%,5%)
    }

    70% {
        transform: translate(5%,-5%)
    }

    100% {
        transform: translate(0%,0%)
    }
}

.main {
    transition: all .3s
}

.visual {
    position: relative;
    padding: 205px 0 120px;
    overflow: hidden;
    max-width: 1320px;
    margin: 0 auto;
    box-sizing: border-box;
    background: url("../images/Home1_headerbg_1920.png")no-repeat 50% 50%/cover
}

.visual .inner {
    position: static
}

.visual .box {
    position: relative;
    z-index: 1
}

.visual .box>span {
    display: inline-block;
    font-size: 22px;
    color: #e26738;
    font-weight: 500
}

.visual .box h2 {
    color: #000;
    font-size: 40px;
    font-weight: 900;
    line-height: 1.1;
    margin: 0;
    text-align: center
}

.visual .box h2 strong {
    font-weight: 900
}

.visual .swiper-slide .box {
    height: 590px
}

.visual .slide01 .box {
    align-items: center
}

.visual .slide01 .box h2 {
    font-size: 64px;
    text-align: left
}

.visual .slide02 .box {
    background: url("../images/main_img2.svg")no-repeat 50% calc(100% - -4px)/auto 470px
}

.visual .txt {
    color: #000;
    text-align: center;
    border-radius: 30px;
    background: rgb(186 73 255/5%);
    backdrop-filter: blur(2px);
    max-width: 1320px;
    font-size: 24px;
    padding: 40px 20px;
    margin: 0 auto 0;
    box-sizing: border-box
}

.visual .bn_img {
    position: relative;
    height: 90%
}

.visual .bn_img div {
    width: 100%;
    height: 100%;
    text-align: center
}

.visual .bn_img img {
    width: auto;
    max-width: none;
    height: 100%
}

@keyframes MoveUpDown {
    0%,100% {
        transform: translateY(5px)
    }

    50% {
        transform: translateY(0px)
    }
}

@keyframes ripple {
    0% {
        transform: scale(.8)
    }

    50% {
        transform: scale(1.2)
    }

    100% {
        transform: scale(.8)
    }
}

.swiper-button-prev,.swiper-button-next {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    margin-top: 20px
}

.swiper-button-prev {
    left: 80px;
    background: rgba(0,0,0,0.8) url("../images/slide-prev.svg")no-repeat 50% 50%
}

.swiper-button-next {
    right: 80px;
    background: rgba(0,0,0,0.8) url("../images/slide-next.svg")no-repeat 50% 50%
}

h3.tit {
    text-align: center;
    font-size: 40px;
    color: #ba49ff;
    margin-bottom: 50px;
    font-weight: 900
}

.sec00 {
    background: #faf2ff;
    padding: 120px 0
}

.sec00 .grid4 {
    gap: 30px
}

.sec00 .grid4>div {
    flex: 1;
    border-radius: 30px;
    background: #ba49ff;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    text-align: center;
    padding: 50px 20px;
    box-sizing: border-box;
    transition: all .5s
}

.sec00 .grid4>div:hover {
    box-shadow: 0 0 30px 0 rgba(186,73,255,.4)
}

.sec00 .grid4>div .icon {
    width: 80px;
    margin: 0 auto 30px
}

.sec00 .grid4>div .icon img {
    width: 100%
}

.sec00 .grid4>div h4 {
    font-size: 32px;
    font-weight: 900;
    margin-bottom: 30px
}

.sec00 .grid4>div p {
    font-size: 18px;
    line-height: 1.25;
    letter-spacing: -.72px
}

.sec01 {
    padding: 100px 0;
    background: #fff
}

.sec01 .grid {
    gap: 30px;
    margin-top: -30px
}

.sec01 .grid .popular-container {
    padding-top: 50px
}

.sec01 .grid .popular-wrapper {
    transition-timing-function: linear
}

.sec01 .grid .popular-slide {
	width: calc(25% - 53px);
	display: inline-block;
	margin: 0 24px 25px;
}

.sec01 .grid .popular-slide .item {
    position: relative;
    border-radius: 30px;
    background: #faf2ff;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: 15px
}

.sec01 .grid .popular-slide .item .thumb {
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translate(-50%);
    -webkit-transform: translate(-50%);
    -ms-transform: translate(-50%);
    -moz-transform: translate(-50%);
    -o-transform: translate(-50%);
    -khtml-transform: translate(-50%);
    width: calc(100% - 40px);
    transition: all .2s ease-in-out
}

.sec01 .grid .popular-slide .item .thumb img {
    width: 100%;
    transition: all .2s ease-in-out;
    border-radius: 6px
}

.sec01 .grid .popular-slide .item:hover .thumb {
    top: -40px
}

.sec01 .grid .popular-slide .item:hover .thumb img {
    box-shadow: 0 19px 38px rgba(0,0,0,.3),0 15px 12px rgba(0,0,0,.22)
}

.sec01 .grid .popular-slide .item .info {
    padding-top: 92%
}

.sec01 .grid .popular-slide .item .info .name {
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    padding: 5px;
    margin-bottom: 16px;
    position: relative;
    transition: all .2s ease-in-out
}

.sec01 .grid .popular-slide .item .info .name>* {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    -moz-transform: translate(-50%,-50%);
    -ms-transform: translate(-50%,-50%);
    -o-transform: translate(-50%,-50%);
    -khtml-transform: translate(-50%,-50%)
}

.sec01 .grid .popular-slide .item .info .name>span {
    position: static;
    width: auto;
    padding: 12px 20px;
    background: #ba49ff;
    color: #fff;
    font-size: 24px;
    border-radius: 50px;
    box-shadow: 0 20px 16px 0 rgba(0,0,0,.3);
    transition: all .3s;
    box-sizing: border-box
}

.sec01 .grid .popular-slide .item:hover .info .name>span {
    background: #ba49ff
}

.sec01 .grid .popular-slide .item:hover .info .name {
    margin-top: 0
}

.sec01 .grid .popular-slide .item .info .description-prod p {
    text-align: center;
    margin-bottom: 16px
}

.sec01 .grid .popular-slide .item:hover .info .description-prod {
    text-align: center;
    width: 100%;
    margin-bottom: 16px
}

.sec01 .grid .popular-slide .item .card-footer {
    padding: 16px 0;
    border-top: 1px solid #fff;
    text-align: center
}

.sec01 .grid .popular-slide .item .price {
    font-size: 18px;
    font-weight: 700
}

.sec01 .taC a {
    display: block;
    width: 130px;
    height: 45px;
    line-height: 45px;
    font-size: 18px;
    border: 1px solid #ba49ff;
    border-radius: 50px;
    text-align: center;
    margin: 40px auto 0;
    box-sizing: border-box;
    color: #ba49ff;
}

.sec02 {
    padding: 100px 0 120px;
    background: #faf2ff
}

.sec02 .inner {
    position: static
}

.sec02 .tab {
    margin-bottom: 48px
}

.sec02 .tab .swiper-container {
    padding: 20px 0;
    height: 98px;
    box-sizing: border-box
}

.sec02 .tab .swiper-wrapper {
    justify-content: center;
    align-items: center
}

.sec02 .tab button {
    width: auto;
    font-size: 24px;
    color: rgba(0,0,0,.5);
    margin-right: 20px;
    border-radius: 100px;
    padding: 10px 30px;
    transition: all .3s
}

.sec02 .tab.click_change button {
    color: rgb(255,255,255,50%)!important;
}

.sec02 .tab.click_change .active {
    background: rgb(0 0 0/0%)!important;
    color: #ba49ff!important
}

.sec02 .tab button.active {
    background: 0 0;
    font-size: 32px;
    color: #ba49ff;
    font-weight: 900;
    box-shadow: 0 0 20px 0 #ba49ff
}

.sec02 .slide {
    margin-top: -20px
}

.sec02 .slide .swiper-container {
    padding: 20px 0
}

.sec02 .box {
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-perspective: 1000px;
    perspective: 1000px
}

.sec02 .front,.sec02 .back {
    background-size: cover;
    box-shadow: 0 4px 8px 0 rgba(0,0,0,.25);
    background-position: center;
    -webkit-transition: -webkit-transform .7s cubic-bezier(.4,.2,.2,1);
    transition: -webkit-transform .7s cubic-bezier(.4,.2,.2,1);
    -o-transition: transform .7s cubic-bezier(.4,.2,.2,1);
    transition: transform .7s cubic-bezier(.4,.2,.2,1);
    transition: transform .7s cubic-bezier(.4,.2,.2,1),-webkit-transform .7s cubic-bezier(.4,.2,.2,1);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    text-align: center;
    height: 0;
    padding-bottom: 100%;
    border-radius: 20px;
    color: #fff
}

.sec02 .back {
    background: #cedce7;
    background: -webkit-linear-gradient(45deg,#cedce7 0%,#596a72 100%);
    background: -o-linear-gradient(45deg,#cedce7 0%,#596a72 100%);
    background: linear-gradient(45deg,#cedce7 0%,#596a72 100%)
}

.sec02 .box:hover .front,.sec02 .box:hover .back {
    -webkit-transition: -webkit-transform .7s cubic-bezier(.4,.2,.2,1);
    transition: -webkit-transform .7s cubic-bezier(.4,.2,.2,1);
    -o-transition: transform .7s cubic-bezier(.4,.2,.2,1);
    transition: transform .7s cubic-bezier(.4,.2,.2,1);
    transition: transform .7s cubic-bezier(.4,.2,.2,1),-webkit-transform .7s cubic-bezier(.4,.2,.2,1)
}

.sec02 .back {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%
}

.sec02 .back:after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,.05);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-radius: 20px
}

.sec02 .box .back {
    -webkit-transform: rotateY(180deg);
    transform: rotateY(180deg);
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d
}

.sec02 .box .front {
    -webkit-transform: rotateY(0deg);
    transform: rotateY(0deg);
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d
}

.sec02 .box:hover .back {
    -webkit-transform: rotateY(0deg);
    transform: rotateY(0deg);
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d
}

.sec02 .box:hover .front {
    -webkit-transform: rotateY(-180deg);
    transform: rotateY(-180deg);
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d
}

.sec02 .box_inner {
    -webkit-transform: translateY(-50%) translateZ(60px) scale(.94);
    transform: translateY(-50%) translateZ(60px) scale(.94);
    top: 50%;
    position: absolute;
    left: 0;
    width: 100%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    outline: 1px solid transparent;
    -webkit-perspective: inherit;
    perspective: inherit;
    z-index: 2
}

.sec02 .box_inner .info {
}

.sec02 .box_inner .info h3 {
    font-size: 24px;
    margin-bottom: 10px
}

.sec02 .box_inner .info p {
    font-size: 18px
}

.sec02 .box_inner .info a {
    display: block;
    width: 140px;
    height: 41px;
    line-height: 41px;
    text-align: center;
    border-radius: 50px;
    border: 1px solid #fff;
    font-size: 18px;
    font-weight: 700;
    margin: 40px auto 0;
    box-sizing: border-box;
    color: #fff
}

.sec03 {
    padding: 163px 0;
    background: rgb(255 255 255/50%)
}

.sec03 .swiper-slide {
    width: 25%
}

.sec03 .swiper-slide a {
    position: relative;
    display: block;
    width: 100%;
    height: 0;
    padding-bottom: 136%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: 50% 50%;
    border-radius: 16px
}

.sec03 .swiper-slide .info {
    position: absolute;
    bottom: 0;
    left: 0;
    width: calc(100% - 40px);
    border-radius: 20px;
    margin: 20px;
    padding: 20px;
    background: rgba(20,20,32,.14);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-sizing: border-box;
    color: #fff
}

.sec03 .swiper-slide .info .tit h3 {
    font-size: 24px;
    margin-bottom: 5px
}

.sec03 .swiper-slide .info .tit span {
    display: block;
    font-size: 18px;
    font-weight: 200
}

.sec03 .swiper-slide .info>p {
    height: 0;
    opacity: 0;
    font-size: 18px;
    border-top: 1px solid #fff;
    font-weight: 200;
    transition: all .3s
}

.sec03 .swiper-slide:hover .info>p {
    height: auto;
    opacity: 1;
    margin-top: 16px;
    padding-top: 16px
}

.sec03 .grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px 16px
}

.sec03 .grid>div .thumb {
    position: relative;
    height: 0;
    padding-bottom: 53.55%;
    overflow: hidden;
    margin-bottom: 16px
}

.sec03 .grid>div .thumb img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 100%;
    height: 100%;
    object-fit: cover
}

.sec03 .grid>div .info h3 {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 16px;
    justify-content: space-between;
    align-items: center
}

.sec03 .grid>div .info h3 span {
    font-weight: 400
}

.sec03 .grid>div .info p {
    color: #bdbdbd
}

.sec04 {
    padding: 120px 0;
    background: #faf2ff
}

.sec04 .news .top {
    align-items: center;
    margin-bottom: 80px
}

.sec04 .news .top .tit {
    margin-bottom: 40px;
    text-align: left
}

.sec04 .news .top .tit span {
    color: #000
}

.sec04 .news .top .tabs button {
    width: 171px;
    height: 41px;
    font-size: 24px;
    font-weight: 700;
    color: rgba(0,0,0,.5);
    border-radius: 50px
}

.sec04 .news .top .tabs button.active {
    border-radius: 100px;
    background: 0 0;
    box-shadow: 0 0 20px 0 #ba49ff;
    font-weight: 900;
    color: #ba49ff
}

.sec04 .news .top.click_change_tab button {
    color: rgb(255, 255, 255,50%);
}

.sec04 .news .top.click_change_tab button.active {
    background: rgb(170 170 170/0%)!important;
    color: #ba49ff!important
}

.sec04 .news .list .item {
    padding: 40px 0;
    border-bottom: 1px solid #ba49ff
}

.sec04 .news .list .item a {
    display: block;
    width: 100%;
    background: url("../images/arrow-right-white.svg")no-repeat 100% 50%;
    padding-right: 40px;
    box-sizing: border-box
}

.sec04 .news .list .item .title {
    margin-bottom: 17px;
    align-items: center
}

.sec04 .news .list .item .title strong {
    font-weight: 900;
    margin-right: 20px;
    font-size: 20px
}

.sec04 .news .list .item .title span {
    color: rgba(0,0,0,.5);
    font-weight: 200
}

.sec04 .news .list .item .subject {
    font-size: 32px;
    font-weight: 600;
    color: #000
}


div.news_popbox {
	text-align: center;
    background: rgb(255 255 255 / 95%);
    width: calc(100% - 40px);
    margin: 0 auto;
    display: none;
    border-radius: 20px;
    top: 0px;
    position: absolute;
    padding: 40px 20px;
    height: 80%;
    overflow-y: scroll;
}

  a.news_close {
    float: right;
    padding-right: 20px;
	position:relative;
	z-index:1;
}

.news_company {
    color: #ba49ff;
    font-size: 20px;
    float: left;
    text-align: left;
    padding-right: 20px;
}

.news_regdate {
    display: inline;
    font-size: 20px;
    color: rgb(0 0 0 / 50%);
    text-align: left;
    float: left;
}

.news_title {
    font-size: 32px;
    color: #000;
    text-align: left;
    clear: both;
    font-weight: 600;
}

.news_popup_inner {opacity: 1;}

.news_header {
    border-bottom: 1px solid #ba49ff;
    padding-bottom: 40px;
    margin-bottom: 20px;
}

.board_read {
    color: #000;
}

.news_box_color_change .news_regdate {
    color: rgb(255 255 255 / 50%);
}

.news_box_color_change .news_title, .news_box_color_change .conts {
    color: #fff;
}

.sec05 {
    padding: 240px 0 120px;
    overflow: hidden;
    box-sizing: border-box
}

.sec05:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    z-index: -1
}

.sec05 .inner {
    position: static
}

.sec05_1 {
    gap: 10px
}

.sec05_1 .box {
    position: relative;
    z-index: 1;
    max-width: 780px
}

.sec05_1 .box>span {
    display: inline-block;
    font-size: 22px;
    color: #e26738;
    font-weight: 500
}

.sec05_1 .box h2 {
    color: #000;
    font-size: 48px;
    font-weight: 600;
    line-height: 1.1;
    margin: 0
}

.sec05_1 .box h2 strong {
    font-weight: 600
}

.sec05_1 .box p {
    border-radius: 30px;
    background: rgb(186 73 255/5%);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    padding: 40px;
    font-size: 24px;
    font-weight: 300;
    margin-top: 40px;
    word-break: keep-all;
    box-sizing: border-box;
    color: #000
}

.sec05_1 .bn_img {
    position: relative;
    flex: 1
}

.sec05_1 .bn_img div {
    animation: MoveUpDown 2s linear infinite;
    position: absolute;
    top: 0;
    left: 0
}

.sec05_1 .bn_img img {
    max-width: 100%
}

.sec05 .benefit {
    position: relative;
    padding: 100px 20px 50px;
    z-index: 1;
    margin-top: 175px;
    background: #faf2ff
}

.sec05 .benefit .inner {
    position: relative;
    border-radius: 30px;
    background: rgba(255,255,255,.05);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    padding: 80px 120px;
    box-sizing: border-box
}

.sec05 .benefit h3 {
    position: absolute;
    font-size: 64px;
    font-weight: 800;
    color: #ba49ff
}

.sec05 .benefit h3 span {
    display: block;
    font-size: 20px;
    margin-bottom: 17px;
    font-weight: 400;
    border-radius: 100px;
    background: transparent;
    box-shadow: 0 0 20px 0 #ba49ff;
    width: 114px;
    height: 47px;
    line-height: 47px;
    text-align: center;
    color: #fff
}

.sec05 .benefit .form {
    padding-left: 600px;
    padding-top: 33px
}

.sec05 .benefit .form .flex {
    gap: 16px;
    justify-content: end;
    align-items: end
}

.sec05 .benefit .form .flex>div {
    position: relative
}

.sec05 .benefit .form .flex>div .circle {
    position: relative;
    border-radius: 50%
}

.sec05 .benefit .form .flex>div .circle span {
    display: block;
    text-align: center;
    margin-bottom: 20px
}

.sec05 .benefit .form .flex>div .circle .box {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 100%
}

.sec05 .benefit .form .flex>div p {
    text-align: center;
    font-size: 24px;
    color: #fff;
    font-weight: 400;
    text-transform: uppercase
}

.sec05 .benefit .form .flex>div p strong {
    color: #ba49ff;
    font-weight: 900
}

.sec05 .benefit .form .flex>div.gray {
    top: -30px
}

.sec05 .benefit .form .flex>div.gray .circle {
    width: 300px;
    height: 0;
    padding-bottom: 100%;
    background: rgb(186 73 255/20%);
    color: #fff;
    font-size: 48px;
    font-weight: 900
}

.sec05 .benefit .form .flex>div.gray .circle span {
    letter-spacing: -2.8px
}

.sec05 .benefit .form .flex>div.purple .circle {
    width: 500px;
    height: 0;
    padding-bottom: 100%
}

.sec05 .benefit .form .flex>div.purple .circle:after {
    content: '';
    position: absolute;
    top: 44%;
    left: 50%;
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background-image: linear-gradient(rgba(186,73,255,1),rgba(186,73,255,0));
    box-sizing: border-box;
    animation: spin 10s infinite linear;
    z-index: -1
}

@keyframes spin {
    from {
        transform: translate(-50%,-50%) rotate(0deg)
    }

    to {
        transform: translate(-50%,-50%) rotate(359deg)
    }
}

.sec05 .benefit .form .flex>div.purple .circle>div {
    position: relative;
    border-radius: 50%;
    background: #ba49ff;
    color: rgba(255,255,255,.6);
    font-size: 33px;
    width: 445px;
    height: 0;
    padding-bottom: 84.9%;
    margin: 0 auto;
    border: 10px solid transparent;
    box-sizing: border-box
}

.sec05 .benefit .form .flex>div.purple .circle span {
    font-size: 36px;
    color: #fff
}

.sec05 .benefit .form .flex>div.purple .circle span strong {
    display: block;
    font-weight: 900;
    font-size: 60px
}

.sec05 .benefit .form .flex>div.purple .circle p strong {
    color: #000
}

.sec05 .benefit .txt {
    position: absolute;
    top: 370px;
    left: 120px;
    font-size: 18px;
    color: #000
}

.sec05 .benefit .txt strong {
    display: block;
    margin-bottom: 5px
}

.sec05 .benefit .txt p {
    line-height: 1.5
}

.sec05 .benefit2 {
    position: relative;
    text-align: center;
    padding-bottom: 120px;
    background: #faf2ff
}

.sec05 .benefit2 .inner {
    position: relative;
    background: url("../images/benefit_bg.png")no-repeat 50% 50%/cover;
    padding: 222px 0;
    border-radius: 30px;
    overflow: hidden
}

.sec05 .benefit2 .inner:after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: linear-gradient(0deg,rgba(14,13,18,0.40) 0%,rgba(14,13,18,0.40) 100%),rgba(255,255,255,0.05);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px)
}

.sec05 .benefit2 .box {
    position: relative;
    z-index: 1
}

.sec05 .benefit2 .box h3 {
    font-size: 64px;
    font-weight: 800
}

.sec05 .benefit2 .box h3 span {
    display: block;
    font-size: 20px;
    margin-bottom: 17px;
    font-weight: 400;
    border-radius: 100px;
    background: #0e0d12;
    box-shadow: 0 0 20px 0 #ba49ff;
    width: 114px;
    height: 47px;
    line-height: 47px;
    text-align: center;
    margin: 0 auto 20px
}

.benefit3 {
    position: relative;
    padding: 135px 0
}

.benefit3 .flex {
    justify-content: center;
    gap: 72px
}

.benefit3 .flex>div {
    text-align: center;
    font-size: 24px;
    color: #999
}

.benefit3 .flex>div h3 {
    font-size: 100px;
    font-weight: 800;
    color: #ba49ff;
    margin-bottom: 16px
}

.sec06 {
    padding: 220px 0 0;
    overflow: hidden;
    box-sizing: border-box
}

.lab {
    position: relative;
    padding-bottom: 100px
}

.lab .grid {
    justify-content: space-between;
    align-items: end;
    max-width: 1480px;
    margin: 0 auto
}

.lab .text {
    gap: 20px 10px;
    align-items: center
}

.lab .text .logo {
    margin-bottom: 28px
}

.lab .text .title {
    font-size: 44px;
    line-height: 1.2;
    margin-bottom: 28px;
    color: #ba49ff
}

.lab .text .title h3 {
    font-weight: 800
}

.lab .text p {
    font-size: 24px;
    color: #000
}

.lab .text .img {
    flex: 1
}

.lab .text .img img {
    width: 100%
}

.lab .box {
    gap: 40px;
    justify-content: center;
    margin: 40px auto 0
}

.lab .box>div {
    flex: 1;
    align-items: center;
    background: #faf2ff;
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    padding: 48px 0;
    border-radius: 30px;
    text-align: center;
    transition: all .3s
}

.lab .box>div:hover {
    box-shadow: 0 0 30px 0 rgba(186,73,255,.4)
}

.lab .box>div .icon {
    width: 80px;
    margin: 0 auto 20px
}

.lab .box>div .icon img {
    width: 100%
}

.lab .box>div p {
    font-size: 32px;
    color: #000
}

.contact_bar {
    position: relative;
    background: #ba49ff
}

.contact_bar:before {
    content: '';
    display: block;
    position: absolute;
    width: 400px;
    height: 400px;
    border-radius: 50%;
    animation: mainVb_word1 both linear infinite 4s;
    top: 50px;
    left: 15%;
    transform: translateX(-50%);
    background: #3b2d63;
    filter: blur(100px);
    z-index: -1
}

.contact_bar .flex {
    align-items: center;
    padding: 100px 0;
    line-height: 1.5;
    justify-content: space-between
}

.contact_bar .flex h3 {
    font-size: 48px;
    font-weight: 800
}

.contact_bar .flex p {
    font-size: 24px
}

.contact_bar .flex p strong {
    display: block
}

.contact_bar .flex p a {
    display: block;
    width: 100%;
    border-radius: 100px;
    background: #fff;
    font-size: 20px;
    font-weight: 700;
    color: #ba49ff;
    text-align: center;
    margin-top: 20px;
    padding: 10px 30px;
    box-shadow: 0 0 20px 0 rgba(20,20,32,.5);
    box-sizing: border-box
}

.contact {
    padding: 100px 0;
    background: #fff
}

.contact .form .flex {
    gap: 10px 30px
}

.contact .form .flex>div {
    flex: 1;
    border-radius: 30px;
    background: #faf2ff;
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    padding: 40px;
    box-sizing: border-box;
    margin-bottom: 30px
}

.contact .form .flex>div h4 {
    font-size: 32px;
    font-weight: 700;
    color: #000;
    margin-bottom: 20px
}

.contact .form .flex>div select {
    font-size: 26px;
    background-color: transparent;
    padding: 0;
    height: 42px;
    background-position: 100% 50%
}

.contact .form .flex>div input {
    display: block;
    width: 100%;
    height: 42px;
    background: 0 0;
    font-size: 26px;
    /* color: #aaa; */
}


.contact .form .flex>div input::-webkit-input-placeholder {
  color: #000;
}
.contact .form .flex>div input:-ms-input-placeholder {
  color: #000;
}

.contact.placeholder_color_change .form .flex>div input::placeholder {
    color: rgb(0 0 0/60%)
}

.contact .form .flex>div textarea {
    display: block;
    width: 100%;
    padding: 0;
    height: 247px;
    background: 0 0;
    font-size: 26px;
    resize: none;
    border: 0
}

.contact .taC button {
    display: block;
    width: 147px;
    height: 45px;
    border-radius: 50px;
    font-size: 24px;
    font-weight: 700;
    margin: 50px auto 0
}

.sec07 {
    padding: 100px 0 80px;
    background: #faf2ff
}

.sec07 h3.tit img {
    margin-right: 10px
}

.sec07 .flex>div {
    width: 25%
}

.sec07 .flex>div a {
    position: relative;
    display: block;
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover
}

.sec07 .flex>div a:after {
    content: '';
    opacity: 0;
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,.05);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    transition: all .3s
}

.sec07 .flex>div .info {
    display: none;
    padding: 60px 40px;
    box-sizing: border-box;
    color: #fff;
}

.sec07 .flex>div .info h4 {
    position: relative;
    font-size: 32px;
    z-index: 1
}

.sec07 .flex>div .info p {
    position: absolute;
    bottom: 60px;
    left: 40px;
    z-index: 1;
    font-size: 26px
}

.sec07 .flex>div a:hover:after {
    opacity: 1
}

.sec07 .flex>div a:hover .info {
    display: block
}

@media screen and (max-width: 1600px) {
    .visual .slide01 .box h2 {
        font-size:60px
    }

    .sec05 .benefit .form {
        padding-left: 470px
    }

    .sec05 .benefit .inner {
        padding: 80px 50px
    }

    .sec05 .benefit .txt {
        left: 50px
    }

    .sec05 .benefit .form .flex>div.gray .circle {
        width: 260px;
        font-size: 38px
    }

    .sec05 .benefit .form .flex>div.purple .circle {
        width: 390px
    }

    .sec05 .benefit .form .flex>div.purple .circle>div {
        width: 360px;
        padding-bottom: 87.2%
    }

    .sec05 .benefit .form .flex>div.purple .circle:after {
        top: 46%
    }

    .sec05 .benefit .form .flex>div.purple .circle span strong {
        font-size: 42px
    }
}

@media screen and (max-width: 1280px) {
    .visual .swiper-slide .box {
        height:470px
    }

    .visual .slide01 .box h2 {
        font-size: 50px
    }

    .visual .slide01 .box .bn_img {
        flex: 1
    }

    .visual .slide02 .box {
        background-size: auto 365px
    }

    .visual .txt {
        font-size: 20px
    }

    .bg>div {
        width: 270px;
        height: 270px
    }

    .bg>div.bg1 {
        top: 0;
        left: -35px
    }

    .bg>div.bg3 {
        top: 26%;
        right: 7%
    }

    .sec00 .grid4 {
        gap: 15px
    }

    .sec00 .grid4>div h4 {
        font-size: 28px
    }

    .sec00 .grid4>div p {
        font-size: 16px
    }

    .sec01 {
        padding: 120px 0 60px
    }

    .sec01 .grid .swiper-slide .item .info {
        padding-top: 85%
    }

    .sec01 .grid .swiper-slide .item .info .name>span {
        font-size: 20px
    }

    .sec01 .taC a {
        font-size: 20px
    }

    .sec02 {
        padding: 100px 0 90px
    }

    .sec02 .tab .swiper-container {
        height: 90px
    }

    .sec02 .tab button {
        font-size: 20px
    }

    .sec02 .tab button.active {
        font-size: 24px
    }

    .sec02 .box_inner .info h3 {
        font-size: 20px
    }

    .sec02 .slide .swiper-slide .info p {
        font-size: 16px
    }

    .sec02 .box_inner .info a {
        font-size: 16px
    }

    .sec03 {
        padding: 100px 0
    }

    .sec03 .swiper-slide .info .tit h3 {
        font-size: 18px
    }

    .sec03 .swiper-slide .info .tit span {
        font-size: 14px
    }

    .sec03 .swiper-slide .info>p {
        font-size: 14px
    }

    .sec04 .bg>div.bg1 {
        top: -7%;
        width: 500px;
        height: 500px
    }

    .sec04 .news {
        padding: 0
    }

    .sec04 .news .top {
        margin-bottom: 65px
    }

    .sec04 .news .top .tabs button {
        width: 100px;
        height: 47px;
        font-size: 22px;
        margin-right: 17px
    }

    .sec04 .news .list .item .subject {
        font-size: 30px
    }

 
    .sec05 {
        padding: 100px 0 0
    }

    .sec05_1 {
        width: 100%
    }

    .sec05_1 .bn_img {
        flex: none;
        width: 100%
    }

    .sec05_1 .box {
        width: 100%;
        max-width: 100%;
        margin-top: 50%
    }

    .sec05_1 .box h2 {
        text-align: center
    }

    .sec05 .benefit {
        padding: 8% 20px 50px
    }

    .sec05 .benefit .inner {
        padding: 50px 30px
    }

    .sec05 .benefit h3 {
        font-size: 48px
    }

    .sec05 .benefit .txt {
        top: 245px;
        left: 30px;
        max-width: 350px
    }

    .sec05 .benefit .form {
        padding-left: 360px
    }

    .sec05 .benefit .form .flex>div p {
        font-size: 20px
    }

    .sec05 .benefit .form .flex>div.gray {
        top: -10px
    }

    .sec05 .benefit .form .flex>div.gray .circle {
        width: 220px;
        font-size: 34px
    }

    .sec05 .benefit .form .flex>div.purple .circle {
        width: 330px
    }

    .sec05 .benefit .form .flex>div.purple .circle:after {
        top: 47%
    }

    .sec05 .benefit .form .flex>div.purple .circle>div {
        width: 310px;
        padding-bottom: 88%
    }

    .sec05 .benefit .form .flex>div.purple .circle span strong {
        font-size: 34px
    }

    .sec05 .benefit2 .inner {
        padding: 95px 0
    }

    .sec05 .benefit2 .box h3 {
        font-size: 48px
    }

    .benefit3 {
        padding: 100px 0
    }

    .benefit3 .flex>div h3 {
        font-size: 85px;
        margin-bottom: 8px
    }

    .sec06 {
        padding-top: 100px
    }

    .sec07 .flex>div .info {
        padding: 35px 20px
    }

    .sec07 .flex>div .info h4 {
        font-size: 24px
    }

    .sec07 .flex>div .info p {
        bottom: 35px;
        left: 20px;
        font-size: 22px
    }

    .lab .text .title {
        font-size: 34px
    }

    .lab .text p {
        font-size: 20px
    }

    .lab .box>div {
        padding: 40px 0
    }

    .lab .box>div .icon {
        width: 65px;
        margin: 0 auto 10px
    }

    .lab .box>div p {
        font-size: 24px
    }

    .contact_bar .flex h3 {
        font-size: 28px
    }

    .contact_bar .flex p {
        font-size: 20px
    }

    .contact_bar .flex p a {
        font-size: 18px
    }

    .contact {
        padding: 100px 0 90px
    }

    .contact .form .flex {
        gap: 0 20px
    }

    .contact .form .flex>div {
        margin-bottom: 20px
    }

    .contact .form .flex>div h4 {
        font-size: 20px
    }

    .contact .form .flex>div select {
        font-size: 22px
    }

    .contact .form .flex>div input {
        font-size: 22px
    }

    .contact .form .flex>div textarea {
        font-size: 22px
    }

    .contact .taC button {
        font-size: 20px
    }
}

@media screen and (max-width: 1024px) {
    .bg>div {
        width:180px;
        height: 180px
    }

    .bg>div.bg2 {
        top: 0;
        right: -20px
    }

    .visual {
        padding: 145px 0 75px
    }

    .visual .bn_img {
        height: 65%
    }

    .visual .slide01 .box h2 {
        font-size: 38px
    }

    .sec00 .grid4>div {
        flex: none;
        width: calc(50% - 8px);
        padding: 25px 10px
    }

    .sec00 .grid4>div h4 {
        font-size: 24px
    }

    .sec01 .grid {
        grid-template-columns: 1fr 1fr
    }

    .sec02 .tab .swiper-container {
        height: 85px;
        margin: 0 -20px;
        padding-left: 20px
    }

    .sec02 .tab button {
        font-size: 18px
    }

    .sec02 .tab button.active {
        font-size: 20px
    }

    .sec02 .tab .swiper-wrapper {
        justify-content: normal
    }

    .sec03 .slide .swiper-container {
        margin: 0 -20px;
        padding-left: 20px
    }

    .sec04 .news .top {
        margin-bottom: 30px
    }

    .sec04 .news .top .tit {
        margin-right: 30px
    }

    .sec04 .news .top .tabs button {
        width: 86px;
        height: 42px;
        font-size: 18px;
        margin-right: 12px
    }

    .sec04 .news .list .item {
        padding: 20px 0
    }

    .sec04 .news .list .item a {
        background-size: 15px!important;
        background-position: calc(100% - 7px) 50%;
        padding-right: 30px
    }

    .sec04 .news .list .item .title strong {
        font-size: 14px
    }

    .sec04 .news .list .item .title span {
        font-size: 14px
    }

    .sec04 .news .list .item .subject {
        font-size: 22px
    }

    .sec04 .marketing .slide .swiper-slide .info h3 {
        font-size: 26px
    }

    .sec04 .marketing .slide .swiper-slide .info div span {
        font-size: 18px
    }

    .sec04 .marketing .slide .swiper-slide .info div strong {
        font-size: 26px
    }

    .sec05_1 .box h2 {
        font-size: 34px
    }

    .sec05_1 .box p {
        font-size: 14px
    }

    .sec05 .benefit {
        padding: 85px 20px 100px
    }

    .sec05 .benefit h3 span {
        font-size: 20px
    }

    .sec05 .benefit h3 {
        position: static;
        font-size: 36px
    }

    .sec05 .benefit .form {
        padding-left: 0
    }

    .sec05 .benefit .form .flex {
        justify-content: center
    }

    .sec05 .benefit .txt {
        position: static;
        margin-top: 40px;
        font-size: 16px;
        max-width: 100%
    }

    .sec05 .benefit2 .box h3 {
        font-size: 36px
    }

    .benefit3 .flex {
        gap: 35px
    }

    .benefit3 .flex>div {
        width: calc(50% - 18px)
    }

    .lab .text .title {
        font-size: 28px
    }

    .lab .text p {
        font-size: 16px
    }

    .lab .text .img {
        flex: none;
        width: 100%
    }

    .lab .box>div .icon {
        width: 55px
    }

    .lab .box>div p {
        font-size: 20px
    }

    .sec07 .flex>div .info h4 {
        font-size: 18px
    }

    .sec07 .flex>div .info p {
        font-size: 18px
    }

    .contact_bar .flex {
        justify-content: center;
        gap: 10px;
        text-align: center
    }

    .contact_bar .flex h3 {
        font-size: 24px;
        width: 100%
    }

    .contact_bar .flex p {
        width: 100%;
        font-size: 14px
    }

    .contact_bar .flex p a {
        max-width: 500px;
        margin: 20px auto 0
    }

    .contact .form .flex>div {
        padding: 16px 24px
    }

    .contact .form .flex>div h4 {
        font-size: 16px;
        margin-bottom: 10px
    }

    .contact .form .flex>div select {
        font-size: 18px;
        height: 36px
    }

    .contact .form .flex>div input {
        font-size: 18px;
        height: 36px
    }

    .contact .form .flex>div textarea {
        font-size: 18px;
        height: 180px
    }

    .contact .taC button {
        width: 190px;
        height: 60px;
        font-size: 20px;
        margin: 35px auto 0
    }
}

@media screen and (max-width: 768px) {
    .visual {
        padding:110px 0 75px
    }

    .visual .swiper-slide .box {
        height: 425px
    }

    .visual .box h2 {
        font-size: 26px
    }

    .visual .slide01 .box {
        justify-content: center
    }

    .visual .slide01 .box h2 {
        width: 100%;
        font-size: 30px
    }

    .visual .slide02 .box {
        background-size: auto 330px
    }

    .visual .txt {
        font-size: 16px
    }

    .sec01 .grid .swiper-slide .item .info {
        padding-top: 91%
    }

    .sec01 .grid .swiper-slide .item .info .name>span {
        font-size: 14px
    }

    .sec01 .grid .swiper-slide .item .info .description-prod p {
        font-size: 14px
    }

    .sec01 .grid .swiper-slide .item .card-footer {
        font-size: 14px
    }

    .sec01 .taC a {
        font-size: 16px;
        width: 125px;
        height: 42px;
        line-height: 44px
    }

    .sec02 {
        padding: 80px 0
    }

    .sec02 .tab button {
        font-size: 20px;
        margin-right: 18px
    }

    .sec02 .slide {
        margin-top: -40px
    }

    .sec02 .slide .swiper-container {
        margin: 0 -20px;
        padding-left: 20px
    }

    .sec03 .grid>div .info h3 {
        font-size: 18px;
        margin-bottom: 10px
    }

    .sec04 {
        padding-bottom: 110px
    }

    .sec04 .bg>div.bg1 {
        width: 250px;
        height: 250px
    }

    .sec04 .bg>div.bg2 {
        top: 389px;
        width: 250px;
        height: 250px
    }

    .sec04 .news .top .tit {
        display: block;
        margin-bottom: 20px;
        marign-right: 0
    }

    .sec04 .news .top .tabs {
        display: block
    }

    .sec04 .news .top .tabs button {
        width: 75px;
        height: 32px;
        font-size: 14px;
        margin-right: 8px
    }

    .sec04 .news .list .item .subject {
        font-size: 18px
    }

    .sec04 .news .list .item a {
        background-size: 12px!important
    }

    .sec04 .marketing .swiper-container {
        padding-left: 20px;
        margin: 0 -20px
    }

    .sec04 .marketing .slide .swiper-slide .info {
        padding: 20px
    }

    .sec04 .marketing .slide .swiper-slide .info h3 {
        font-size: 22px
    }

    .sec04 .marketing .slide .swiper-slide .info div span {
        font-size: 16px
    }

    .sec04 .marketing .slide .swiper-slide .info div strong {
        font-size: 22px
    }

    .sec05_1 .box {
        padding: 0 0 10%;
        margin-top: 55%
    }

    .sec05 .benefit {
        padding: 15px 20px 30px
    }

    .sec05 .benefit h3 span {
        font-size: 18px
    }

    .sec05 .benefit h3 {
        font-size: 30px
    }

    .sec05 .benefit .form .flex>div {
        flex: 1
    }

    .sec05 .benefit .form .flex>div p {
        font-size: 18px
    }

    .sec05 .benefit .form .flex>div.gray .circle {
        width: 80%;
        font-size: 20px;
        padding-bottom: 80%;
        margin: 8% auto
    }

    .sec05 .benefit .form .flex>div.purple .circle {
        width: 100%
    }

    .sec05 .benefit .form .flex>div.purple .circle span {
        font-size: 20px;
        letter-spacing: -1px
    }

    .sec05 .benefit .form .flex>div.purple .circle span strong {
        font-size: 26px
    }

    .sec05 .benefit .form .flex>div.purple .circle>div {
        width: calc(100% - 25px);
        padding-bottom: calc(100% - 35px);
        border-width: 7px
    }

    .sec05 .benefit .form .flex>div.purple .circle:after {
        top: 46%
    }

    .sec05 .benefit2 .box h3 {
        font-size: 30px
    }

    .benefit3 {
        padding: 65px 0
    }

    .benefit3 .flex {
        gap: 25px
    }

    .benefit3 .flex>div h3 {
        font-size: 65px
    }

    .sec07 h3.tit img {
        width: 140px
    }

    .sec07 .flex>div {
        width: 50%
    }

    .sec07 .flex>div .info {
        padding: 15px
    }

    .sec07 .flex>div .info h4 {
        font-size: 14px
    }

    .sec07 .flex>div .info p {
        bottom: 15px;
        left: 15px;
        font-size: 14px
    }

    .lab .box {
        gap: 15px
    }

    .lab .box>div {
        flex: none;
        width: 100%
    }

    .contact_bar {
        margin-top: 40px
    }

    .contact_bar .flex {
        padding: 50px 0
    }

    .contact_bar .flex h3 {
        margin: 0 0 30px
    }

    .contact .form .flex>div {
        flex: none;
        width: 100%;
        border-radius: 15px
    }

    .contact .form .flex>div:nth-child(2) {
        margin-left: 0
    }
}

@media screen and (max-width: 480px) {
    h3.tit {
        font-size:32px
    }

    .visual .swiper-slide .box {
        height: 340px
    }

    .visual .box h2 {
        font-size: 20px
    }

    .visual .slide01 .box h2 {
        font-size: 26px
    }

    .visual .slide02 .box {
        background-size: auto 260px
    }

    .sec00 .grid4>div {
        width: 100%
    }

    .sec01 {
        padding: 80px 0 40px
    }

    .sec01 .grid {
        grid-template-columns: 1fr
    }

    .sec01 .grid>div .thumb {
        margin-bottom: 12px
    }

    .sec02 .tab button {
        font-size: 16px;
        margin-right: 14px
    }

    .sec02 .slide .swiper-slide .info h3 {
        font-size: 16px
    }

    .sec02 .slide .swiper-slide .info p {
        font-size: 14px
    }

    .sec03 .grid {
        grid-template-columns: 1fr;
        gap: 30px 0
    }

    .sec05_1 .box h2 {
        font-size: 26px
    }

    .sec05 .benefit .form .flex>div {
        flex: none;
        width: 100%
    }

    .sec05 .benefit .form .flex>div p {
        position: static
    }

    .sec05 .benefit .form .flex>div.gray {
        margin-bottom: 20px
    }

    .sec05 .benefit .form .flex>div.purple .circle:after {
        top: 47%
    }

    .sec05 .benefit .txt {
        text-align: center
    }

    .sec05 .benefit2 h4 {
        font-size: 26px
    }

    .benefit3 .flex>div {
        width: calc(50% - 13px);
        font-size: 20px
    }

    .benefit3 .flex>div h3 {
        font-size: 50px
    }

    .sec07 h3.tit img {
        width: 100px
    }

    .lab .text .title {
        font-size: 22px;
        margin-bottom: 16px
    }

    .lab .text p {
        font-size: 14px
    }

    .lab .box {
        padding: 20px 24px
    }

    .lab .box>div {
        padding: 20px 0
    }

    .contact_bar .flex h3 {
        font-size: 20px
    }
}

@media screen and (max-width: 380px) {
    .visual .swiper-slide .box {
        height:220px
    }

    .visual .box h2 {
        font-size: 16px
    }

    .visual .slide01 .box h2 {
        font-size: 22px
    }

    .visual .slide02 .box {
        background-size: auto 160px
    }

    .sec04 .news .top .tabs button {
        width: 55px;
        height: 32px;
        margin-right: 4px
    }

    .sec04 .news .list .item .subject {
        font-size: 16px
    }

    .sec04 .marketing .slide .swiper-slide .info h3 {
        font-size: 18px
    }

    .sec04 .marketing .slide .swiper-slide .info div span {
        font-size: 14px
    }

    .sec04 .marketing .slide .swiper-slide .info div strong {
        font-size: 18px
    }

    .sec05 .benefit .form .flex>div.purple .circle:after {
        top: 46%
    }

    .benefit3 .flex>div h3 {
        font-size: 40px
    }

    .sec07 h3.tit img {
        width: 85px;
        display: block;
        margin: 0 auto 10px
    }

    .contact .form .flex>div {
        margin-bottom: 16px
    }

    .contact .form .flex>div select {
        font-size: 14px;
        height: 32px
    }

    .contact .form .flex>div input {
        font-size: 14px;
        height: 32px
    }

    .contact .taC button {
        font-size: 18px
    }
}
