@font-face {
    font-family: 'TOSHO-YuGothic';
    src: local('Yu Gothic Bold'),local('YuGothic'),url(font/YuGothic/YuGothic-Bold-01.woff) format('woff');
    font-weight: 700;
    font-display: swap;
}
@font-face {
    font-family: 'TOSHO-YuGothic';
    src: local('Yu Gothic Light'),local('YuGothic'),url(font/YuGothic/YuGothic-Light-01.woff) format('woff');
    font-weight: 500;
    font-display: swap;
}

@font-face {
    font-family: 'Celine Peach Free';
    src: url(font/celine-peach-free/Celine-Peach-Script.ttf) format('truetype');
}

@font-face {
    font-family: 'Bayon';
    src: url(font/rightfont/Bayon.ttf) format('truetype');
}

@font-face {
    font-family: 'Bison';
    src: url(font/ellen-luff/Bison.ttf) format('truetype');
}

*{
    margin: 0px;
    padding: 0px;
    box-sizing: border-box;
    list-style: none;
}
::before,
::after{
    box-sizing: border-box;
}
fieldset{
    border: none;
}
img{
    vertical-align: top;
}

:root{
    --site-font-family-Gothic:'TOSHO-YuGothic', sans-serif;
    --site-font-family-Celine-Peach-Free:'Celine Peach Free', sans-serif;
    --site-font-family-Bayon:'Bayon', sans-serif;
    --site-font-family-Bison:'Bison', sans-serif;
    --site-max-width:100%;
    --site-main-width:100%;
    --site-division:375;
    --site-content-width:336;
    --site-horizontal-ratio:calc(100vw / var(--site-division));
    --site-padding:calc(calc(var(--site-division) - var(--site-content-width)) * var(--site-horizontal-ratio) / 2);
}

*.mobile{
    display: initial;
}
*.desktop{
    display: none;
}

.box-100vw{
    width: 100vw;
    margin-left: calc((100% - 100vw - 0px) * 0.5);
}

