@charset "utf-8";

/* ==================================================
Common CSS
================================================== */

@media(max-width:1099px){

/*STYLE*/
.pc {
display:none;
}

.bg_movie {
    width:100vw;
    height:100vh;
    position:fixed;
    top:0;
    left:0;
    z-index:-1;
    overflow:hidden;
}

.bg_movie video{
    width:auto;
    height:100%;
}

.bg_movie .mask {
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.85);
    position:absolute;
    top:0;
    left:0;
}

#mv video {
    width:100%;
    height:auto;
}

.cts {
width:90%;
}

.titles {
padding-bottom:20px;
text-align:center;
}

.titles .icon {
    width:50px;
    margin:0 auto 10px;
}

.titles .corner {
    font-size:90%;
    font-weight:600;
    margin-bottom:10px;
}

.titles .corner span {
    border:#000 1px solid;
    padding:5px 10px;
    display:inline-block;
}

.titles .point {
    width:15px;
    height:15px;
    background:rgba(230,30,130,0.5);
    border-radius:100vw;
    margin:0 auto;
    animation:2s pointer infinite forwards;
}

.titles h2.en {
font-size:350%;
font-weight:500;
line-height:100%;
}

.titles h2.jp {
}

.titles h2.jp p {
    font-size:180%;
    font-weight:bold;
    line-height:135%;
    padding-top:15px;
    transform:scale(0.95,1);
}

.titles h2.en:first-letter {
color:#e61e82;
}

.titles .subtitle {
font-size:150%;
font-weight:bold;
line-height:135%;
margin-bottom:5px;
}

.titles .kana {
font-size:100%;
font-weight:600;
transform:scale(0.95,1);
padding-top:5px;
}



/*HEADER*/
header {
    position:fixed;
    top:20px;
    left:15px;
}

header h1 {
    width:90px;
}



/*FIXED CTA*/
.fixed_cta {
    width:70px;
    position:fixed;
    top:10px;
    right:10px;
    z-index:999;
}

.fixed_cta .bomb {
    animation:rotate linear 5s infinite forwards;
    -webkit-animation:rotate linear 5s infinite forwards;
    position:relative;
}

.fixed_cta img:last-child {
    position:absolute;
    top:0;
    left:0;
}



/*MV*/
#mv {
    width:100%;
    min-height:650px;
    position:relative;
    overflow:hidden;
    /*background:#000 url(../img/mv_bg.jpg) center;
    background-size:cover;*/
}

#mv h1 {
    width:70px;
    position:absolute;
    top:20px;
    left:15px;
}

#mv .balloon {
    width:68%;
    margin:100px auto 15px;
}

#mv .cts {
    width:100%;
    height:100%;
}

#mv .movies {
    width:100%;
    margin:0 auto 50px;
}

#mv .movies .movie {
    width:85%;
    margin:auto;
}

#mv .movie video{
    width:100%;
    height:auto;
}

#mv .sound {
    width:80px;
    position:absolute;
    right:15px;
    bottom:15px;
    cursor:pointer;
    z-index:999;
}

#mv .maincopies {
    width:90%;
    margin:auto;
    display:flex;
    justify-content:space-between;
    margin-bottom:20px;
}

#mv .maincopies .maincopy {
    width:48.5%;
}

#mv .subcopies {
    position:absolute;
    width:100%;
    bottom:30px;
    margin:auto;
    left:0;
    right:0;
    z-index:999;
    padding:15px 15px 15px;
    background:linear-gradient(to right,rgba(0,0,0,0),rgba(0,0,0,0.7),rgba(0,0,0,0.7),rgba(0,0,0,0));
}

#mv .subcopies .subcopy {
    width:75%;
    margin:0 auto;
    position:absolute;
    top:-25px;
    left:0;
    right:0;
}

#mv .subcopies .subcopy img {
}

#mv .subcopies .copies {
    width:100%;
    text-align:center;
}

#mv .subcopies .copies .copy2 {
    font-size:150%;
    font-weight:bold;
    line-height:100%;
    padding-bottom:10px;
}

#mv .subcopies .copies .copy3 {
    font-size:110%;
    font-weight:bold;
    line-height:100%;
}


/*SUB MV*/
#submv {
    background:#e61e82;
}

#submv .cts {
    padding:15px 0;
}

#submv .cts div {
    display:flex;
    align-items:center;
}

