* {
    font-family: 'BIZ UDPGothic', sans-serif;
}

body {
    color: var(--black);
    background: #FFF8C8 !important;
}

.wrapper {
    margin: 60px auto;
    max-width: 750px;
    width: 100%;
    background: white;
    border-radius: 20px;
}

.process {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 4px;
}

.shiori {
    max-width: 640px;
    margin: 0px auto 30px;
    box-sizing: border-box;
}

@media (max-width: 768px) {
    .shiori {
        max-width: 96%;
    }
}

.shiori img {
    width: 100%;
}

#code_form .code input[type=text] {
    font-size: 18px;
    height: 2em;
    width: 70px;
}

@media (max-width: 768px) {

    /* #wrapper {
        margin: 20px auto 60px;
        width: 93%;
    } */
    .wrapper {
        margin: 20px auto 60px;
        width: 93%;
    }

    #wrapper p {
        font-size: 16px;
        text-align: left;
        margin-top: 12px;
    }
}

#card,
#mail {
    display: block;
    max-width: 440px;
    margin-bottom: 0;
}

.deadline-box {
    border: 8px solid #f7e58b;
    padding: 24px;
    max-width: 640px;
    margin: 30px auto;
    text-align: center;
    box-sizing: border-box;
}

.title {
    display: block;
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 16px;
}

.date-block {
    margin-bottom: 16px;
}

.date {
    display: inline-block;
    font-size: 28px;
    font-weight: bold;
}

.note-block {
    justify-content: center;
    align-items: flex-start;
    gap: 4px;
    line-height: 1.6;
    text-align: center;
    margin: 0 auto;
}

.note-mark {
    display: none;
}

.note {
    font-size: 16px;
    font-weight: normal;
    text-align: center;
}

/* スマホ対応 */
@media (max-width: 768px) {
    .deadline-box {
        border: 5px solid #f7e58b;
        max-width: 95%;
        padding: 10px;
        font-size: 16px;
    }

    .date {
        font-size: 24px;
    }

    .deadline-box .sp-only {
        display: inline;
    }

    .note-block {
        max-width: 100%;
        display: flex !important;
        flex-direction: row;
        align-items: flex-start;
    }

    .note {
        font-weight: normal;
        text-align: left !important;
    }

    .note-mark {
        display: block;
        font-size: 14px;
        flex-shrink: 0;
    }

    #code_form .error {
        text-align: center;
    }
}

.sp-only {
    display: none;
}

@media screen and (max-width: 767px) {
    .pc-only {
        display: none;
    }

    .sp-only {
        display: block;
        width: 100%;
    }
}

#code_form {
    padding-bottom: 0;
}

#code_form img {
    display: block;
    width: 63%;
    max-width: 440px;
    margin: auto;
    padding: 28px;
}

@media (max-width: 768px) {
    #code_form img {
        display: block;
        width: 95%;
        margin: auto;
        padding: 18px 0 0 0;
    }
}

.logo {
    background: #FDD62F;
    border-radius: 20px 20px 0 0;
}

.logo-suginami img {
    max-width: 20%;
    margin: auto;
    display: block;
    padding: 30px;
}

@media (max-width: 768px) {
    .logo-suginami img {
        width: 40%;
        max-width: 165px;
    }
}

@media (max-width: 768px) {
    .logo-suginami img {
        max-width: 40%;
        padding: 18px;
    }
}


#wrapper .logo img {
    max-width: 30%;
    margin: auto;
    padding: 20px;
    display: block;
}

@media (max-width: 768px) {
    #wrapper .logo img {
        max-width: 40%;
        padding: 18px;
    }
}

#card h2,
#mail h2,
#present h2 {
    font-size: 16px;
    padding-bottom: 16px;
}

@media (max-width: 768px) {

    #card h2,
    #mail h2,
    #present h2 {
        text-align: left;
    }
}

@media (max-width: 768px) {
    .pc-only {
        display: none;
    }
}

.text {
    text-align: center;
    font-size: 16px;
    padding-bottom: 16px;
    display: block;
}

@media (max-width: 768px) {
    .text {
        text-align: left;
    }
}

.code-text {
    display: block;
    width: 138px;
    margin: auto;
    padding-bottom: 5px;
    font-size: 16px;
    text-align: left;
}

@media (max-width: 768px) {
    .pTop {
        text-align: right;
        padding-right: 10px;
    }
}

#login_btn {
    background: #EB8100;
}


/*------------------------------------------
 *
 * ユニウェブスタイル
 *
------------------------------------------*/
#uniweb-open-fixed {
    display: block;
    width: 70px;
    height: 70px;
    border-radius: 50%;
    box-shadow: 0px 0px 10px -1px var(--black-transparent);
    text-indent: -9999px;
    background: transparent url("/receive/tmp_set/tokyo_leisure-2000/images/uniweb_mark.png") center / contain no-repeat !important;
    position: fixed;
    bottom: 30px;
    right: 5px;
    border: none;
}



/* ユニウェブウィジェットボタン表示/非表示 */
button#uniweb-open {
    display: none;
    /* デフォルトでは表示 */
}

button#uniweb-open-fixed {
    display: block;
    bottom: 50%;
    right: 14px;
    background: transparent url("/receive/tmp_set/suginamiku_bousai7-3000/images/uniweb_mark.png") center / contain no-repeat !important;
    box-shadow: none;
    width: 40px;
    height: 40px;
}



/* ユニウェブ言語ボタンデフォルトデザイン */
#uniweb-language-switch {
    /* z-index: 1 !important; */
    /* ↑ハンバーガーメニューに被らないように */
    z-index: 99 !important;
}

