.course-section,
.lunch-section,
.wine-section {
    padding: 0 25px;
    padding-top: 64px;
}
.course-label {
    font-size: 20px; font-size: 2.0rem; font-size: 5.333vw;
    line-height: 28px; line-height: 2.8rem; line-height: 7.555vw;
    text-align: center;
    padding: 24px 0 40px 0;
}
.course-label-notes {
    font-size: 12px; font-size: 1.2rem;
    line-height: 20px; line-height: 2.0rem;
    text-align: center;
    padding: 16px 0 32px 0;
}

.course-container,
.course-group-container {
    max-width: 420px;
    margin: 0 auto;
    text-align: center;
}
.course-group {
    width: 100%;
}
.course-group+.course-group {
    padding-top: 42px;
}

.option-group {
    padding-top: 48px;
    margin: 0 -25px;
    width: calc(100% + 50px);
}
.option-group .course-menu-label {
    padding-right: 25px;
    padding-left: 25px;
}
.option-group .course-menu {
    background-color: #e6e6e6;
    text-align: left;
    padding-left: 25px;
    padding-right: 25px;
}
.option-group .course-menu:first-of-type {
    padding-top: 52px;
}
.option-group .course-menu:last-of-type {
    padding-bottom: 52px;
}

.course-menu,
.course-menu-label {
    padding: 22px 0;
    border-bottom: solid 1px #e6e6e6;
    font-size: 10px; font-size: 1.0rem;
    line-height: 16px; line-height: 1.6rem;
}
.course-menu-label {
    font-size: 14px; font-size: 1.4rem;
    line-height: 22px; line-height: 2.2rem;
    font-weight: 400;
    padding-bottom: 30px;
}
.course-menu .ja {
    font-size: 14px; font-size: 1.4rem;
    line-height: 22px; line-height: 2.2rem;
    font-weight: 400;
    margin: 8px 0 -3px 0;
}
.course-menu .course-menu-caption {
    font-size: 13px; font-size: 1.3rem;
    line-height: 23px; line-height: 2.3rem;
    margin-top: 12px;
}
.course-menu .or+.or {
    margin-top: 24px;
    padding-top: 24px;
    position: relative;
}
.course-menu .or+.or::before {
    content: "又は";
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: -8px;
}

@media screen and (min-width: 450px)
{
    .course-label {
        font-size: 24px; font-size: 2.4rem;
        line-height: 34px; line-height: 3.4rem;
    }
}

@media screen and (min-width: 480px)
{
    .course-section:last-of-type .option-group,
    .lunch-section:last-of-type .option-group {
        margin-bottom: 64px;
    }
}

@media screen and (min-width: 720px)
{
    .course-container,
    .course-group-container {
        max-width: 640px;
    }
    .course-section,
    .lunch-section,
    .wine-section {
        padding-top: 80px;
    }

    .option-group {
        padding-top: 48px;
        margin: 0;
        width: 100%;
    }
    .option-group .course-menu-label {
        padding-right: 0;
        padding-left: 0;
    }
    .option-group .course-menu {
        padding-left: 32px;
        padding-right: 32px;
    }
    .option-group .course-menu:first-of-type {
        padding-top: 72px;
    }
    .option-group .course-menu:last-of-type {
        padding-bottom: 72px;
    }

    .course-section:last-of-type .option-group,
    .lunch-section:last-of-type .option-group {
        margin-bottom: 96px;
    }

    .course-menu,
    .course-menu-label {
        padding: 32px 0;
        font-size: 12px; font-size: 1.2rem;
        line-height: 20px; line-height: 2.0rem;
    }
    .option-group .course-menu {
        line-height: 18px; line-height: 1.8rem;
    }
    .course-menu-label {
        font-size: 18px; font-size: 1.8rem;
        line-height: 30px; line-height: 3.0rem;
        padding-bottom: 24px;
    }

    .course-menu .ja {
        font-size: 20px; font-size: 2.0rem;
        line-height: 30px; line-height: 3.0rem;
        margin: 12px 0 -2px 0;
    }
    .option-group .course-menu .ja {
        font-size: 16px; font-size: 1.6rem;
        line-height: 24px; line-height: 2.4rem;
    }

    .course-menu .course-menu-caption {
        font-size: 12px; font-size: 1.2rem;
        line-height: 20px; line-height: 2.0rem;
        margin-top: 12px;
    }
    .course-menu .or+.or {
        margin-top: 32px;
        padding-top: 32px;
        position: relative;
    }
    .course-menu .or+.or::before {
        top: -10px;
    }
}

@media screen and (min-width: 960px)
{
    .container {
        padding: 40px 0 120px 0;
    }
    .course-section,
    .lunch-section,
    .wine-section {
        padding: 80px 40px 0 40px;
    }
    .course-label {
        padding: 16px 0;
    }

    .course-container {
        /*max-width: 1240px;*/
        padding: 40px 0;
    }

    .course-group-container {
        display: flex;
        justify-content: space-between;
        max-width: 1240px;
        padding: 40px 0;
    }

    .course-group {
        width: 640px;
    }
    .option-group {
        width: 440px;
    }
    .course-group+.course-group {
        padding-top: 0px;
    }
    .course-group:nth-of-type(even) {
        margin-left: 40px;
    }
    .course-section:last-of-type .option-group,
    .lunch-section:last-of-type .option-group {
        margin-bottom: 0;
    }

    .option-group .course-menu {
        padding-right: 32px;
        padding-left: 32px;
    }
    .option-group .course-menu:first-of-type {
        padding-top: 72px;
    }
    .option-group .course-menu:last-of-type {
        padding-bottom: 72px;
    }
}