#submv .cts .copy1 {
    width:100%;
    margin-bottom:10px;
}

#submv .cts .copy2 {
    width:60%;
    margin:auto;
}




/*INTRO*/
#intro {
    padding:50px 0 0;
    background:#000;
}

#intro .cts {
}

#intro .intro_title {
    text-align:center;
    margin-bottom:15px;
}

#intro .intro_title .item1 {
    font-size:110%;
    font-weight:bold;
    line-height:100%;
    border:#fff 1px solid;
    padding:8px 10px 11px;
    display:inline-block;
    margin-bottom:10px;
}

#intro .intro_title .item2 {
    font-size:110%;
    font-weight:bold;
    line-height:100%;
}

#intro .details {
}

#intro .details .detail {
    width:100%;
    position:relative;
    z-index:1;
    text-align:center;
    padding-bottom:10px;
}

#intro .details .detail .item {
}

#intro .details .detail .item p {
    font-size:220%;
    font-weight:bold;
    line-height:100%;
    color:#e61e82;
    padding-bottom:15px;
    transform:scale(0.95,1);
    transform-origin:center;
}

#intro .details .detail .tx {
    font-size:100%;
    font-weight:500;
}

#intro .details .photo {
    width:80%;
    margin:auto;
}

#intro .company_account {
    border:#e61e82 3px solid;
    border-radius:15px;
    margin-bottom:30px;
}

#intro .company_account .items {
    border-bottom:#e61e82 1px dotted;
    padding:10px;
    text-align:center;
}

#intro .company_account .items .item1 {
    font-size:120%;
    font-weight:bold;
    color:#e61e82;
}

#intro .company_account .items .item2 {
    font-size:70%;
    color:#646464;
}

#intro .play_numbers {
}

#intro .play_numbers .play_number {
    width:100%;
    padding:15px 25px 20px;
    text-align:center;
}

#intro .play_numbers .play_number:first-child {
    border-bottom:#e61e82 2px dotted;
}

#intro .play_numbers .play_number .item {
    font-size:100%;
    font-weight:600;
    color:#e61e82;
    padding-bottom:10px;
}

#intro .play_numbers .play_number .number {
}

#intro .play_numbers .play_number .number img {
    width:auto;
    height:50px;
}

#intro .points {
    width:100%;
    display:flex;
}

#intro .points .point {
    width:33.3%;
    height:250px;
    position:relative;
    overflow:hidden;
}

#intro .points .point .bg {
    width:100%;
    height:100%;
}

#intro .points .point:nth-child {
    width:33.4%;
}

#intro .points .point1 .bg {
    background:url(../img/intro_point1.jpg) center;
    background-size:cover;
}

#intro .points .point2 .bg {
    background:url(../img/intro_point2.jpg) center;
    background-size:cover;
}

#intro .points .point3 .bg {
    background:url(../img/intro_point3.jpg) center;
    background-size:cover;
}

#intro .points .point .copies {
    position:absolute;
    left:12px;
    bottom:10px;
}

#intro .points .point .item {
    font-size:120%;
    font-weight:700;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    position:absolute;
    top:15px;
    left:10px;
}

#intro .points .point:nth-child(-n+2) .item {
    font-size:120%;
}

#intro .points .point .item:first-letter {
    color:#e61e82;
    }

#intro .points .point .tx {
    font-size:80%;
    font-weight:500;
    position:absolute;
    left:0;
    right:0;
    bottom:10px;
    width:80%;
    margin:auto;
}




/*ABOUT*/
#about {
    padding:35px 0 0;
    background:#000;
    overflow:hidden;
}

#about .cts {
}

#about .details {
}

#about .details .detail {
    width:100%;
    padding-top:15px;
    position:relative;
    z-index:1;
    padding-bottom:15px;
}

#about .details .detail .logo {
    width:70%;
    margin:0 auto 20px;
}

#about .details .detail h3 {
    font-size:120%;
    font-weight:bold;
    line-height:150%;
    color:#e61e82;
    padding-bottom:10px;
    text-align:center;
}

#about .details .detail .tx {
    padding-bottom:15px;
}

#about .details .about_photo {
    position:relative;
}

#about .details .about_photo .about_slider {
    width:90%;
    margin:auto;
    text-align:center;
    position:relative;
    overflow:hidden;
}

