﻿

*,
*::before,
*::after {
    box-sizing: border-box
}

html,
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
li,
figure,
img,
a {
    margin: 0;
    padding: 0
}

/* img {
    max-width: 100%;
    display: block;
    height: auto
} */

ul,
ol {
    list-style: none
}

a {
    text-decoration: none
}

a:hover {
    opacity: .9
}

.pc {
    display: block
}

@media screen and (max-width: 768px) {
    .pc {
        display: none
    }
}

.sp {
    display: none
}

@media screen and (max-width: 768px) {
    .sp {
        display: block
    }
}

.bg2 {
    color: #542222
}

/* img {
    max-width: 100%;
    height: auto;
    display: block
} */

#site {
    font-family: "Noto Sans JP", serif;
    font-style: normal;
    color: #101f3e;
    font-weight: 400;
    max-width: 1440px;
    width: 100%;
    background-color: #fffafd;
    background-image: linear-gradient(to right, rgba(255, 139, 187, 0.3) 1px, transparent 1px), linear-gradient(to bottom, rgba(255, 139, 187, 0.3) 1px, transparent 1px);
    background-size: 50px 50px;
    padding-bottom: 160px
}

@media screen and (max-width: 768px) {
    #site {
        width: 100%;
        padding-bottom: 40px
    }
}

.c-btn1 {
    font-size: clamp(12px, 1.6666666667vw, 24px);
    line-height: 1em;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: clamp(52px, 7.2222222222vw, 104px);
    padding: 0 clamp(28px, 3.8888888889vw, 56px);
    box-sizing: border-box;
    border: none;
    border-radius: 100px;
    text-decoration: none;
    cursor: pointer;
    overflow: hidden;
    color: #fff;
    text-align: center;
    font-weight: 700;
    letter-spacing: 1.68px;
    background: linear-gradient(106deg, rgba(255, 255, 255, 0) 55.04%, rgba(255, 255, 255, 0.08) 56.57%, rgba(255, 255, 255, 0.08) 68.79%, rgba(255, 255, 255, 0) 70.31%), #e5327c;
    box-shadow: inset 0 3px 8px hsla(0, 0%, 100%, .32), inset 0 -6px 10px rgba(159, 30, 92, .5), inset 6px 0 10px hsla(0, 0%, 100%, .22), inset -6px 0 10px rgba(159, 30, 92, .45), 2px 2px 10px 0 rgba(229, 67, 137, .2);
    transition: transform .15s ease-out, box-shadow .15s ease-out;
    position: relative
}

@media screen and (max-width: 768px) {
    .c-btn1 {
        height: 68px;
        padding: 0 48px;
        font-size: 20px;
        font-weight: 700;
        line-height: 100%;
        letter-spacing: 1.4px
    }
}

.c-btn1--type2 {
    margin-left: auto;
    margin-right: auto;
    font-size: 24px;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 1.68px;
    height: 64px;
    padding: 0 56px;
    box-shadow: inset 0 3px 8px hsla(0, 0%, 100%, .32), inset 0 -6px 10px rgba(159, 30, 92, .5), inset 6px 0 10px hsla(0, 0%, 100%, .22), inset -6px 0 10px rgba(159, 30, 92, .45), 0 0 20px 0 #fff
}

.c-btn1--type3 {
    margin-left: auto;
    margin-right: auto;
    color: #fff;
    text-align: center;
    font-family: "Noto Sans JP";
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 1.4px;
    height: 60px;
    padding: 0 56px
}

.c-btn1::after {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    box-shadow: 2px 2px 10px 0 rgba(229, 67, 137, .2);
    border-radius: 100px
}

.c-btn1:hover {
    transform: translateY(1px);
    box-shadow: inset 0 3px 8px hsla(0, 0%, 100%, .34), inset 0 -6px 10px rgba(159, 30, 92, .54), inset 6px 0 10px hsla(0, 0%, 100%, .24), inset -6px 0 10px rgba(159, 30, 92, .49)
}