#wine-container {
    background-color: #fff;
}
.wine-group {
    max-width: 420px;
    margin: 0 auto;
    padding-bottom: 64px;
}
.wine-group:last-of-type {
    padding-bottom: 100px;
}
.wine-group-title {
    font-size: 20px; font-size: 2.0rem; font-size: 5.333vw;
    line-height: 25px; line-height: 2.5rem; line-height: 6.666vw;
    padding: 24px 0;
    text-align: center;
}

.wine {
    padding: 24px 0;
    border-bottom: solid 1px #e6e6e6;
}

.wine-name,
.wine-price {
    font-size: 14px; font-size: 1.4rem;
    line-height: 22px; line-height: 2.2rem;
    font-weight: 400;
}
.wine-name .en,
.wine-name .ja {
    display: block;
}
.wine-name .en {
    font-size: 10px; font-size: 1.0rem;
    line-height: 16px; line-height: 1.6rem;
}
.wine-name .ja {
    margin: 8px 0 0 0;
}
.wine-caption {
    font-size: 12px; font-size: 1.2rem;
    line-height: 20px; line-height: 2.0rem;
    margin-top: 16px;
}

.wine-price {
    text-align: right;
}
.wine-price span {
    display: block;
}

@media screen and (min-width: 450px)
{
    .wine-group-title {
        font-size: 24px; font-size: 2.4rem;
        line-height: 30px; line-height: 3.0rem;
    }
}

@media screen and (min-width: 720px)
{
    .wine-group {
        max-width: 640px;
    }
    .wine-group:last-of-type {
        padding-bottom: 110px;
    }
    .wine-group-title {
        font-size: 24px; font-size: 2.4rem;
        line-height: 30px; line-height: 3.0rem;
    }
    
    .wine {
        padding: 32px 0;
    }
    
    .wine-name,
    .wine-price {
        font-size: 20px; font-size: 2.0rem;
        line-height: 30px; line-height: 3.0rem;
    }
    .wine-name .en,
    .wine-name .ja {
        display: block;
    }
    .wine-name .en {
        font-size: 12px; font-size: 1.2rem;
        line-height: 20px; line-height: 2.0rem;
    }
    .wine-name .ja {
        margin: 10px 0 0 0;
    }
    .wine-caption {
        font-size: 14px; font-size: 1.4rem;
        line-height: 22px; line-height: 2.2rem;
        margin-top: 14px;
    }
}

@media screen and (min-width: 960px)
{
    .wine-group {
        max-width: 1160px;
    }
    .wine-group:last-of-type {
        padding-bottom: 0;
    }
    .wine-group-title {
        text-align: left;
    }

    .wine-list-2col {
        display: flex;
        justify-content: space-between;
    }

    .wine:not(.wine-set) {
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
    }
    .wine-set {
        width: 540px;
    }
    .wine-set:nth-of-type(even) {
        margin-left: 40px;
    }
    .wine:not(.wine-set) .wine-price {
        white-space: nowrap;
        padding-left: 24px;
    }
}

.special-container {
    border-top: solid 1px #e6e6e6;
    display: block !important;
    max-width: 100% !important;
    margin: 40px auto 40px !important;
}
.price_single {
    font-size: 16px;
    padding: 40px 0 24px;
}
.special {
    margin: 40px auto 80px;
    border: solid 1px #000;
    padding: 40px;
    max-width: 1240px;
    text-align: center;

}

.special .ttl {
    font-size: 16px;
    width: 640px;
    margin: auto;

}

.special .ttl span {
    font-size: 22px;
    display: block;
    margin: 8px 0 40px;
}

.special .ttl span.p {
    font-size: 15px;
    display: inherit;
}

.special p.ttl_dis {
    font-size: 16px;
    padding-bottom: 16px;
    line-height: 180%;
    width: 640px;
    margin: auto;
    @media (max-width: 767px) { 
        width: 100%;
     }
}
.special p {
    font-size: 16px;
    padding-bottom: 16px;
    line-height: 180%;
}

.special a {
    color: #000;
}

br.pc {
    display: block;
}
br.sp {
    display: none;
}

@media screen and (max-width: 768px) {
    .special {
        margin-top: 40px;
        border: solid 1px #000;
        padding: 40px 16px;
    }

    .special .ttl {
        font-size: 14px;
        width: 100%;
    }

    .special .ttl span {
        font-size: 19px;
    }

    .special .ttl span.p {
        font-size: 14px;
        display: inherit;
    }



    .special p {
        font-size: 13px;
        padding-bottom: 0;
        width: 100%;
    }
    br.pc {
        display: none;
    }

    br.sp {
        display: block;
    }


    .price_single {
        font-size: 14px;
        padding: 40px 0 0px;
    }
    
}