#about .details .about_photo .photo img {
    width:auto;
    height:100%;
    position:relative;
}

#about .details .about_photo .bg {
    width:140vw;
    height:140vw;
    background:radial-gradient(at center bottom,rgba(230,30,130,0.5),#000,#000);
    position:absolute;
    left:-35vw;
    right:0;
    bottom:0;
    margin:auto;
}



/*PLAN*/
#plan {
    padding:50px 0;
    position:relative;
    background:#000;
}

#plan .bg_top {
    width:100%;
    height:70px;
    background:linear-gradient(#1e1e1e,#000);
    position:absolute;
    top:0;
    left:0;
}

#plan .bg_bottom {
    width:100%;
    height:70px;
    background:linear-gradient(#000,#1e1e1e);
    position:absolute;
    bottom:0;
    left:0;
}

#plan .cts {
    position:relative;
}

#plan .plan_titles {
    text-align:center;
    padding-bottom:30px;
}

#plan .plan_titles .subtitle {
    display:flex;
    justify-content:center;
    align-items:center;
    padding-bottom:15px;
}

#plan .plan_titles .subtitle .line {
    width:30px;
    height:1px;
    background:#fff;
}

#plan .plan_titles .subtitle p {
    font-size:100%;
    font-weight:600;
    line-height:100%;
    padding:0 10px;
    color:#fff;
}

#plan .plan_titles h2 p {
    font-size:200%;
    font-weight:600;
    line-height:100%;
    color:#fff;
    transform:scale(0.95,1);
}

#plan .plans {
    margin-bottom:55px;
}

#plan .plans .plan {
    margin-bottom:30px;
}

#plan .plans .plan:last-child {
    margin-bottom:0;
}

#plan .plans .plan .types {
    width:100%;
    text-align:center;
    border:#fff 3px solid;
    padding:65px 20px 15px;
    overflow:hidden;
    display:flex;
    justify-content:center;
    align-items:center;
    position:relative;
}

#plan .plans .plan.silver .types {
    border:#d2d2d2 3px solid;
}

#plan .plans .plan.gold .types {
    border:#ecaa01 3px solid;
}

#plan .plans .plan.platinum .types {
    border:#e61e82 3px solid;
}

#plan .plans .plan .types .type {
    width:200px;
    margin:0 auto 15px;
    position:absolute;
    top:0;
    left:0;
    right:0;
}

#plan .plans .plan .types .item {
    font-size:100%;
    font-weight:bold;
    padding-right:15px;
}

#plan .plans .plan.silver .types .item {
    color:#d2d2d2;
}

#plan .plans .plan.gold .types .item {
    color:#ecaa01;
}

#plan .plans .plan.platinum .types .item {
    color:#e61e82;
}

#plan .plans .plan .types .commit {
}

#plan .plans .plan .types .commit img {
    width:auto;
    height:45px;
}

#plan .plans .plan .arrow {
    width:100px;
    margin:0 auto 10px;
}

#plan .plans .plan .prices {
    width:60%;
    margin:auto;
    padding:4px;
}

#plan .plans .plan.silver .prices {
    background:#d2d2d2;
}

#plan .plans .plan.gold .prices {
    background:#ecaa01;
}

#plan .plans .plan.platinum .prices {
    background:#e61e82;
}

#plan .plans .plan .prices .frame {
    border:#000 1px solid;
    padding:15px 30px;
}

#plan .plans .plan .prices .frame .price {
    margin:auto;
}

#plan .breakdown {
    width:100%;
    margin:0 auto 20px;
    border:#e61e82 3px solid;
    padding:40px 30px 20px;
    text-align:center;
    position:relative;
}

#plan .breakdown .item {
    font-size:110%;
    font-weight:bold;
    line-height:100%;
    position:absolute;
    top:-20px;
    left:0;
    right:0;
    display:flex;
    justify-content:center;
    align-items:center;
    height:40px;
}

#plan .breakdown .item span {
    background:#e61e82;
    color:#000;
    display:inline-block;
    padding:10px 15px;
}

#plan .breakdown .cost {
    font-size:150%;
    font-weight:600;
    line-height:100%;
    padding-bottom:10px;
}

#plan .breakdown .complement {
}

#plan .attention {
    width:100%;
    margin:auto;
}

#plan .attention p {
    display:flex;
    font-size:70%;
    color:#787878;
}