.c-btn1:active {
    transform: translateY(2px);
    box-shadow: inset 0 2px 7px hsla(0, 0%, 100%, .3), inset 0 -5px 9px rgba(159, 30, 92, .56), inset 5px 0 9px hsla(0, 0%, 100%, .23), inset -5px 0 9px rgba(159, 30, 92, .5)
}

.c-waku {
    margin-left: auto;
    margin-right: auto;
    width: clamp(450px, 62.5vw, 900px);
    padding: clamp(20px, 2.7777777778vw, 40px) clamp(31px, 4.3055555556vw, 62px);
    border-radius: 10px;
    border: 1px solid #e5327c;
    background: #fff;
    box-shadow: 8px 8px 0 0 rgba(229, 67, 137, .5)
}

@media screen and (max-width: 768px) {
    .c-waku {
        margin-left: auto;
        margin-right: auto;
        width: calc(100% - 40px);
        padding: 32px 16px
    }
}

.c-waku h2 {
    font-size: clamp(16px, 2.2222222222vw, 32px);
    line-height: 1em;
    font-family: "keifont", serif;
    font-style: normal;
    color: #e5327c;
    font-weight: 400;
    letter-spacing: 1.6px;
    margin-bottom: clamp(8px, 1.1111111111vw, 16px);
    text-align: center
}

@media screen and (max-width: 768px) {
    .c-waku h2 {
        font-size: 24px;
        line-height: 100%;
        letter-spacing: 1.2px;
        margin-bottom: 16px
    }
}

.c-waku .hr {
    background-image: url("../image/line2.png");
    background-repeat: no-repeat;
    background-position: 0px center;
    background-size: contain;
    width: 100%;
    height: clamp(8px, 1.1111111111vw, 16px);
    margin-bottom: clamp(8px, 1.1111111111vw, 16px)
}

@media screen and (max-width: 768px) {
    .c-waku .hr {
        margin-bottom: 16px
    }
}

.c-waku .def_list {
    display: grid;
    grid-template-columns: auto 1fr;
    row-gap: 4px;
    column-gap: 8px;
    align-items: flex-start;
    margin: 0
}

@media screen and (max-width: 768px) {
    .c-waku .def_list {
        display: block
    }
}

.c-waku .def_list+* {
    margin-top: clamp(20px, 2.7777777778vw, 40px)
}

.c-waku .def_list dt {
    font-size: clamp(8px, 1.1111111111vw, 16px);
    line-height: 1em;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: clamp(44px, 6.1111111111vw, 88px);
    height: clamp(14px, 1.9444444444vw, 28px);
    border-radius: 5px;
    border: 1px solid #e5327c;
    background: #fff;
    color: #e5327c;
    font-weight: 700;
    letter-spacing: 1.12px
}

@media screen and (max-width: 768px) {
    .c-waku .def_list dt {
        width: 80px;
        height: 26px;
        font-size: 12px;
        letter-spacing: .84px;
        margin-bottom: 4px
    }
}

.c-waku .def_list dd {
    font-size: clamp(8px, 1.1111111111vw, 16px);
    line-height: 1em;
    line-height: calc(1em + clamp(4px, .5555555556vw, 8px));
    padding-top: clamp(1px, .1388888889vw, 2px);
    color: #52444a;
    font-weight: 700;
    letter-spacing: .8px;
    margin: 0
}

@media screen and (max-width: 768px) {
    .c-waku .def_list dd {
        font-family: "Noto Sans JP", serif;
        font-style: normal;
        padding-top: 3px;
        margin-bottom: 16px;
        font-size: 13px;
        line-height: 140%;
        letter-spacing: .65px
    }

    .c-waku .def_list dd:last-child {
        margin-bottom: 0
    }
}

.c-waku .player {
    width: 100%
}

