@charset "UTF-8";
/*
サイト名：
URL：
制作開始日：
制作完了予定：

*/
html {
    font-size: 62.5%;
}

body {
    font-family: "M PLUS 1p", sans-serif;
    color: #555;
}

/*=======================================


	共通


=======================================*/
.flex {
    display: flex;
    align-items: flex-start;
}

.row {
    flex-direction: row-reverse;
}

.ps {
    display: block;
}

.sp {
    display: none;
}

.pc-br {
    display: block;
}

.flex {
    display: flex;
}

video {
    display: block;
}

.object {
    position: absolute;
    z-index: -1;
}

/*---------------------------------------------

				partsの共通ｃｓｓ

----------------------------------------------*/
body {
    /*--文書う文字サイズの基準--*/
}

body .font-11 {
    font-size: 1.1rem;
}

body .font-16 {
    font-size: 1.4rem;
}

@media screen and (min-width: 640px) {
    body .font-16 {
        font-size: 1.4vw;
    }
}

@media screen and (min-width: 1200px) {
    body .font-16 {
        font-size: 1.6rem;
    }
}

body .font-24 {
    font-size: 2.4rem;
}

@media screen and (min-width: 640px) {
    body .font-24 {
        font-size: 2vw;
    }
}

@media screen and (min-width: 1200px) {
    body .font-24 {
        font-size: 2.4rem;
    }
}

body .font-28 {
    font-size: 2.8rem;
    line-height: 120%;
}

body .font-28 span {
    font-weight: bold;
}

@media screen and (min-width: 640px) {
    body .font-30 {
        font-size: 2.4vw;
    }
}

@media screen and (min-width: 1200px) {
    body .font-30 {
        font-size: 2.8rem;
    }
}

body .font-32 {
    font-size: 3.2rem;
    line-height: 120%;
}

body .font-32 span {
    font-weight: bold;
}

@media screen and (min-width: 640px) {
    body .font-32 {
        font-size: 3vw;
    }
}

@media screen and (min-width: 1200px) {
    body .font-32 {
        font-size: 3.2rem;
    }
}

body .font-40 {
    font-size: 4rem;
    line-height: 120%;
}

body .font-40 span {
    font-weight: bold;
}

@media screen and (min-width: 640px) {
    body .font-40 {
        font-size: 3.4vw;
    }
}

@media screen and (min-width: 1200px) {
    body .font-40 {
        font-size: 4rem;
    }
}

body .font-48 {
    font-size: 4.8rem;
    line-height: 120%;
}

body .font-48 span {
    font-weight: bold;
}

@media screen and (min-width: 640px) {
    body .font-48 {
        font-size: 4vw;
    }
}

@media screen and (min-width: 1200px) {
    body .font-48 {
        font-size: 4.8rem;
    }
}

body .font-56 {
    font-size: 5.6rem;
    font-weight: 600;
    line-height: 120%;
}

body .font-56 span {
    font-weight: bold;
}

@media screen and (min-width: 640px) {
    body .font-56 {
        font-size: 4vw;
    }
}

@media screen and (min-width: 1200px) {
    body .font-56 {
        font-size: 5.6rem;
    }
}

.montserrat {
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    font-size: 120%;
    vertical-align: -5%;
}

.sns-line {
    background-color: #060000;
    height: 60px;
    align-items: center;
    padding: 0 24px;
    justify-content: end;
    border-bottom: solid 4px #ff7c00;
}

.sns-set li {
    margin: 0 16px;
}

.sns-set li img {
    display: block;
}

header .top {
    height: 55.8vw;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
}

header .top .top-text1 {
    position: absolute;
    right: 0;
    left: 0;
    display: block;
    margin: auto;
    top: 3vw;
    width: 43vw;
    max-width: 90%;
}

header .top .top-text2 {
    position: absolute;
    right: 0;
    left: 0;
    display: block;
    margin: auto;
    bottom: 5vw;
    max-width: 90%;
}

header .bg_movie {
    position: absolute;
    background-color: #000;
    width: 100%;
    height: 100%;
    z-index: -1;
    display: flex;
    align-items: center;
}

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

header .bg_movie::after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: url("img/pixelgrid.png") 0px 0px repeat fixed transparent;
    background-size: auto;
    display: none;
}

header .sanka-kochira {
    display: block;
    background-color: #ff7c00;
    padding: 20px;
}