/*FEATURE*/
#feature {
    padding:50px 0 0;
    background:#000;
}

#feature #result {
    margin-bottom:0;
}

#feature #result .maincopy p {
    font-size:160%;
    font-weight:bold;
    text-align:center;
    line-height:135%;
    padding-bottom:40px;
    transform:scale(0.95,1);
}

#feature #result .results {
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap;
}

#feature #result .results .result {
    width:48%;
    border:#e61e82 3px solid;
    position:relative;
    text-align:center;
    padding-bottom:20px;
    margin-bottom:35px;
}

#feature #result .results .result .area {
    width:70px;
    height:34px;
    border:#fff 2px solid;
    background:#000;
    position:absolute;
    top:-17px;
    left:0;
    right:0;
    margin:auto;
    text-align:center;
    display:flex;
    justify-content:center;
    align-items:center;
    font-weight:600;
    color:#fff;
    z-index:1;
}

#feature #result .results .result .photo {
    margin-bottom:15px;
}

#feature #result .results .result .job {
    font-size:110%;
    font-weight:bold;
    padding-bottom:10px;
}

#feature #result .results .result .period {
    border:#e61e82 1px solid;
    color:#e61e82;
    font-size:110%;
    font-weight:bold;
    line-height:100%;
    display:inline-block;
    padding:5px 10px;
    margin-bottom:20px;
}

#feature #result .results .result .data {
    font-size:150%;
    font-weight:600;
    line-height:100%;
    color:#e61e82;
}

#feature #result .results .result .data .number {
    font-size:250%;
}

#feature #result .results .result .sub {
    font-size:80%;
    font-weight:bold;
    line-height:100%;
    color:#e61e82;
    padding-top:10px;
}

#feature .features {
}

#feature .features .feature {
    padding-bottom:50px;
}

#feature .features .feature:nth-child(odd) {
}

#feature .features .feature .photo {
    width:95%;
    height:70vw;
    position:relative;
    z-index:1;
}

#feature .features .feature .photo1 {
    background:url(../img/about_1.jpg) center;
    background-size:cover;
    margin:0 0 0 auto;
}

#feature .features .feature .photo2 {
    background:url(../img/about_2.jpg) center;
    background-size:cover;
}

#feature .features .feature .details {
    width:100%;
    position:relative;
}

#feature .features .feature .details .detail {
    width:95%;
    padding:30px;
    background:#181818;
    position:relative;
}

#feature .features .feature:nth-child(1) .details .detail {

}

#feature .features .feature:nth-child(2) .details .detail {
    margin:0 0 0 auto;
}

#feature .features .feature .details .detail .deco {
    width:14px;
    height:14px;
    background:#e61e82;
    position:absolute;
    bottom:-10px;
}

#feature .features .feature:nth-child(1) .details .detail .deco {
    right:-7px;
}

#feature .features .feature:nth-child(2) .details .detail .deco {
    left:-7px;
}

#feature .features .feature .details .detail h3 p {
    font-size:135%;
    font-weight:bold;
    line-height:150%;
    transform:scale(0.95,1);
    transform-origin:center;
    padding-bottom:15px;
    text-align:center;
}





/*REASON*/
#reason {
    padding:50px 0;
    background:#181818;
}

#reason .cts {
}

#reason .maincopy p {
    font-size:160%;
    font-weight:bold;
    text-align:center;
    line-height:135%;
    padding-bottom:30px;
    transform:scale(0.95,1);
}

#reason .result_cts {
}

#reason .result_cts .questionnaire {
    width:100%;
    margin-bottom:70px;
}

#reason .result_cts .questionnaire:last-child {
    margin-bottom:0;
}

#reason .questionnaire .results {

}

#reason .questionnaire .results .result {
    margin-bottom:35px;
}

#reason .questionnaire .results .result .question {
    display:flex;
    align-items:center;
    margin-bottom:15px;
}

#reason .questionnaire .results .result .item {
    font-size:100%;
    font-weight:600;
}

#reason .questionnaire .results .result h4 {
    font-size:100%;
    font-weight:600;
    border-left:#aaa 1px solid;
    padding-left:15px;
    margin-left:15px;
    color:#e61e82;
}

#reason .questionnaire .results .result .graph {
    background:#000;
    display:flex;
    justify-content:center;
    align-items:center;;
    padding:20px;
}