.c-waku .detail h3 {
    font-size: clamp(8px, 1.1111111111vw, 16px);
    line-height: 1.8em;
    color: #52444a;
    font-weight: 700;
    letter-spacing: .8px
}

.c-waku .detail h3+p {
    margin-top: 0
}

@media screen and (max-width: 768px) {
    .c-waku .detail h3 {
        font-size: 13px;
        line-height: 180%
    }
}

.c-waku .detail p {
    font-size: clamp(8px, 1.1111111111vw, 16px);
    line-height: 1.8em;
    color: #52444a;
    font-weight: 700;
    letter-spacing: .8px;
    margin-top: clamp(8px, 1.1111111111vw, 16px)
}

.c-waku .detail p:first-child {
    margin-top: 0
}

@media screen and (max-width: 768px) {
    .c-waku .detail p {
        font-size: 13px;
        line-height: 180%;
        letter-spacing: .65px
    }
}

.c-waku .detail hr {
    border: none;
    border-bottom: 1px #f7c3da solid;
    margin-top: clamp(12px, 1.6666666667vw, 24px);
    margin-bottom: clamp(12px, 1.6666666667vw, 24px);
    width: 100%
}

.c-waku ul+.image {
    margin-top: clamp(8px, 1.1111111111vw, 16px)
}

@media screen and (max-width: 768px) {
    .c-waku ul+.image {
        margin-top: 16px
    }
}

.c-waku .image+* {
    margin-top: clamp(8px, 1.1111111111vw, 16px)
}

@media screen and (max-width: 768px) {
    .c-waku .image+* {
        margin-top: 16px
    }
}

.flex {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: stretch
}

@media screen and (max-width: 768px) {
    .flex {
        flex-direction: column
    }
}

section {
    margin-bottom: clamp(24px, 3.3333333333vw, 48px)
}

section:last-child {
    margin-bottom: 0
}

@media screen and (max-width: 768px) {
    section {
        margin-bottom: 40px
    }
}

ul+* {
    margin-top: clamp(4px, .5555555556vw, 8px)
}

ul.point li {
    font-size: clamp(7px, .9722222222vw, 14px);
    font-weight: 700;
    line-height: 180%;
    letter-spacing: .7px;
    margin-bottom: clamp(4px, .5555555556vw, 8px)
}

ul.point li:last-child {
    margin-bottom: 0
}

ul.point li::before {
    content: "・";
    aspect-ratio: 1/1;
    height: auto
}

@media screen and (max-width: 768px) {
    ul.point li {
        font-size: 14px;
        font-weight: 700;
        line-height: 180%;
        letter-spacing: .7px
    }
}

ul.anno li {
    font-size: clamp(7px, .9722222222vw, 14px);
    line-height: 1.8em;
    font-weight: 700;
    letter-spacing: .7px;
    margin-bottom: clamp(4px, .5555555556vw, 8px)
}

@media screen and (max-width: 768px) {
    ul.anno li {
        font-size: 11px;
        font-weight: 700;
        line-height: 180%;
        letter-spacing: .55px
    }
}

ul.anno li:last-child {
    margin-bottom: 0
}

ul.anno li::before {
    content: "※";
    aspect-ratio: 1/1;
    width: clamp(13px, 1.8055555556vw, 26px);
    height: auto
}

ul.star li {
    font-size: clamp(8px, 1.1111111111vw, 16px);
    line-height: 1.8em;
    display: flex;
    align-items: flex-start;
    gap: 4px;
    font-weight: 700;
    letter-spacing: .8px;
    margin-bottom: clamp(4px, .5555555556vw, 8px)
}

@media screen and (max-width: 768px) {
    ul.star li {
        font-size: 13px;
        line-height: 180%;
        letter-spacing: .65px
    }
}

ul.star li:last-child {
    margin-bottom: 0
}

