@charset "UTF-8";
body {
    counter-reset: number 0;
}
.main__title{
    padding-top: 16px;
}
.main__title .bg{
    top: 0;
}
#present {
    display: flex;
    max-width: 1050px;
    flex-direction: column;
    gap: 20px;
    width: 100%;
    margin: 20px auto;
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}
@media screen and (max-width:480px) {
    #present {
        padding: 0 10px;
    }
}
.main_title,
.main_lead {
    text-align: center;
    color: #220055;
    font-weight: 600;
}
.main_title {
    font-size: 30px;
    line-height: 1.5;
}
@media screen and (max-width:480px) {
    .main_title {
        font-size: 17px;
    }
}
.main_lead_wrap {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.main_lead {
    display: block;
    margin: auto;
    font-size: 20px;
    line-height: 1.5;
}
@media screen and (max-width:480px) {
    .main_lead {
        font-size: 16px;
    }
}
.main_lead em {
    color: #8B008B;
    font-weight: 600;
}
ul.present_date,
dl.present_date2 {
    display: flex;
    align-self: center;
    flex-direction: column;
    gap: 20px;
    width: 600px;
    padding: 20px 0;
    border: 1px solid #cc0000;
}
dl.present_date2 {
    padding: 20px;
    gap: 10px;
}
@media screen and (max-width:600px) {
    ul.present_date,
    dl.present_date2 {
        width: 100%;
    }
}
dl.present_date2 dd.__caution_list{
    font-size: .9375rem;
    position: relative;
    padding-left: 1.25rem;
    line-height: 1.25;
}
dl.present_date2 dd.__caution_list::before{
    content:"\f06a";
    position: absolute;
    font-weight: 900;
    font-family: "Font Awesome 6 Free";
    top:0;
    left: 0;
}
dl.present_date2 dd.__form_btn_wrap{
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: center;
    margin: auto;
}

ul.present_date li {
    display: grid;
    gap: 10px;
    grid-template-columns: 1fr 1.2fr;
}
ul.present_date li:not(:first-child) {
    padding-top: 20px;
    border-top: 1px solid #cc0000;
}
span.date_h,
span.date_d {
    color: #cc0000;
    font-size: 18px;
}
span.date_h {
    text-align: right;
    font-weight: 600;
}
.section-present {
    display: flex;
    justify-content: space-between;
    /*gap: 20px;*/
    padding: 0px;
    border: 1px solid #D2CCE6;
    border-radius: 10px;
    background-color: #F5F5FF;
}
@media screen and (max-width:768px) {
    .section-present {
        flex-direction: column;
    }
}
.coming_soon{
    display: flex;
    flex: 1 1 100%;
    flex-direction: column;
    gap: 20px;
    padding: 100px 0;
}
.coming_soon h3.__cs_ttl{
    align-self: center;
    font-size: 1.25rem;
    font-weight: 600;
    color: #220055;
}
.coming_soon p{
    align-self: center;
    font-size: 1rem;
    color: #220055;
}
.pickup_box {
    display: flex;
    flex-basis: 70%;
    flex-direction: column;
    gap: 20px;
    padding: 20px;
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
    background: url(../img/seat5-1/pickup_bg.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}
@media screen and (max-width:768px) {
    .pickup_box {
        border-top-right-radius: 10px;
        border-bottom-left-radius: 0px;
    }
}
.pickup_box.__winner {
    flex-basis: 100%;
    }
.pickup_title {
    text-align: center;
    color: #DDA7FF;
    font-size: 24px;
    font-weight: 600;
}
@media screen and (max-width:480px) {
    .pickup_title {
        font-size: 24px;
    }
}
.pickup_lead {
    text-align: center;
    color: #CC0000;
    font-size: 20px;
    font-weight: 600;
}
@media screen and (max-width:480px) {
    .pickup_lead {
        font-size: 16px;
        line-height: 1.5;
    }
}
.pickup_inner {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 20px;
    border-radius: 5px;
    background-color: #fff;
}
ul.present_item {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
ul.present_item li {
    display: flex;
    gap: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid #D2CCE6;
}
@media screen and (max-width:480px) {
    ul.present_item li {
        gap: 10px;
    }
}
.p_item_h {
    flex-basis: 7%;
    color: #8B008B;
    font-size: 20px;
    font-weight: 600;
}
@media screen and (max-width:480px) {
    .p_item_h {
        flex-basis: 12%;
        font-size: 18px;
    }
}
.p_item_d {
    display: flex;
    flex-basis: calc(93% - 20px);
    flex-direction: column;
    gap: 10px;
}
@media screen and (max-width:480px) {
    .p_item_d {
        flex-basis: calc(88% - 20px);
    }
}
.p_item {
    display: flex;
    gap: 20px;
    color: #220055;
    font-size: 1rem;
    line-height: 1.5;
}
.p_item:not(:first-child) {
    padding-top: 10px;
    border-top: 1px dotted #D2CCE6;
}
@media screen and (max-width:480px) {
    .p_item {
        flex-direction: column;
    }
}
.p_item_date {
    flex-basis: 130px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
@media screen and (max-width:480px) {
    .p_item_date {
        flex-basis: 0px;
    }
}
.p_item_nmb {
    font-size: .875rem;
    font-weight: 600;
}
.p_item_name{
line-height: 1.5;
}
.p_item_subdate{
    font-size: .75rem;
    line-height: 1.5;
}
.winner_num{
    float: inline-end;
    font-weight: 600;
}
.p_item_img{
    display: flex;
    gap: 10px;
}
@media screen and (max-width:480px) {
    .p_item_img {
        flex-direction: column;
    }
}
.p_item_main_img,
.p_item_other_img{
    display: flex;
    flex-direction: column;
    gap: 10px;

}
@media screen and (max-width:480px) {
    .p_item_other_img {
        flex-direction: row;
        justify-content: center;
    }
}
.p_item_img img {
    max-width: 97px;
}
@media screen and (max-width:480px) {
    .p_item_img img {
        max-width: 100px;
    }
}
.p_item_img .__main_L{
    max-width: 320px;
}

.p_item_img .__main_M{
    max-width: 210px;
}
@media screen and (max-width:480px) {
    .p_item_img .__main_L,
    .p_item_img .__main_M {
        max-width: 100%;
    }
}
.p_item_subtext {
    position: relative;
    display: block;
    padding-left: 2rem;
    font-size: .75rem;
    font-style: normal;
    line-height: 1.25;
}
.p_item_subtext:before {
    content: "提供";
    position: absolute;
    left: 0;
}
dl.p_item_winner{    
    /*flex-basis: 250px;*/
    border: #6E5AE1 1px solid;
    border-radius: 4px;
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
dl.p_item_winner dt{
    color: #220055;
    font-weight: 600;
}
dl.p_item_winner dd{
    display: flex;
    flex-direction: column;
    gap: 10px;
}
dl.p_item_winner dd:not(:first-child){
    border-top: 1px dotted #6E5AE1;
    padding-top: 10px;
}
.__winner_nickname{
    color: #444;
    font-weight: 600;
    font-size:1rem;
}
.__winner_nickname small{
    font-size:.8125rem;
    font-weight: normal; 
    color: #666;
}
.__form_btn{
    display: flex;
    justify-content: center;
    padding: 10px 20px;
    background: #0077ff;
    color: #fff;
    border-radius: 15px;
    font-size: .8125rem;
    align-self: center;
    box-shadow: 2px 2px #ccc;
}
.__caution_ttl{
    font-size: 1rem;
    font-weight: 600;
    color: #CC0000;
    text-align: center;
}
.pickup_box2 {
    display: flex;
    flex-basis: 30%;
    flex-direction: column;
    gap: 20px;
    padding: 20px;
    background-image: url(../img/seat5-1/mineral_img_L.png);
    background-repeat: no-repeat;
    background-position: bottom right;
    background-size: 100%;
}
@media screen and (max-width:768px) {
    .pickup_box2 {
        background-image: none;
    }
}
ul.pickup_list {
    display: flex;
    flex-basis: 100%;
    flex-direction: column;
    gap: 50px;
    padding-top: 45px;
}
@media screen and (max-width:480px) {
    ul.pickup_list {
        gap: 20px;
        padding-top: 0px;
    }
}
ul.pickup_list li {
    position: relative;
    padding-bottom: 10px;
    padding-left: 26px;
    color: #220055;
    border-bottom: 1px dotted #A59ACA;
    font-size: 16px;
    font-weight: normal;
    line-height: 1.5;
}
@media screen and (max-width:480px) {
    ul.pickup_list li {
        letter-spacing: normal;
        font-size: 15px;
    }
}
ul.pickup_list li::before {
    content: "";
    position: absolute;
    top: 6px;
    left: 0;
    width: 16px;
    height: 16px;
    border-radius: 4px;
    background-color: #6E5AE1;
}
ul.pickup_list li em {
    display: inline-block;
    padding-bottom: 5px;
    font-size: 18px;
    font-weight: 600;
}
.__small_text {
    font-size: 14px;
}
.__button,
.__button_no_link {
    display: flex;
    align-items: center;
    align-self: center;
    padding: 20px 50px;
    cursor: pointer;
    transition: all .5s ease;
    letter-spacing: 6px;
    color: #fff;
    border: none;
    border-radius: 10px;
    outline: none;
    background: linear-gradient(90deg, #741474, #0C32A4);
    box-shadow: #D2CCE6 0 5px 0;
    font-size: 24px;
    font-weight: 600;
}
@media screen and (max-width:480px) {
    .__button,
    .__button_no_link {
        padding: 20px;
        font-size: 18px;
    }
}
.__button::after {
    content: url(../img/seat5-1/arrow.png);
    padding-left: 10px;
}
@media screen and (max-width:480px) {
    .__button::after {
        padding-top: 3px;
    }
}
.__button:hover {
    transform: translateY(5px);
    box-shadow: none;
}
.__present_btn {
    background: #cc0000;
}
.__button_no_link {
    padding: 20px;
    pointer-events: none;
    background: #006699;
    box-shadow: none;
    font-size: 18px;
}
@media screen and (max-width:768px) {
    .sp_none {
        display: none;
    }
}
.sp_br {
    display: none;
}
@media screen and (max-width:480px) {
    .sp_br {
        display: block;
    }
}
.msg-btn-box {
    display: flex;
    align-self: stretch;
    justify-content: center;
}
a.msg-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 20px;
    letter-spacing: .1rem;
    color: #fff;
    border-radius: 4px;
    background-color: #0077ff;
    font-size: 14px;
}
.__asterisk{
    position: relative;
    padding-left: 1rem;
    font-size: .875rem;
    font-style: normal;
    display: inline-block;
    line-height: 1.25;
}
.__asterisk::before{
    content: "※";
    position: absolute;
    left: 0;
}
.red{
    color:#CC0000;
}