#reason .questionnaire .results .result .graph img {
    width:270px;
}

#reason .questionnaire .summary {
    font-size:120%;
    font-weight:600;
    line-height:135%;
    color:#e61e82;
    text-align:center;
    padding-bottom:15px;
}

#reason .questionnaire .attention {
    font-size:70%;
    color:#646464;
}



/*CASE*/
#case {
    padding:50px 0;
    background:#000;
}

#case .copy {
    font-size:110%;
    font-weight:600;
    transform:scale(0.95,1);
    padding-top:5px;
    text-align:center;
    margin-bottom:30px;
}

#case .awards {
}

#case .awards .award {
    width:100%;
    margin-bottom:30px;
}

#case .awards .award:last-child {
    margin-bottom:0;
}

#case .awards .award .award_cts {
    background:#181818;
    padding:25px 25px 20px;
    margin-bottom:15px;
}

#case .awards .award .award_cts .medals {
    display:flex;
    justify-content:center;
    flex-wrap:wrap;
    margin-bottom:15px;
}

#case .awards .award .award_cts .medals .medal {
    width:28%;
    margin:0 2.5%;
}

#case .awards .award .award_cts .medals .medal:nth-child(n+4) {
    margin-top:10px;
}

#case .awards .award .attention {
    font-size:70%;
    color:#646464;
}




/*MEDIA*/
#media {
    padding:50px 0;
    background:#181818;
}

#media .cts {
}

#media .copy {
    text-align:center;
    padding-bottom:20px;
}

#media .medias {
}

#media .medias .media {
    width:100%;
    border:#fff 2px solid;
    text-align:center;
    margin:0 0 15px 0;
}

#media .medias .media:nth-child(3n) {
    margin-right:0;
}

#media .medias .media .item {
    font-weight:bold;
    line-height:100%;
    border-bottom:#fff 1px dashed;
    padding:10px;
}

#media .medias .media .date {
    padding:10px;
    font-size:80%;
    line-height:100%;
}

#media .etc {
    text-align:center;
}



/*ACCOUNT*/
#account {
    padding:50px 0;
    background:#000;
}

#account .titles {
    padding-bottom:15px;
}

#account .cts {
}

#account .copy {
    text-align:center;
    padding-bottom:30px;
}

#account .accounts {
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap;
    margin-bottom:15px;
}

#account .accounts .account {
    width:48.5%;
    position:relative;
    margin-bottom:15px;
    border:#fff 1px solid;
}

#account .accounts .account:nth-child(4n) {
    margin-right:0;
}

#account .accounts .account a {
    box-sizing:border-box;
    display:block;
    padding:15px 15px 12px;
}

#account .accounts .account a .photo {
    width:60px;
    margin:0 auto 10px;
}

#account .accounts .account a .photo img {
    border-radius:30vw;
}

#account .accounts .account a .detail {
    text-align:center;
}

#account .accounts .account a .detail .id {
    font-size:90%;
    font-weight:bold;
}

#account .accounts .account a .detail .name {
    font-size:60%;
}

#account .accounts .account a .sns {
    width:20px;
    position:absolute;
    top:10px;
    right:10px;
}

#account .summary {
    font-size:100%;
    font-weight:600;
    text-align:center;
}





/*FAQ*/
#faq {
    padding:50px 0 25px;
    background:#181818;
}

#faq .cts {
}

#faq .copy {
    text-align:center;
    padding-bottom:25px;
}

#faq .faqs {
}

#faq .faqs .faq {
}

#faq .faqs .faq .question {
    display:flex;
    align-items:center;
    position:relative;
    margin-bottom:15px;
    border:#e61e82 2px solid;
    cursor:pointer;
}

#faq .faqs .faq .question .item {
    color:#e61e82;
    width:40px;
    height:auto;
    display:flex;
    justify-content:center;
    align-items:center;
    text-align:center;
    font-size:120%;
    font-weight:500;
}

#faq .faqs .faq .question .tx {
    width:calc(100% - 20px);
    font-size:100%;
    font-weight:600;
    color:#e61e82;
    border-left:#e61e82 1px dashed;
    padding:10px 15px;
    padding-right:40px;
}

#faq .faqs .faq .question .arrow {
    width:10px;
    height:10px;
    border-top:#e61e82 2px solid;
    border-right:#e61e82 2px solid;
    transform:rotate(45deg);
    position:absolute;
    right:15px;
}