ul.star li::before {
    content: "";
    display: block;
    background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%2215%22%20height%3D%2214%22%20viewBox%3D%220%200%2015%2014%22%20fill%3D%22none%22%3E%0A%20%20%3Cpath%20d%3D%22M4.84967%201.71546C5.5929%20-0.571948%208.82898%20-0.571948%209.5722%201.71546C9.90458%202.73842%2010.8579%203.43102%2011.9335%203.43102C14.3386%203.43102%2015.3386%206.50871%2013.3928%207.92241C12.5226%208.55464%2012.1585%209.67528%2012.4909%2010.6982C13.2341%2012.9857%2010.6161%2014.8878%208.67028%2013.4741C7.8001%2012.8419%206.62178%2012.8419%205.7516%2013.4741C3.80581%2014.8878%201.18777%2012.9857%201.93099%2010.6982C2.26337%209.67528%201.89925%208.55464%201.02907%207.92241C-0.916718%206.50871%200.0832849%203.43102%202.48841%203.43102C3.56402%203.43102%204.51729%202.73842%204.84967%201.71546Z%22%20fill%3D%22%23E5327C%22/%3E%0A%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    aspect-ratio: 1/1;
    width: clamp(8px, 1.1111111111vw, 16px);
    height: auto;
    margin-top: clamp(3px, .4166666667vw, 6px)
}

@media screen and (max-width: 768px) {
    ul.star li::before {
        width: 13px;
        margin-top: 4px
    }
}

ul.star li span {
    flex: 1
}

ul li {
    color: #52444a;
    font-weight: 700
}

.line {
    color: #e5327c;
    background-image: url("../image/ico_line1.svg");
    background-repeat: repeat-x;
    background-position: 0px center;
    background-size: clamp(20.5px, 2.8472222222vw, 41px) clamp(8px, 1.1111111111vw, 16px);
    margin-left: calc(clamp(7px, .9722222222vw, 14px)*-1);
    height: clamp(8px, 1.1111111111vw, 16px);
    width: 100%
}

#mv {
    background-image: url("../image/bg.png");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 100%;
    position: relative;
    padding: clamp(30.5px, 4.2361111111vw, 61px) clamp(20px, 2.7777777778vw, 40px) 0 clamp(48px, 6.6666666667vw, 96px)
}

@media screen and (max-width: 768px) {
    #mv {
        padding: 53px 0 0
    }
}

#mv article {
    padding: 0
}

@media screen and (max-width: 768px) {
    #mv article {
        margin-left: auto;
        margin-right: auto;
        width: 375px
    }
}

#mv article .flex {
    gap: clamp(25px, 3.4722222222vw, 50px)
}

@media screen and (max-width: 768px) {
    #mv article .flex {
        gap: 25px
    }
}

#mv article .flex__item.info {
    flex: 1;
    text-align: center
}

#mv article .flex__item.info h1 {
	margin-bottom: clamp(15px, 2.0833333333vw, 30px);
	text-align: center;
}

#mv article .flex__item.info h1 .logo1 {
	margin-left: auto;
	margin-right: auto;
	aspect-ratio: 705/117;
	width: clamp(176.25px, 24.4791666667vw, 261.5px);
	margin-bottom: clamp(8.85px, 1.2291666667vw, 17.7px);
}

@media screen and (max-width: 768px) {
    #mv article .flex__item.info h1 .logo1 {
        width: 264px;
        margin-bottom: 12px
    }
}

#mv article .flex__item.info h1 .logo2 {
	margin-left: auto;
	margin-right: auto;
	aspect-ratio: 708/234;
	width: clamp(177px, 24.5833333333vw, 300px);
}

@media screen and (max-width: 768px) {
    #mv article .flex__item.info h1 .logo2 {
        width: 266px;
        margin-bottom: 12px
    }
}

#mv article .flex__item.info .text1 {
    margin-left: auto;
    margin-right: auto;
    aspect-ratio: 1193/132;
    width: clamp(298.25px, 41.4236111111vw, 596.5px);
    margin-bottom: clamp(8px, 1.1111111111vw, 16px)
}