/* -------------------------------base(mobile)↓-------------------------------------- */
/* body start */
body{
    font-family: var(--site-font-family-Gothic);
    max-width: var(--site-max-width);
    margin: auto;
    background:linear-gradient(to left bottom, #E32525, #14101A 50%, #14101A 100%);
    background-repeat: no-repeat;
    color: #ffffff;
}
/* body end */

/* main start */
main{
    overflow: hidden;
    padding-top: calc(52.5 * var(--site-horizontal-ratio));
}
main>*{
    width: calc(var(--site-content-width) * var(--site-horizontal-ratio));
    margin: auto;
}
body.menuOn>main{
    display: none;
    padding-top: 0;
}
/* main end */

/* header start */
header{
    padding-top: calc(20 * var(--site-horizontal-ratio));
    position: fixed;
    z-index: 10;
}
body.menuOn>header{
    height: calc(100vh);
    position: relative;
}
header>div{
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: calc(356 * var(--site-horizontal-ratio));
}
header>div>a>img{
    width: calc(50 * var(--site-horizontal-ratio));
}
header>div>img{
    width: calc(32 * var(--site-horizontal-ratio));
}
header>nav{
    display: none;
    width: 100vw;
    flex-wrap: wrap;
    gap: calc(20 * var(--site-horizontal-ratio));
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
body.menuOn>header>nav{
    display: flex;
}
header>nav>a{
    display: flex;
    justify-content: center;
    align-items: center;
    width: calc(280 * var(--site-horizontal-ratio));
    height: calc(60 * var(--site-horizontal-ratio));
    border: 1px solid #ffffff;
    border-radius: 100px;
    margin: auto;
    font-family: var(--site-font-family-Bayon);
    font-weight: 400;
    font-size: calc(20 * var(--site-horizontal-ratio));
    line-height: calc(36.13 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
    color: #ffffff;
    text-decoration: none;
}
/* header end */

/* h1 start */
h1{
    font-weight: 700;
    font-size: calc(20 * var(--site-horizontal-ratio));
    line-height: calc(30 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
    position: relative;
    text-align: center;
}
h1::before{
    display: block;
    width: fit-content;
    text-align: center;
    font-family: var(--site-font-family-Celine-Peach-Free);
    font-weight: 400;
    font-size: calc(120 * var(--site-horizontal-ratio));
    line-height: calc(138 * var(--site-horizontal-ratio));
    letter-spacing: 0;
    background: linear-gradient(90deg, #FF9900 0%, #FA5A00 40.22%, #E41111 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin: auto;
    margin-top: calc(calc(120 - 32.5 - 20) * var(--site-horizontal-ratio));
    padding: 0 calc(15 * var(--site-horizontal-ratio));
}
/* h1 end */

/* h2 start */
h2{
    font-weight: 700;
    font-size: calc(20 * var(--site-horizontal-ratio));
    line-height: calc(30 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
    margin-bottom: calc(calc(690 - 598 - 60) * var(--site-horizontal-ratio));
}
h2::before{
    display: block;
    width: 100%;
    text-align: center;
    font-family: var(--site-font-family-Bayon);
    font-weight: 400;
    font-size: calc(30 * var(--site-horizontal-ratio));
    line-height: calc(54.2 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
}
h2~p{
    font-weight: 500;
    font-size: calc(16 * var(--site-horizontal-ratio));
    line-height: calc(32 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
}
/* h2 end */

/* h3 start */
h3{
    font-weight: 700;
    font-size: calc(18 * var(--site-horizontal-ratio));
    line-height: calc(18 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
}
h3~p{
    font-weight: 500;
    font-size: calc(14 * var(--site-horizontal-ratio));
    line-height: calc(28 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
}
/* h2 end */

/* btn start */
.btn,
.btn-gradation{
    font-family: var(--site-font-family-Bison);
    font-weight: 700;
    font-size: calc(14 * var(--site-horizontal-ratio));
    line-height: calc(16.8 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    gap: calc(20 * var(--site-horizontal-ratio));
    width: calc(280 * var(--site-horizontal-ratio));
    height: calc(48 * var(--site-horizontal-ratio));
    padding: 0 calc(20 * var(--site-horizontal-ratio)) 0 calc(30 * var(--site-horizontal-ratio));
    border-radius: calc(100 * var(--site-horizontal-ratio));
    margin: auto;
    text-decoration: none;
}
.btn{
    background-color: #ffffff;
    color: #E32525;
}
.btn-gradation{
    background: linear-gradient(90deg, #FF9900 0%, #FA5A00 40.22%, #E41111 100%);
    color: #ffffff;
}
.btn::after,
.btn-gradation::after{
    display: block;
    content: "";
    width: calc(10 * var(--site-horizontal-ratio));
    height: calc(10 * var(--site-horizontal-ratio));
    border-radius: 50%;
}
.btn::after{
    background: linear-gradient(90deg, #FF9900 0%, #FA5A00 40.22%, #E41111 100%);
}
.btn-gradation::after{
    background-color: #ffffff;
}
/* btn end */

/* footer start */
footer{
    padding: calc(30 * var(--site-horizontal-ratio)) calc(20 * var(--site-horizontal-ratio));
    display: grid;
    grid-template-areas:
        "footer-logo footer-text"
        "footer-btns footer-btns"
        "footer-small footer-small";
}
body.menuOn>footer{
    display: none;
}
footer>img:nth-child(1){
    width: calc(40 * var(--site-horizontal-ratio));
    height: calc(26 * var(--site-horizontal-ratio));
    grid-area: footer-logo;
}
footer>span:nth-child(2){
    font-weight: 700;
    font-size: calc(12 * var(--site-horizontal-ratio));
    line-height: calc(28 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
    grid-area: footer-text;
}
footer>div:nth-child(3){
    margin-top: calc(calc(96.5 - 40.5 - 26) * var(--site-horizontal-ratio));
    display: flex;
    flex-wrap: wrap;
    gap: calc(4 * var(--site-horizontal-ratio));
    font-family: var(--site-font-family-Bayon);
    font-weight: 400;
    font-size: calc(14 * var(--site-horizontal-ratio));
    line-height: calc(25.29 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
    grid-area: footer-btns;
}
footer>div:nth-child(3)>a{
    width: 100%;
    color: #ffffff;
    text-decoration: none;
}
footer>small:nth-child(4){
    display: block;
    margin-top: calc(calc(267.5 - 96.5 - 141) * var(--site-horizontal-ratio));
    font-family: var(--site-font-family-Bayon);
    font-weight: 400;
    font-size: calc(12 * var(--site-horizontal-ratio));
    line-height: calc(21.68 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
    grid-area: footer-small;
}
/* footer end */

/* component-contact start */
.component-contact{
    margin-top: calc(calc(2803 - 2675 - 48) * var(--site-horizontal-ratio));
    width: 100%;
    background-color: #ffffff;
    padding: calc(30 * var(--site-horizontal-ratio)) calc(20 * var(--site-horizontal-ratio))
}
.component-contact>span{
    background: linear-gradient(90deg, #FF9900 0%, #FA5A00 40.22%, #E41111 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-family: var(--site-font-family-Bison);
    font-weight: 700;
    font-size: calc(30 * var(--site-horizontal-ratio));
    line-height: calc(36 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
}
.component-contact>p{
    color: #000000;
    margin-top: calc(calc(86 - 30 - 36) * var(--site-horizontal-ratio));
    margin-bottom: calc(calc(244 - 96 - 86) * var(--site-horizontal-ratio));
    font-weight: 700;
    font-size: calc(16 * var(--site-horizontal-ratio));
    line-height: calc(24 * var(--site-horizontal-ratio));
    letter-spacing: 0.1em;
}
.component-contact>.btn-gradation{
    font-family: var(--site-font-family-Gothic);
    font-weight: 700;
}
/* component-contact end */

/*== landscape responsive ==*/
@media screen and (max-width: 767px) and (orientation: landscape){
}
/*== landscape responsive ==*/
/* -------------------------------base(mobile)↑-------------------------------------- */

/* ---------------------------desktop(include ipad)↓--------------------------------- */
@media screen and (min-width: 768px){
    :root{
        --site-division: 1440;
        --site-padding: calc(60 * var(--site-horizontal-ratio));
        --site-content-width: 1320;
    }
    *.mobile{
        display: none;
    }
    *.desktop{
        display: initial;
    }
    .btn,
    .btn-gradation{
        font-family: var(--site-font-family-Bayon);
        font-weight: 400;
        line-height: calc(25.29 * var(--site-horizontal-ratio));
        height: calc(40 * var(--site-horizontal-ratio));
        width: fit-content;
        padding: calc(3 * var(--site-horizontal-ratio)) calc(20 * var(--site-horizontal-ratio)) 0 calc(30 * var(--site-horizontal-ratio));
    }
    .btn{
        position: relative;
        overflow: hidden;
        background: #ffffff;
    }
    .btn::before{
        content: "";
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        z-index: -1;
        background: linear-gradient(90deg, #FF9900 0%, #FA5A00 40.22%, #E41111 100%);
        left: 0;
        transform: translateX(-101%);
    }
    .btn:hover{
        color: #ffffff;
        transition: color 0.5s linear;
        z-index: 0;
    }
    .btn:hover::before{
        transform: translateX(0%);
        transition: transform 0.5s linear;
    }
    .btn:hover::after{
        background: #ffffff;
    }

    /* main start */
    main{
        padding-top: 0;
    }
    body.menuOn>main{
        display: block;
    }
    /* main end */

    /* header start */
    header{
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: calc(1377 * var(--site-horizontal-ratio));
        position: relative;
    }
    header>div{
        width: auto;
    }
    header>div>a>img{
        width: calc(80 * var(--site-horizontal-ratio));
    }
    header>div>img{
        display: none;
    }
    body.menuOn>header{
        height: auto;
    }
    body.menuOn>header>nav,
    header>nav{
        display: flex;
        position: initial;
        transform: initial;
        width: auto;
    }
    header>nav>a{
        width: auto;
        border: none;
    }
    /* header end */

    /* h1 start */
    h1{
        font-size: calc(28 * var(--site-horizontal-ratio));
        line-height: calc(42 * var(--site-horizontal-ratio));
        position: relative;
        margin-top: calc(calc(347 - 20 - 52) * var(--site-horizontal-ratio));
    }
    h1::before{
        font-size: calc(230 * var(--site-horizontal-ratio));
        line-height: calc(264.5 * var(--site-horizontal-ratio));
        position: absolute;
        bottom: 0;
        left: 50%;
        transform: translate(-50%,calc(38 * var(--site-horizontal-ratio)));
        margin-top: 0;
        padding: 0 calc(35 * var(--site-horizontal-ratio));
    }
    /* h1 end */

    /* h2 start */
    h2{
        margin-bottom: calc(calc(1025 - 46 - 939) * var(--site-horizontal-ratio));
        font-size: calc(28 * var(--site-horizontal-ratio));
        line-height: calc(56 * var(--site-horizontal-ratio));
    }
    h2~p{
        line-height: calc(36 * var(--site-horizontal-ratio));
    }
    /* h2 end */

    /* h3 start */
    h3{
        font-size: calc(20 * var(--site-horizontal-ratio));
        line-height: calc(28 * var(--site-horizontal-ratio));
    }
    /* h3 end */

    /* footer start */
    footer{
        padding: calc(60 * var(--site-horizontal-ratio)) calc(60 * var(--site-horizontal-ratio));
        grid-template-areas:
            "footer-logo footer-text footer-btns"
            "footer-small footer-small footer-small";
        column-gap: calc(calc(160 - 80 - 60) * var(--site-horizontal-ratio));
        row-gap: calc(calc(126 - 52 - 60) * var(--site-horizontal-ratio));
        grid-template-columns: calc(80 * var(--site-horizontal-ratio)) 1fr calc(378 * var(--site-horizontal-ratio));
    }
    footer>img:nth-child(1){
        width: calc(80 * var(--site-horizontal-ratio));
        height: calc(52 * var(--site-horizontal-ratio));
    }
    footer>span:nth-child(2){
        font-size: calc(14 * var(--site-horizontal-ratio));
        line-height: calc(28 * var(--site-horizontal-ratio));
    }
    footer>span:nth-child(2)>span{
        font-weight: 500;
        font-size: calc(12 * var(--site-horizontal-ratio));
        line-height: calc(12 * var(--site-horizontal-ratio));
        letter-spacing: 0.1em;
    }
    footer>div:nth-child(3){
        margin-top: 0;
        flex-wrap: nowrap;
        align-items: center;
        gap: calc(20 * var(--site-horizontal-ratio));
    }
    footer>div:nth-child(3)>a{
        width: fit-content;
    }
    footer>small:nth-child(4){
        margin-top: 0;
    }
    /* footer end */

    /* component-contact start */
    .component-contact{
        margin-top: calc(calc(2706 - 2546 - 40) * var(--site-horizontal-ratio));
        padding: calc(60 * var(--site-horizontal-ratio)) calc(65 * var(--site-horizontal-ratio));
    }
    .component-contact>span{
        font-family: var(--site-font-family-Bayon);
        font-weight: 400;
        font-size: calc(40 * var(--site-horizontal-ratio));
        line-height: calc(72.27 * var(--site-horizontal-ratio));
    }
    .component-contact>p {
        margin-top: calc(calc(140 - 60 - 72) * var(--site-horizontal-ratio));
        margin-bottom: calc(calc(244 - 72 - 140) * var(--site-horizontal-ratio));
        font-size: calc(18 * var(--site-horizontal-ratio));
        line-height: calc(36 * var(--site-horizontal-ratio));
    }
    .component-contact>.btn-gradation{
        margin-left: 0;
    }
    /* component-contact end */

}
/* ---------------------------desktop(include ipad)↑--------------------------------- */