#faq .faqs .faq .question .arrow.open {
    transform:rotate(135deg);
    right:20px;
    margin-bottom:6px;
}

#faq .faqs .faq .answer_cts {
    display:none;
}

#faq .faqs .faq .answer {
    margin-bottom:35px;
    display:flex;
    justify-content:space-between;
}

#faq .faqs .faq:last-child .answer {
    margin-bottom:0;
}

#faq .faqs .faq .answer .item {
    width:40px;
    height:40px;
    background:#e61e82;
    display:flex;
    justify-content:center;
    align-items:center;
    text-align:center;
    font-size:120%;
    font-weight:500;
    color:#181818;
}

#faq .faqs .faq .answer .detail {
    width:calc(100% - 55px);
}




/*COMPANY*/
#company {
    background:#000 url(../img/company_bg.jpg) center bottom no-repeat;
    background-size:100%;
    padding:50px 0 100px;
}

#company .titles .icon {
    width:36px;
}

#company .companies {
}

#company .companies .company {
    background:rgba(30,30,30,0.8);
    padding:15px 20px;
    margin-bottom:12px;
}

#company .companies .company:last-child {
    display:block;
    margin-bottom:0;
}

#company .companies .company .item {
    width:100%;
    font-weight:600;
}

#company .companies .company:last-child .item {
    width:100%;
}

#company .companies .company .tx {
}



/*OFFICE*/
#office {
    background:#000;
    padding-top:15px;
}

#office .photos {
    width:100%;
    margin:auto;
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap;
}

#office .photos .photo {
    width:calc(50% - 6px);
    margin-bottom:15px;
}

#office .photos .photo:nth-child(n+3) {
    margin-bottom:0;
}




/*CTA*/
.cta {
    padding:30px 0;
    position:relative;
}

.cta .bg {
    width:100%;
    height:70px;
    background:#e61e82;
    position:absolute;
    bottom:0;
    left:0;
    z-index:0;
}

.cta .cts {
}

.cta .details {
}

.cta .details .detail {
    width:100%;
}

.cta .details .detail .subcopy {
    display:flex;
    justify-content:center;
    align-items:center;
    margin-bottom:15px;
}

.cta .details .detail .subcopy img {
    width:100px;
    border:#e61e82 1px solid;
    margin:0 5px;
}

.cta .details .detail .brand {
    width:80%;
    margin:0 auto 20px;
}

.cta .details .detail .cta_btn {
    width:100%;
    margin:auto;
    animation:cta 1s infinite alternate;
    -webkit-animation:cta 1s infinite alternate;
}

.cta .details .detail .cta_btn a {
    background:#ffff00;
    border-radius:30vw;
    display:flex;
    justify-content:center;
    align-items:center;
    position:relative;
    padding:25px;
}

.cta .details .detail .cta_btn a .soon {
    width:55px;
    height:55px;
    position:absolute;
    left:20px;
    display:flex;
    justify-content:center;
    align-items:center;
}

.cta .details .detail .cta_btn a .soon .circle {
    position:relative;
}

.cta .details .detail .cta_btn a .soon .circle .bomb {
    animation:rotate linear 5s infinite forwards;
    -webkit-animation:rotate linear 5s infinite forwards;
}

.cta .details .detail .cta_btn a .soon .circle .tx {
    position:absolute;
    top:5px;
    left:5px;
    width:45px;
}

.cta .details .detail .cta_btn a .item {
    width:160px;
}

.cta .details .detail .cta_btn a .icon {
    width:30px;
    position:absolute;
    right:25px;
}

.cta .details .blank {
    display:none;
}

.cta .details .photo {
    width:70%;
    margin:auto;
}




/*MAIN CTA*/
#cta {
    position:relative;
}

#cta .bg {
    width:100%;
    height:70px;
    background:#e61e82;
    position:absolute;
    bottom:0;
    left:0;
    z-index:0;
}

#cta .cts {
    position:relative;
    padding:30px 0;
}

#cta .details {
    display:flex;
    justify-content:space-between;
    align-items:center;
}

#cta .details .detail {
    width:100%;
    position:relative;
    z-index:1;
}

#cta .details .detail .subcopy {
    display:flex;
    justify-content:center;
    align-items:center;
    margin-bottom:20px;
}