@media screen and (max-width: 768px) {
    #mv article .flex__item.info .text1 {
        aspect-ratio: 661/208;
        width: 266px;
        margin-bottom: 12px
    }
}

#mv article .flex__item.info .text2 {
	margin-left: auto;
	margin-right: auto;
	aspect-ratio: 773/80;
	width: clamp(193.25px, 26.8402777778vw, 307.5px);
	margin-bottom: clamp(9.5px, 1.3194444444vw, 19px);
}

@media screen and (max-width: 768px) {
    #mv article .flex__item.info .text2 {
        width: 287px;
        margin-bottom: 14px
    }
}

#mv article .flex__item.info .line {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: clamp(4px, .5555555556vw, 8px);
    width: clamp(200px, 27.7777777778vw, 400px)
}

@media screen and (max-width: 768px) {
    #mv article .flex__item.info .line {
        height: 16px;
        width: 303px;
        margin-bottom: 14px
    }
}

#mv article .flex__item.info .text3 {
    font-family: "keifont", serif;
    font-style: normal;
    font-size: clamp(12.8995px, 1.7915972222vw, 25.799px);
    line-height: 1.4000155045em;
    color: #fff;
    letter-spacing: 1.29px
}

#mv article .flex__item.info .text3 span {
    font-size: clamp(12.8995px, 1.7915972222vw, 25.799px);
    line-height: 1.6000232567em;
    margin-left: clamp(3.5px, .4861111111vw, 7px)
}

#mv article .flex__item.image {
    position: relative;
    aspect-ratio: 1339/1092;
    width: clamp(334.75px, 46.4930555556vw, 669.5px);
    margin-top: calc(clamp(21.565px, 2.9951388889vw, 43.13px)*-1)
}

@media screen and (max-width: 768px) {
    #mv article .flex__item.image {
        padding: 0 0 0 38px;
        aspect-ratio: unset;
        width: 100%
    }
}

#mv article .flex__item.image::before {
    content: "";
    background-image: url("../image/ico_mv1.png");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    aspect-ratio: 292/292;
    width: clamp(73px, 10.1388888889vw, 146px);
    position: absolute;
    top: clamp(18px, 2.5vw, 36px);
    left: calc(clamp(36.5px, 5.0694444444vw, 73px)*-1)
}

@media screen and (max-width: 768px) {
    #mv article .flex__item.image::before {
        left: 0px
    }
}

#mv article .flex__item.image img {
    width: 100%
}

#event_info article {
    padding: 0
}

@media screen and (max-width: 768px) {
    #event_info article {
        max-width: unset
    }
}

@media screen and (max-width: 768px) {
    #apply .def_list {
        display: block
    }
}

#apply .def_list dt {
    width: clamp(67.5px, 9.375vw, 135px)
}

@media screen and (max-width: 768px) {
    #apply .def_list dt {
        width: 113px;
        height: 26px;
        margin-bottom: 4px
    }
}

@media screen and (max-width: 768px) {
    #apply .def_list dd {
        font-family: "din-2014", "Noto Sans JP", serif;
        font-style: normal;
        font-size: 13px;
        font-weight: 700;
        line-height: 140%;
        letter-spacing: .65px;
        margin-bottom: 16px
    }

    #apply .def_list dd:last-child {
        margin-bottom: 0
    }
}

@media screen and (max-width: 768px) {
    #attention .detail p {
        font-size: 11px;
        font-weight: 700;
        line-height: 180%;
        letter-spacing: .55px
    }
}

@media screen and (max-width: 768px) {
    #attention .detail .point li {
        font-size: 11px;
        font-weight: 700;
        line-height: 180%;
        letter-spacing: .55px
    }
}

#btns {
    text-align: center
}

#btns .c-btn1 {
    margin-bottom: clamp(4px, .5555555556vw, 8px)
}

#btns .anno li {
    color: #e5327c
}