header .sanka-kochira > img {
    display: block;
    margin: 0 auto;
}

header .app-link {
    background-color: #060000;
    border-top: solid 5px #ff26ff;
    border-bottom: solid 5px #ff26ff;
    color: #fff;
    padding: 1vw;
    bottom: 0;
    z-index: 10;
    width: 100%;
}

header .app-link .flex {
    align-items: center;
}

header .app-link .inner {
    justify-content: space-around;
    max-width: 980px;
    margin: 0 auto;
}

header .app-link .inner p {
    font-size: 2rem;
    font-weight: 800;
    text-align: left;
}

@media screen and (min-width: 640px) {
    header .app-link .inner p {
        font-size: 2.4vw;
    }
}

@media screen and (min-width: 1200px) {
    header .app-link .inner p {
        font-size: 3rem;
    }
}

header .app-link .inner img {
    display: block;
}

header .app-link .inner .link-button-outside {
    margin-right: 8px;
}

header .app-link .inner .montserrat {
    color: #ff26ff;
}

header .app-link .inner a:first-child {
    margin-right: 8px;
}

.section-1 {
    background-color: #1e1e1e;
    overflow: hidden;
    position: relative;
}

.section-1::after {
    padding-top: 50%;
    content: "";
    display: block;
}

.section-1 .about-text {
    position: absolute;
    top: 5vw;
    left: 5vw;
    width: 52vw;
    z-index: 1;
    color: #fff;
}

.section-1 .about-text h2 {
    color: #ff7c00;
    position: relative;
    text-align: center;
    margin: 4vw 0;
    position: relative;
    z-index: 1;
}

.section-1 .about-text h2::before {
    content: "";
    position: absolute;
    bottom: -10px;
    right: 0;
    left: 0;
    margin: 0 auto;
    height: 4px;
    width: 100%;
    background-color: #ff7c00;
}

.section-1 .about-text p {
    display: block;
    font-size: 1.6rem;
    font-weight: bold;
    margin-top: 8px;
    line-height: 190%;
}

@media screen and (min-width: 640px) {
    .section-1 .about-text p {
        font-size: 1.6vw;
    }
}

@media screen and (min-width: 1200px) {
    .section-1 .about-text p {
        font-size: 2rem;
    }
}

.section-1 .about-instructor {
    position: absolute;
    width: 67vw;
    top: 0;
    right: -10vw;
    height: 100%;
}

.section-1 .about-instructor img {
    display: block;
    height: 100%;
}

.section-2 {
    position: relative;
    padding: 10vw 16px;
    text-align: center;
    background-image: url("../img/sp-bg.png");
    background-size: cover;
    background-color: #000;
    background-repeat: no-repeat;
    background-position: center;
}

.section-2::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    left: 0;
    top: 0;
    z-index: 0;
}

.section-2 .inner {
    position: relative;
    z-index: 1;
    color: #fff;
    margin: 0 auto;
    max-width: 720px;
}

.section-2 .inner > div {
    margin-bottom: 56px;
}

.section-2 .inner > div h3 {
    margin: 0 auto 24px;
    max-width: 580px;
    border-bottom: solid 4px #ff7c00;
}

.section-2 .inner > div h3 img {
    display: block;
    margin: 0 auto 24px;
}

.section-2 .inner > div > span {
    font-weight: 800;
    display: block;
    margin-bottom: 24px;
    line-height: 140%;
}

.section-2 .inner > div p {
    text-align: left;
    margin-bottom: 24px;
    line-height: 180%;
}

.section-3 .judge-member {
    background-color: #1e1e1e;
    text-align: center;
    padding: 56px 0;
}

.section-3 .judge-member h3 {
    margin: 0 auto 24px;
    max-width: 580px;
    border-bottom: solid 4px #ff7c00;
}

.section-3 .judge-member h3 img {
    display: block;
    margin: 0 auto 24px;
}

.section-3 .judge-member ul {
    justify-content: center;
}

.section-3 .judge-member ul li {
    margin: 6px;
    font-size: 1.6rem;
}

.section-3 .judge-member ul li img {
    width: auto;
    height: auto;
    display: block;
    margin-bottom: 16px;
    border: solid 4px #ff7c00;
    box-sizing: border-box;
}

.section-3 .judge-member ul li span {
    color: #fff;
}