#cta .details .detail .subcopy img {
    width:100px;
    border:#e61e82 1px solid;
    margin:0 5px;
}

#cta .details .detail .brand {
    width:50%;
    margin:0 auto 10px;
}

#cta .details .detail .tx {
    font-size:120%;
    font-weight:600;
    color:#e61e82;
    text-align:center;
    padding-bottom:10px;
}

#cta .details .detail .cta_btn {
    width:100%;
    margin:auto;
    animation:cta 1s infinite alternate;
    -webkit-animation:cta 1s infinite alternate;
}

#cta .details .detail .cta_btn a {
    background:#ffff00;
    border-radius:30vw;
    display:flex;
    justify-content:center;
    align-items:center;
    position:relative;
    padding:25px;
}

#cta .details .detail .cta_btn a .soon {
    width:55px;
    height:55px;
    position:absolute;
    left:20px;
    display:flex;
    justify-content:center;
    align-items:center;
}

#cta .details .detail .cta_btn a .soon .circle {
    position:relative;
}

#cta .details .detail .cta_btn a .soon .circle .bomb {
    animation:rotate linear 5s infinite forwards;
    -webkit-animation:rotate linear 5s infinite forwards;
}

#cta .details .detail .cta_btn a .soon .circle .tx {
    position:absolute;
    top:5px;
    left:5px;
    width:45px;
}

#cta .details .detail .cta_btn a .item {
    width:160px;
}

#cta .details .detail .cta_btn a .icon {
    width:30px;
    position:absolute;
    right:25px;
}

#cta .details .photo {
    width:70%;
    margin:auto;
}

#cta .details .blank {
    display:none;
}





/*CONTACT*/
#contact {
    padding:35px 0;
    margin-top:50px;
}

#contact .titles .icon {
    width:45px;
    margin:0 auto 15px;
}

#contact .copies {
    margin-bottom:25px;
}

#contact .copies .copy {
    font-weight:500;
}

#contact .copies .caution {
    display:inline-block;
    background:#e61e82;
    color:#fff;
    padding:10px 15px;
    font-size:90%;
    font-weight:500;
}

#contact .temp {
    background:#181818;
    padding:25px 25px;
}

#contact .temp .step_ex {
    margin-bottom:20px;
    text-align:center;
}

#contact .temp .step_ex .tx {
    font-size:110%;
    font-weight:600;
    padding-bottom:5px;
}

#contact .temp .step_ex .attention {
    font-size:80%;
    color:#969696;
}

#contact form {
}

#contact .forms {

}

#contact .forms .form:first-child {
    border-top:#323232 1px solid;
}

#contact .forms .form {
    border-bottom:#323232 1px solid;
    padding:15px 0;
}

#contact .forms .form .items {
    width:100%;
    display:flex;
    align-items:center;
    margin-bottom:7px;
}

#contact .forms .form .items .required {
    font-size:70%;
    line-height:100%;
    background:#e61e82;
    color:#fff;
    display:inline-block;
    padding:5px 6px;
}

#contact .forms .form .items .any {
    font-size:70%;
    line-height:100%;
    background:#646464;
    color:#000;
    display:inline-block;
    padding:5px 6px;
}

#contact .forms .form .items .item {
    font-weight:600;
    padding-left:10px;
}

#contact .forms .form .detail {
    width:100%;
}

#contact .forms .form .detail .yesno {
    display:flex;
    align-items:center;
}

#contact .forms .form .detail .note {
    font-weight:600;
    color:#e61e82;
    padding-bottom:5px;
}

#contact .forms .form .detail .yesno p {
    display:flex;
    align-items:center;
    margin-right:30px;
}

#contact .forms .form .detail .yesno label {
    cursor:pointer;
}

#contact .forms .form .consent_cap {
    font-size:100%;
}
    
#contact .forms .form .consent {
    display:flex;
    align-items:center;
}

#contact .forms .form .consent label {
    font-weight:600;
    margin-left:10px;
    cursor:pointer;
}

#contact .privacy_policy {
    border:#646464 1px solid;
    padding:15px 20px;
    margin:12px 0 15px;
    height:200px;
    overflow:auto;
}

#contact .privacy_policy .privacies {
}

#contact .privacy_policy .privacies .privacy {
    border-bottom:#d2d2d2 1px solid;
    padding-bottom:10px;
    margin-bottom:10px;
}

