@charset "utf-8";

/* CSS INFORMATION -====================================================
File name : special.css
Description :
===================================================================== */

/* =====================================================================
*    special
* =================================================================== */
.special {
    padding: calc(100 / 750 * 100%) 0 calc(150 / 750 * 100%);
    background-color: #ffe822;
}

.special::after {
    content: "";
    display: block;
    width: 100%;
    padding-top: calc(235 / 750 * 100%);
    background: url(../images/common/line_tate_white.png) repeat left top;
    background-size: calc(20 / 750 * 100%) auto;
    position: absolute;
    left: 0;
    bottom: 0;
}

.special .inner {
    z-index: 2;
}

.special_box {
    margin: 0 0 calc(70 / 750 * 100%);
}

.special_box .sec_ttl {
    margin: 0 auto calc(80 / 750 * 100%);
}

.special_what {
}

.special_what dt {
    width: calc(360 / 750 * 100%);
    margin: 0 auto calc(30 / 750 * 100%);
}

.special_what dt span {
    display: block;
    padding: calc(19 / 360 * 100%) 0;
    background-color: #000;
    color: #ffe822;
    font-size: 3.2rem;
    font-weight: 700;
    line-height: 1;
    text-align: center;
}

.special_what dt::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: url(../images/common/line_naname_black.png) repeat left top;
    background-size: calc(12 / 360 * 100%) auto;
    position: absolute;
    top: 0;
    left: 0;
    margin: calc(10 / 360 * 100%) 0 0 calc(10 / 360 * 100%);
}

.special_what dd {
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1.64;
    text-align: center;
}

.special_list {
    width: calc(600 / 750 * 100%);
    margin: 0 auto;
}

.special_list li {
    margin: 0 0 calc(50 / 600 * 100%);
}

.special_list li:last-child {
    margin: 0;
}

.special_list_box {
    z-index: 2;
}

.special_list_ttl {
    padding: calc(32 / 600 * 100%) 0;
    color: #fff;
    font-size: 3rem;
    line-height: 1.5;
    text-align: center;
    background-color: #000;
}

.special_list_photo {
    border: calc(10 / 750 * 100vw) solid #000;
}

.special_list_btn {
    width: calc(440 / 600 * 100%);
    margin: calc(-25 / 600 * 100%) 0 0 calc(190 / 600 * 100%);
    padding: calc(25 / 580 * 100%) 0 calc(11 / 580 * 100%) calc(26 / 580 * 100%);
    border: calc(10 / 750 * 100vw) solid #000;
    background-color: #ffe822;
    color: #000;
    font-size: 2.8rem;
    line-height: 1;
}

.special_list_btn span {
    font-weight: 700;
}

.special_list_btn::after {
    content: "";
    display: block;
    width: calc(12 / 440 * 100%);
    padding-top: calc(12 / 440 * 100%);
    border-top: 0.17em solid #000;
    border-right: 0.17em solid #000;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    bottom: 0;
    right: 0;
    margin: 0 5% 4% 0;
}

@media screen and (min-width: 768px) {
    .special {
        padding: calc(100 / 1100 * 100%) 0;
    }
    
    .special::after {
        padding-top: calc(200 / 1100 * 100%);
        background-size: calc(10 / 1100 * 100%) auto;
    }
    
    .special_box {
        margin: 0 0 calc(45 / 1100 * 100%);
    }
    
    .special .sec_ttl {
        margin: 0 auto calc(50 / 1100 * 100%);
    }
    
    .special_what dt {
        width: calc(300 / 1100 * 100%);
        margin: 0 auto calc(17 / 1100 * 100%);
    }
    
    .special_what dt::before {
        background-size: calc(6 / 300 * 100%) auto;
        margin: calc(5 / 300 * 100%) 0 0 calc(5 / 300 * 100%);
    }
    
    .special_what dt span {
        font-size: 2rem;
        padding: calc(15 / 300 * 100%) 0;
    }
    
    .special_what dd {
        font-size: 1.8rem;
        line-height: 1.7;
    }
    
    .special_list {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        width: calc(1000 / 1100 * 100%);
    }
    
    .special_list li {
        width: calc(320 / 1000 * 100%);
        margin: 0 calc(20 / 1000 * 100%) calc(50 / 1000 * 100%) 0;
    }
    
    .special_list li:nth-child(3n) {
        margin-right: 0;
    }
    
    .special_list li a {
        width: calc(300 / 320 * 100%);
    }
    
    .special_list_ttl {
        padding: calc(18 / 300 * 100%) 0;
        font-size: 1.6rem;
    }
    
    .special_list_photo {
        border: calc(5 / 1100 * 100vw) solid #000;
    }
    
    .special_list_btn {
        width: calc(260 / 300 * 100%);
        margin: calc(-20 / 300 * 100%) 0 0 calc(60 / 300 * 100%);
        padding: calc(23 / 300 * 100%) 0 calc(9 / 300 * 100%) calc(20 / 300 * 100%);
        border: calc(5 / 1100 * 100vw) solid #000;
        color: #000;
        font-size: 1.8rem;
        -webkit-transition: color 0.1s ease 0.2s;
        transition: color 0.1s ease 0.2s;
    }
    
    .special_list_btn::after {
        width: calc(8 / 260 * 100%);
        padding-top: calc(8 / 260 * 100%);
        border-top: 0.23em solid #000;
        border-right: 0.23em solid #000;
        margin: 0 7% 5% 0;
        -webkit-transition: border 0.1s ease 0;
        transition: border 0.1s ease 0;
    }
    
    .special_list_btn::before {
        content: "";
        display: block;
        width: 0;
        height: 100%;
        background-color: #000;
        position: absolute;
        top: 0;
        left: 0;
        -webkit-transition: 0.3s ease;
        transition: 0.3s ease;
    }
    
    .special_list li a:hover .special_list_btn {
        color: #ffe822;
        -webkit-transition: none;
        transition: none;
    }
    
    .special_list li a:hover .special_list_btn::before {
        width: 100%;
    }
    
    .special_list li a:hover .special_list_btn::after {
        border-color: #ffe822;
        -webkit-transition: border 0.1s ease 0.2s;
        transition: border 0.1s ease 0.2s;
    }
}