#uniweb-language-switch {
    top: unset !important;
    right: unset !important;
    bottom: 30px !important;
    left: 5px !important;
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
    #uniweb-language-switch {
        top: 100px !important;
        right: 30px !important;
        bottom: unset !important;
        left: unset !important;
    }
}

@media screen and (min-width: 1025px) {
    #uniweb-language-switch {
        top: 18px !important;
        right: 30px !important;
        bottom: unset !important;
        left: unset !important;
    }
}

.uniweb-language-switch-button .uniweb-language-switch-icon {
    width: 14px;
    height: 14px;
}

.uniweb-language-switch-button .uniweb-language-switch-text {
    font-size: 14px;
    line-height: 1.5;
}

/*開始前*/
.before_start {
    margin-bottom: 60px;
}

.before_start h2 {
    font-size: 16px;
    font-weight: bolder;
    text-align: center;
    margin-bottom: 2em;
    padding: 10px;
}

.before_start p {
    font-size: 16px !important;
    text-align: center !important;
}



/*footer*/
.copyright {
    background: #0E945E !important;
    margin-top: 32px !important;
    font-size: 16px !important;
    line-height: 20px !important;
    text-align: center !important;
}

footer {
    line-height: 24px !important;
    border-top: 1px solid #0E945E !important;
    padding-top: 30px !important;
}

footer .logo-footer img {
    margin-left: 0 !important;
    width: 16% !important;

}

.pTop {
    text-align: right !important;
    padding-top: 0 !important;
    padding-right: 0px !important;
}

.pTop a {
    display: inline-block !important;
    padding: 4px 16px 4px 32px !important;
    position: relative !important;
    color: #333333 !important;
    font-size: 14px !important;
    line-height: 21px !important;
}

.pTop a::after {
    position: absolute !important;
    top: 0 !important;
    left: 50% !important;
    display: block !important;
    content: '' !important;
    width: 4px !important;
    height: 4px !important;
    margin-top: -1px !important;
    border-top: 2px solid #333333 !important;
    border-left: 2px solid #333333 !important;
    -webkit-transform: rotate(45deg) !important;
    -ms-transform: rotate(45deg) !important;
    transform: rotate(45deg) !important;
}

.pTop a {
    background: none !important;
}

footer dl.fInfo-center {
    border-left: 1px solid #CCC !important;
    padding: 8px 0 8px 32px !important;
    position: absolute !important;
    right: 400px !important;
    top: -15px !important;
    width: 290px !important;
}

.tell {
    font-size: 24px !important;
    padding: 0 !important;
    align-items: center !important;
    display: flex !important;
    justify-content: flex-start !important;
    margin: 5px 0 !important;
}

.tell img {
    vertical-align: middle !important;
    width: 60px;
}

footer dl.fInfo {
    font-size: 16px !important;
    padding: 8px 0 38px 32px !important;
    top: -15px !important;
    width: 256px !important;
}

.contact {
    background: #EB8100 !important;
    max-width: 256px !important;
}

.contact:hover {
    background: #F29C33 !important;
}

footer ul.fNavi li {
    font-size: 16px !important;
    padding: 12px 16px 0 0 !important;
}

@media (max-width: 960px) {
    .pTop {
        text-align: right !important;
        padding-right: 10px !important;
    }

    .pTop a {
        display: inline-block !important;
        padding: 4px 16px !important;
        position: relative !important;
        color: #333333 !important;
        font-size: 16px !important;
        line-height: 24px !important;
    }

    .pTop a::after {
        position: absolute !important;
        top: 0% !important;
        right: 50% !important;
        display: block !important;
        content: '' !important;
        width: 4px !important;
        height: 4px !important;
        margin-top: -1px !important;
        border-top: 2px solid #333333 !important;
        border-left: 2px solid #333333 !important;
        -webkit-transform: rotate(45deg) !important;
        transform: rotate(45deg) !important;
    }

    footer {
        font-size: 16px !important;
        padding-top: 0 !important;
    }

    footer .fBox {
        width: 100% !important;
    }

    footer .logo-footer img {
        display: block !important;
        width: 32% !important;
        min-width: 120px !important;
        max-width: 170px !important;
        margin: auto !important;
    }

    footer ul.fNavi {
        margin-bottom: 16px !important;
    }

    footer ul.fNavi li {
        display: block !important;
        border-bottom: 1px solid #CCC !important;
        padding: 10px !important;
        font-size: 16px !important;
        width: auto !important;
    }

    footer dl.fInfo {
        padding: 20px 10px 0 !important;
        text-align: center !important;
        font-size: 16px !important;
    }

    footer dl.fInfo dd img {
        width: 60px !important;
        vertical-align: middle !important;
        margin: 0 4px 4px 0 !important;
    }

    footer dl.fInfo dd {
        line-height: 1.4 !important;
    }

    footer dl.fInfo li.tell {
        font-size: 24px !important;
        margin: 0 0 10px 0 !important;
    }

    li.tell {
        justify-content: center !important;
    }

    footer {
        border-top: 5px solid #0E945E !important;
    }

    footer .fWrap {
        width: 100% !important;
        max-width: 1000px !important;
        flex-direction: column !important;
        align-items: center !important;
        text-align: left !important;
        gap: 20px !important;
    }

    footer .logo-footer {
        margin-bottom: 15px !important;
    }

    .fNavi {
        flex-direction: column !important;
        align-items: center !important;
        gap: 10px !important;
    }

    footer dl.fInfo-center {
        position: static !important;
        font-size: 16px !important;
        border-left: none !important;
        padding: 0 !important;
        width: auto !important;
        text-align: center !important;
    }

    footer dl.fInfo {
        margin-left: 0 !important;
        width: auto !important;
    }

    .contact {
        max-width: 280px !important;
    }
}

.clear {
    background-color: #FFF !important;
}

.box1000.cl.clear {
    background-color: transparent !important;
}