#contact .privacy_policy .privacies .privacy:last-child {
    border-bottom:none;
    padding-bottom:0;
    margin-bottom:0;
}

#contact .privacy_policy .privacies .privacy .privacy_item {
    font-size:80%;
    font-weight:500;
}

#contact .privacy_policy .privacies .privacy .ex {
    font-size:80%;
}

#contact .btns {
    display:flex;
    justify-content:center;
    align-items:center;
    margin-top:20px;
}

#contact .btns .btn {
    margin:0 7px;
}



/*FORM*/
#contact input[type="text"], 
#contact input[type="tel"],
#contact input[type="email"],
#contact textarea {
    padding:12px 15px;
}

#contact .forms .form .style_company {
width:100%;
}

#contact .forms .form .style_name {
width:100%;
}

#contact .forms .form .style_mail {
width:100%;
}

#contact .forms .form .style_tel {
width:100%;
}

#contact .forms .form .style_chatwork {
width:100%;
}

#contact .forms .form .style_confirm {
}

#contact .forms .form .style_area {
width:100%;
}

#contact .forms .form .style_url {
width:100%;
}

#contact .forms .form .style_account {
width:100%;
height:120px;
}

#contact .forms .form .style_detail {
width:100%;
height:250px;
}

#contact .forms .form .style_privacy {
}

#contact .forms .form .warning {
font-size:90%;
color:#e61e82;
}

#contact .forms .form .warning.block {
display:block;
padding-top:5px;
}

#contact .btns .btn .style_submit {
font-size:100%;
font-weight:600;
padding:20px 25px;
background:#e61e82;
color:#fff;
cursor:pointer;
border:none;
border-radius:10px;
}

#contact .btns .btn .style_submit:disabled {
background:#323232;
pointer-events:none;
}

#contact .btns .btn .style_fix {
font-size:100%;
font-weight:600;
padding:15px 20px;
background:#aaa;
color:#fff;
cursor:pointer;
border:none;
border-radius:10px;
}


/*CONFIRM*/
#contact.confirm {
}

#contact.confirm .copies {
    margin-bottom:20px;
}


/*FINISH*/
#contact.finish {
    text-align:center;
}

#contact.finish .titles {
    margin-bottom:10px;
}

#contact.finish .step_ex {
    margin-bottom:15px;
}

#contact.finish .schedule {
    border:#e61e82 3px solid;
    padding:25px 50px 30px;
    text-align:center;
    display:inline-block;
    margin-bottom:20px;
}

#contact.finish .schedule .schedule_item {
    font-weight:600;
    color:#e61e82;
    padding-bottom:15px;
}

#contact.finish .schedule .schedule_btn {
    animation:cta 1s infinite alternate;
    -webkit-animation:cta 1s infinite alternate;
}

#contact.finish .schedule .schedule_btn .btn {
    display:inline-block;
}

#contact.finish .schedule .schedule_btn .btn a {
    background:#e61e82;
    display:flex;
    justify-content:center;
    align-items:center;
    padding:15px 50px;
    border-radius:10vw;
}

#contact.finish .schedule .schedule_btn .btn a img {
    width:30px;
    margin-right:15px;
}

#contact.finish .schedule .schedule_btn .btn a p {
    font-size:100%;
    font-weight:bold;
    color:#fff;
}

#contact.finish .attention {
    font-size:90%;
    padding-bottom:50px;
}

#contact.finish .backbtn {
    text-align:center;
}

#contact.finish .backbtn .btn {
    display:inline-block;
}

#contact.finish .backbtn .btn a {
    display:flex;
    justify-content:center;
    align-items:center;
    border:#646464 1px solid;
    padding:8px 15px;
}

#contact.finish .backbtn .btn a .arrow {
    width:8px;
    height:8px;
    border-bottom:#646464 1px solid;
    border-left:#646464 1px solid;
    transform:rotate(45deg);
    margin-right:10px;
}

#contact.finish .backbtn .btn a p {
    font-size:90%;
    color:#646464;
}






/*BACK TO TOP*/
.BackToTop {
position:fixed;
width:64px;
right:0;
bottom:0;
z-index:100;
display:none;
}



/*FOOTER*/
footer {
padding:30px 0;
background:#000;
}

footer .copyright {
font-size:60%;
text-align:center;
color:#464646;
}



















}