.section-3 .shokin-shohin {
    background-color: #ff7c00;
    padding: 4vw 16px;
    text-align: center;
    position: relative;
}

.section-3 .shokin-shohin .king-queen {
    position: absolute;
    right: 0;
    left: 0;
    bottom: 7%;
    margin: auto;
    z-index: 0;
}

.section-3 .shokin-shohin .inner {
    position: relative;
    z-index: 1;
}

.section-3 .shokin-shohin .inner .oukan {
    display: block;
    margin: 0 auto 32px;
}

.section-3 .shokin-shohin .inner h3 {
    margin: 0 auto 24px;
    max-width: 580px;
    border-bottom: solid 4px #000;
}

.section-3 .shokin-shohin .inner h3 img {
    display: block;
    margin: 0 auto 24px;
}

.section-3 .shokin-shohin .inner > div {
    max-width: 710px;
    margin: 0 auto 56px;
}

.section-3 .shokin-shohin .inner > div h4 {
    margin-bottom: 16px;
}

.section-3 .shokin-shohin .inner > div > span {
    font-weight: 800;
    display: block;
    margin-bottom: 24px;
    line-height: 140%;
}

.section-3 .shokin-shohin .inner > div p {
    text-align: left;
    margin-bottom: 24px;
    line-height: 180%;
    color: #fff;
    font-weight: bold;
}

/*
   最新ニュースのメルマガ登録フォーム
----------------------------------*/
.section-8 {
    background-color: #1e1e1e;
    color: #fff;
    text-align: center;
    padding-bottom: 5vw;
    position: relative;
    padding: 0 2vw 4vw;
    overflow: hidden;
}

.section-8 h3 {
    font-size: 2rem;
    font-weight: 800;
    color: #fff;
    padding: 2.5vw;
    display: inline-block;
}

@media screen and (min-width: 640px) {
    .section-8 h3 {
        font-size: 3.2vw;
    }
}

@media screen and (min-width: 1200px) {
    .section-8 h3 {
        font-size: 3rem;
    }
}

.section-8 #sendmail-form > span {
    font-size: 1.8rem;
    display: block;
    margin: 2vw 0;
}

.section-8 #sendmail-form ul {
    max-width: 860px;
    margin: 0 auto;
    justify-content: space-between;
    flex-wrap: wrap;
}

.section-8 #sendmail-form ul li {
    width: 50%;
    padding: 0.5vw;
    box-sizing: border-box;
}

.section-8 #sendmail-form ul li input {
    display: block;
    padding: 0 16px;
    width: 100%;
    box-sizing: border-box;
    border-radius: 6px;
    border: solid 3px #fff;
    height: 50px;
}

.section-8 #sendmail-form ul .email {
    width: 100%;
}

.section-8 #sendmail-form ul .naiyou {
    width: 100%;
}

.section-8 #sendmail-form ul .naiyou textarea {
    display: block;
    padding: 8px 16px;
    width: 100%;
    box-sizing: border-box;
    border-radius: 6px;
    border: solid 3px #fff;
    font-size: 1.4rem;
}

.section-8 #sendmail-form button {
    display: block;
    background-color: #1e1e1e;
    color: #fff;
    padding: 0 16px;
    width: 40%;
    box-sizing: border-box;
    border-radius: 6px;
    border: solid 3px #fff;
    height: 50px;
    font-size: 1.8rem;
    font-weight: bold;
    letter-spacing: 5px;
    margin: 16px auto;
}

.section-8 #sendmail-form button:focus,
.section-8 #sendmail-form button:hover {
    background-color: #fff;
    color: #032b2e;
    cursor: pointer;
    cursor: hand;
}

.sns-line.bottom {
    border-bottom: solid 5px #000;
    background-color: #ff7c00;
}

/*===============================

	mailsend.html

================================*/
.mailsend {
    text-align: center;
    color: #000;
}

.mailsend .contact-form a {
    font-weight: bold;
    color: #005a92;
    font-size: 2.4rem;
}

.mailsend .contact-form p {
    margin: 3em 0;
}

.sns-line {
    background-color: #000;
    height: 60px;
    align-items: center;
    padding: 0 24px;
    justify-content: end;
}

.sns-set li {
    margin: 0 16px;
}

.sns-set li img {
    display: block;
}
/*# sourceMappingURL=style.css.map */
