
body {background-image: url(../img/body_bg.jpg); background-repeat: repeat-y; word-break:keep-all;}



@keyframes prebook_link {
    0% {transform: translateY(0);}
    50% {transform: translateY(-10px);}
    100% {transform: translateY(0);}
}

/* MAIN */
.main_visual {position: relative; height: 100vh; display: grid; align-items: center; overflow: hidden;}

.main_visual .content {display: grid; grid-template-columns: 50% 50%; align-items: center;}

.main_con {width: 100%;}
.main_con h1 {line-height: 1.2; width: 100%;}
.main_con h1 span {font-size: 80px; color: #4dd3ff;}
.main_con p {width:100%; margin-top: 50px;}

.main_con p span {font-size: 30px; font-weight: 900; background: linear-gradient(90deg, #ff7392, #709ef0); color: transparent; -webkit-background-clip: text;}

.main_img img {max-width: 700px;}

/* USER PROBLEMS */
.user_problems {width: 100%; margin: 150px 0;}
.user_problems .inner {width: 100%; display: grid; grid-template-columns: 700px 700px;}
.user_problems_con {width: 100%; display: grid;}

.user_problems_text { background-size: contain; background-repeat: no-repeat; transform: scale(130%);}
.user_problems_text h6 {margin-bottom: 30px;}
.user_problems_text p {font-size: 20px;}
.user_problems_text p span {font-size: 24px; font-weight: 700;}

.user_organizer {grid-template-columns: 200px auto;}
.user_organizer img {width: 100%;}
.user_organizer .user_problems_text {}
.user_organizer .user_problems_text h6 {padding-left: 10%;}

.user_participant {grid-template-columns: auto 200px;}
.user_participant img {width: 100%;}
.user_participant .user_problems_text {padding-top: 150px;}
.user_participant .user_problems_text h6 {padding-right: 30%; text-align: right;}

/* SERVICE */
.service_info {padding: 100px 0;}
.service_info_title {text-align: center;}

.service_info_box {width: 100%; background: linear-gradient(90deg, rgba(255,115,146,.1), rgba(112,158,240,.1)); border-radius: 50px; display: grid; grid-template-columns: 50% 50%; margin: 250px 0;}

.service_info_box.left .service_info_text {order: 1;}
.service_info_box.left .service_info_img {order: 2;}
.service_info_box.right .service_info_text {order: 2;}
.service_info_box.right .service_info_img {order: 1;}

.service_info_text {padding: 70px;}
.service_info_text h3 {margin-bottom: 30px;}
.service_info_text p {font-size: 20px;}

.service_info_img {position: relative;}
.service_info_img img {position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 90%;}

/* PERFORMANCE */
.performance_info .inner {display: grid;}

.performance_bublle {width: 50%; text-align: center; font-size: 30px; padding: 3%; background-position: center center; background-repeat: no-repeat; background-size: contain;}
.performance_bublle img {width: 100%;}
.performance_bublle.right {text-align: right; margin-left: 50%;}
.performance_bublle.left { text-align: left; margin-right: 50%;}

.performance_info_title {text-align: center; margin: 150px 0;}

.performance_box {padding: 0 10%;}
.performance_contents {background: #fff; box-shadow: 7px 7px 10px rgba(0,0,0,.1); border-radius: 30px; padding: 30px; width: 55%; position: relative;}
.performance_contents.fund {margin-right: 45%;}
.performance_contents.date {margin-left: 45%; top: -50px;}

.performance_contents p {font-size: 20px;}
.performance_contents h3 span {background: linear-gradient(90deg, #ff7392, #709ef0); color: transparent; -webkit-background-clip: text; font-size: 40px;}

.performance_img img {width: 90%; max-width: 400px;}

.performance_contents.fan {width: 100%; text-align: center;}
.performance_contents.fan h2 {background: linear-gradient(90deg, #ff7392, #709ef0); color: transparent; -webkit-background-clip: text;}

.performance_contents.fan p.fan_title {font-size: 30px;}
.performance_contents.fan p.fan_info {font-size: 12px; color: #999;}

/* BOAST */
.boast_info {margin: 200px 0;}
.boast_message_01 {background: linear-gradient(90deg, rgba(255,115,146,.1), rgba(112,158,240,.1)); text-align: center; border-radius: 70px; padding: 50px;}
.boast_message_01 h2 span {color: #f95b85;}
.boast_message_02 {margin: 200px 0; text-align: center;}

/* REVIEW */
.review {margin: 200px 0;}
.review_title {text-align: center; position: relative; background: linear-gradient(90deg, rgba(255,115,146,1), rgba(112,158,240,1)); color: #fff; padding: 10px 70px 10px 30px; font-size: 24px; width: fit-content; border-radius: 15px; margin: 0 auto 100px;}
.review_title img {position: absolute; right: -100px; width: 150px; top: 50%; transform: translateY(-50%);}

.review_list {display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 30px; }
.review_list li {background: #fff; box-shadow: 3px 3px 10px rgba(0,0,0,.15); border-radius: 30px; padding: 30px; display: grid;}
.review_list li img {width: 100%; max-width: 600px; margin: 0 auto; }

.review_name {font-size: 24px; margin-bottom: 10px;}
.review_name span {font-size: 20px; color: #8a8aef;}
.review_text_origin {background: #f4f4f4; padding: 10px; border-radius: 15px; width: 85%; margin-right: 15%; word-break: break-all;}
.review_text_trans {background: #e9e9ff; padding: 10px; border-radius: 15px; font-size: 14px; width: 90%; margin-left: 10%; position: relative; top: -8px; margin-bottom: 30px;}

.review_more {margin: 50px auto; width: 100%; display: block;}
.review_more a {text-align: center; position: relative; background: linear-gradient(90deg, rgba(255,115,146,1), rgba(112,158,240,1)); color: #fff; padding: 10px 50px; font-size: 24px; border-radius: 30px; display: block; width: 100%; max-width: 450px; margin: 0 auto;}

/* CONTENTS */
.contents_info {width: 100%; padding: 100px 0;}
.contents_info .content {display: grid; grid-template-columns: 50% 50%; align-items: center;}
.contents_info_con h2 {margin-bottom: 10px;}
.contents_info_con h2 img {width: 120px;}
.contents_info_con strong {font-size: 30px; margin-bottom: 30px; display: block;}
.contents_info_con p {font-size: 18px;}

.contents_info_img img {width: 100%; max-width: 600px;}

/* .contents_info.left {background-image: url(../img/bg_bottom.png); background-position: bottom; background-repeat: no-repeat;}
.contents_info.right {background-image: url(../img/bg_top.png); background-position: top; background-repeat: no-repeat;} */

.contents_info.left .contents_info_img {padding-left: 100px;}
.contents_info.right .contents_info_img {padding-right: 100px;}

.contents_info.left .content .contents_info_con {order: 1;}
.contents_info.left .content .contents_info_img {order: 2;}
.contents_info.right .content .contents_info_con {order: 2;}
.contents_info.right .content .contents_info_img {order: 1;}

/* .supporting_slide li {width: 300px;} */
.supporting_slide {border-radius: 20px; margin-top: 100px;}
.supporting_slide li {padding: 0 15px; width: 400px;}
.supporting_slide li iframe {width: 100%; height: 250px; border-radius: 20px; overflow: hidden;}

.slick_arrow {background: #fff; width: 50px; height: 50px; border-radius: 25px; box-shadow: 10px 10px 10px rgba(0,0,0,.1); position: absolute; top: 50%; transform: translateY(-50%); display: flex; justify-content: center; z-index: 1; cursor: pointer;}
.slick_arrow.prev_arrow {left: 0;}
.slick_arrow.next_arrow {right: 0;}

.slick_arrow img {width: 20px;}

.title_badge {display: inline-block; margin: 0 10px; background: linear-gradient(45deg, #e53863, #4dd3ff); padding: 10px 15px; color: #fff; vertical-align: middle; border-radius: 30px; font-size: 16px;}

/* PRE BOOK */
.prebook {margin: 100px 0;}
.prebook h2 {text-align: center;}
.prebook_con {background: linear-gradient(90deg, rgba(255,115,146,.1), rgba(112,158,240,.1)); border-radius: 50px; padding: 50px; display: grid; grid-template-columns: 1fr 1fr;}

.prebook_img {padding: 10%;}
.prebook_img img {width: 100%;}

.prebook_info>h2 {text-align: left; margin-bottom: 10px;}
.prebook_info>span {background: linear-gradient(90deg, #ff7392, #709ef0); color: transparent; -webkit-background-clip: text; font-size: 30px; font-weight: 700; margin-bottom: 30px; display: inline-block;}
.prebook_info>p {font-size: 20px;}

.prebook_gift {background: #fff; width: 100%; padding: 30px; border-radius: 30px; margin: 30px 0;}

.prebook_btn {margin-top:20px; width: 100%; border-radius: 25px; height: 50px; color: #fff; font-size: 18px;}
.prebook_btn.googleform {background: linear-gradient(90deg, #ff7392, #709ef0);}
.prebook_btn.twitter {background: #333;}


@media (max-width: 1400px) {
    /* USER PROBLEMS */
    .user_problems {}
    .user_problems .inner {grid-template-columns: none;}

    .user_organizer .user_problems_text {width: 500px;}

    .user_participant {justify-content: right;}
    .user_participant .user_problems_text {width: 500px; margin-top: -50px; padding: 0;}

    /* PERFORMANCE */
    .performance_bublle h3 {font-size: 30px;}

    /* BOAST */
    .boast_message_02 {margin: 100px 0;}

    /* REVIEW */
    .review {margin: 100px 0;}
}

@media (max-width: 1080px) {
    /* MAIN */
    .main_con h1 {font-size: 50px;}
    
    /* PERFORMANCE */
    .performance_bublle h3 {font-size: 24px;}

    .performance_contents {width: 70%;}
    .performance_contents.fund {margin-right: 30%;}
    .performance_contents.date {margin-left: 30%; top: -50px;}

    /* REVIEW */
    .review_list {grid-template-columns: none; max-width: 600px; margin: 0 auto;}

    /* PRE BOOK  */
    .prebook {margin: 50px 0;}
    .prebook_con {grid-template-columns: 1fr;}
    .prebook_img {display: none;}
    .prebook_info>span {font-size: 18px;}
}


@media (max-width: 768px) {

    /* BOTTOM MENU*/
    .bottom_menu {bottom: 15px; left: unset; right: 15px; transform: none;}
    .bottom_menu .store_link {display: block;}
    .bottom_menu .store_link li {margin-top: 10px;}
    .bottom_menu .store_link li a {font-size: 14px; width: 200px; height: 40px; padding: 10px;}
    .bottom_menu .store_link li a img {height: 20px;}

    .bottom_menu .store_link li.prebook_link a {font-size: 16px; padding: 15px 30px;}

    .main_visual {height: auto;}
    .main_visual .content {display: grid; grid-template-columns: none; margin-top: 100px;}

    .main_con {text-align: center;}
    .main_con .store_link {justify-content: center;}

    .main_img {width: 70%; margin: 0 auto;}
    .main_img img {width: 100%;}

    /* USER PROBLEMS */
    .user_problems {margin: 100px 0;}
    .user_problems_text {transform: none;}
    .user_problems_text h6 {margin-bottom: 15px;}
    .user_problems_text p {font-size: 14px; } 
    .user_problems_text p span {font-size: 16px;}

    .user_organizer {grid-template-columns: 120px auto;}
    .user_organizer .user_problems_text {width: 100%; }
    .user_organizer .user_problems_text img {width: 80%;}

    .user_participant {grid-template-columns: auto 120px;}
    .user_participant .user_problems_text {width: 100%; text-align: right;  margin: 0;}
    .user_participant .user_problems_text img {width: 80%;}

    /* SERVICE */
    .service_info_box {grid-template-columns: none; margin: 30px 0;}

    .service_info_text {padding: 30px; text-align: center;}
    .service_info_text p {font-size: 16px;}
    .service_info_img {text-align: center;}
    .service_info_img img {position: static; transform: none; width: 70%;}

    .service_info_box.left .service_info_text {order: 1;}
    .service_info_box.left .service_info_img {order: 2;}
    .service_info_box.right .service_info_text {order: 1;}
    .service_info_box.right .service_info_img {order: 2;}

    /* PERFORMANCE */
    .performance_bublle {width: 70%;}
    .performance_bublle.right {margin-left: 30%; }
    .performance_bublle.left {margin-right: 30%;}

    .performance_box {padding: 0;}

    .performance_contents {width: 90%; margin-bottom: 30px;}
    .performance_contents.fund {margin-right: 10%;}
    .performance_contents.date {margin-left: 10%; top: 0;}
    .performance_contents.fan p.fan_title {font-size: 20px;}
    .performance_contents.fan p.fan_info {font-size: 10px;}


    .contents_info {padding: 50px 0;}
    .contents_info .content {display: grid; grid-template-columns: none; align-items: center;}

    .contents_info_con h2 {text-align: center;}
    .contents_info_con h2 img {width: 70px;}
    .contents_info_con strong {text-align: center; font-size: 24px;}
    .contents_info_con p {text-align: center; font-size: 16px;}
    
    .contents_info_img {text-align: center; margin-top: 50px;}
    .contents_info_img img {width: 100%; max-width: 500px;}

    .contents_info.left .contents_info_img {padding-left: 0;}
    .contents_info.right .contents_info_img {padding-right: 0;}

    .contents_info.left .content .contents_info_con {order: 1;}
    .contents_info.left .content .contents_info_img {order: 2;}
    .contents_info.right .content .contents_info_con {order: 1;}
    .contents_info.right .content .contents_info_img {order: 2;}

    /* PRE BOOK  */
    .prebook_con {padding: 30px;}
    .prebook_info>span {font-size: 20px;}
    .prebook_info>p {font-size: 16px;}
}

@media (max-width: 520px) {

    .main_con h1 {font-size: 40px;}
    .main_con p span {font-size: 20px;}

    .main_con .store_link {display: block;}
    .main_con .store_link li {display: inline-block; margin-bottom: 20px;}

    .main_img {width: 100%; margin: 0 auto;}

    .service_info {padding: 0 0 50px;}
    .service_info_img img {width: 100%;}
    .service_info_text p {font-size: 14px;}

    /* USER PROBLEMS */
    .user_problems_text {transform: none;}
    .user_organizer {grid-template-columns: 70px auto;}
    .user_participant {grid-template-columns: auto 70px;}
    .user_organizer .user_problems_text img {width: 100%;}
    .user_participant .user_problems_text img {width: 100%;}

    .performance_contents.fan h1 {font-size: 36px;}
    .performance_bublle {width: 90%;}
    .performance_bublle.right {margin-left: 10%; }
    .performance_bublle.left {margin-right: 10%;}
    .performance_info_title {margin: 100px 0;}
    .performance_info_title h1 {font-size: 40px;}
    .performance_contents p {font-size: 16px;}
    .performance_contents p {font-size: 16px;}
    .performance_contents h3 {font-size: 22px; margin-bottom: 20px;}
    .performance_contents h3 span {font-size: 24px;}

    
    .boast_info {margin: 100px 0;}
    .boast_message_01 {padding: 30px;}
    .boast_message_01 h2 {font-size: 24px;}
    .boast_message_01 h2 span {font-size: 30px;}

    /* REVIEW */
    .review_title {padding: 15px; margin: 0 auto 50px; font-size: 20px;}
    .review_title img {display: none; }
    .review_text_origin {font-size: 10px;}
    .review_text_trans {font-size: 12px;}
    .review_more a {font-size: 20px; padding: 10px 30px;}

    .contents_info {padding: 30px 0;}
    .contents_info_con h2 img {width: 60px;}
    .contents_info_con strong {font-size: 20px;}
    .contents_info_con p {font-size: 14px;}


    .slick_arrow {width: 40px; height: 40px; }
    .slick_arrow img {width: 15px;}

    .title_badge {font-size: 12px;}

    /* PRE BOOK  */
    .prebook_con {padding: 15px; border-radius: 30px; text-align: center;}
    .prebook_con h2 {text-align: center;}
    .prebook_info>span {font-size: 20px;}
    .prebook_info>p {font-size: 12px;}
    .prebook_btn {margin-top: 10px; font-size: 14px;}


}