@media screen and (min-width: 1100px) {
    .special {
        padding: 100px 0;
    }
    
    .special::after {
        padding-top: 200px;
        background-size: 10px auto;
    }
    
    .special_list_photo {
        border: 5px solid #000;
    }
    
    .special_list_btn {
        border: 5px solid #000;
    }
}


/* =====================================================================
*    .popup
* =================================================================== */
.popup {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 100;
    display: none;
}

.popup_bg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: rgba(0,0,0,0.8);
}

.popup_area {
    width: 100%;
    height: 100%;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
}

.popup_inner {
    position: relative;
    width: calc(630 / 750 * 100%);
    margin: 0 auto;
    padding: 10% 0;
}

.popup_close {
    position: absolute;
    width: 100%;
    margin: -12% 0 0;
}

.popup_close::before, .popup_close::after {
    content: "";
    display: block;
    width: 1px;
    padding-top: 12%;
    background-color: #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    margin: 0 5% 0 auto;
}

.popup_close::after {
    position: absolute;
    top: 0;
    right: 0;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.popup_list {
    width: 100%;
    height: 100%;
    background-color: #fff;
}

.popup_details {
    display: none;
    position: relative;
    padding: 0 0 calc(80 / 630 * 100%);
}

.popup_details .special_list_box {
    margin: 0 0 calc(35 / 630 * 100%);
}

.popup_details .special_list_photo {
    border: 0;
}

.popup_details .special_list_btn {
    width: calc(390 / 630 * 100%);
    margin: 0 0 0 auto;
    padding: calc(19 / 630 * 100%) 0 calc(11 / 630 * 100%) calc(26 / 630 * 100%);
    font-size: 3.6rem;
    font-weight: 700;
    background-color: #fff;
}

.popup_details .special_list_btn::after {
    display: none;
}

.popup_details .special_list_txt {
    width: calc(510 / 630 * 100%);
    margin: 0 auto calc(55 / 630 * 100%);
    font-size: 2.8rem;
    line-height: 1.65;
}

.special_list_link {
    width: calc(450 / 630 * 100%);
    margin: 0 auto;
}

.special_list_link .btn_box::before {
    background-color: #e5004f;
    margin: calc(-18 / 450 * 100%) 0 0 calc(-18 / 450 * 100%);
}

.special_list_link .btn_box_border {
    padding: 1.3em 0;
    font-size: 2.8rem;
    font-family: "Noto Sans JP", "メイリオ", "ＭＳ Ｐゴシック", "小塚ゴシック Pro R", "ヒラギノ角ゴ Pro W3", "Meiryo", "MS PGothic", "KozGoPro-Regular", "Hiragino Kaku Gothic Pro", "MS UI Gothic", Osaka, sans-serif;
    border: 0.35em solid #000;
}

@media screen and (min-width:768px) {
    .popup_bg {
        cursor: pointer;
    }
    
    .popup_area {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }
    
    .popup_inner {
        width: calc(800 / 1100 * 100%);
        max-width: 800px;
        margin: auto;
        padding: calc(60 / 1100 * 100%) 0;
        -ms-flex-item-align: start;
        align-self: flex-start;
    }
    
    .popup_close {
        cursor: pointer;
        margin: -7% 0 0;
    }
    
    .popup_close::before, .popup_close::after {
        padding-top: 7%;
        margin: 0 3% 0 auto;
    }
    
    .popup_close:hover::before, .popup_close:hover::after {
        opacity: 0.7;
    }
    
    .popup_list {
        padding: calc(80 / 800 * 100%) calc(85 / 800 * 100%);
    }
    
    .popup_details {
        padding: 0;
    }
    
    .popup_details .special_list_box {
        margin: 0 0 calc(40 / 630 * 100%);
    }

    .popup_details .special_list_ttl {
        padding: calc(22 / 630 * 100%) 0;
        font-size: 2.4rem;
    }
    
    .popup_details .special_list_photo {
        z-index: 2;
    }
    
    .popup_details .special_list_btn {
        width: calc(260 / 630 * 100%);
        margin: calc(-20 / 630 * 100%) 0 0 calc(400 / 630 * 100%);
        padding: calc(23 / 630 * 100%) 0 calc(13 / 630 * 100%) calc(20 / 630 * 100%);
        font-size: 2.4rem;
    }
    
    .popup_details .special_list_txt {
        width: 100%;
        font-size: 1.6rem;
        line-height: 1.75;
    }
    
    .special_list_link {
        width: calc(340 / 630 * 100%);
    }
    
    .special_list_link .btn_box::before {
        margin: calc(-13 / 340 * 100%) 0 0 calc(-13 / 340 * 100%);
        margin: -3.82% 0 0 -3.82%;
    }
    
    .special_list_link .btn_box_border {
        font-size: 2.1rem;
    }
}

@media screen and (min-width:1100px) {
    .popup_inner {
        padding: 60px 0;
    }
}
