@charset "UTF=8";

/* ---Default Styling--- */

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

figure {
    margin: 0;
}

img {
    max-width: 100%;
    vertical-align: middle;
}

.main {
    overflow: hidden;
    max-width: 1090px;
    margin: 0 auto;
}

p {
    font-size: 16px;
}


p,
h2,
h3,
h4,
h5,
th,
td,
a,
.label {
    font-family: "Noto Serif JP", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
}

h3 {
    font-weight: 700;
}


/* buttonデザイン */

#top-button {
    position: fixed;
    display: inline-block;
    text-align: center;
    padding: 15px;
    border: 1px solid black;
    background-color: rgb(255, 255, 255);
    box-shadow: 1px 1px 5px #b3b2b2;
    z-index: 99;
    bottom: 20px;
    right: 20px;
}

.top-button-img {
    transform: rotateX(180deg);
}

#top-button:hover {
    background-color: #c7cde0;
}





/* --Reusable Classes-- */



.h2,
.main-menu-h3,
.h4 {
    text-align: center;
}

.h2 {

    color: #E7B55A;
    margin-bottom: 100px;
}

.h2-img {
    width: 300px;
}

.main-about-h2-first {
    font-size: 48px;
}



.container {
    margin: 0 30px;
}

.main-margin {
    margin-bottom: 200px;
}


.header-button,
.yoyaku-button {
    border: 1px solid;
    display: inline-block;
    padding: 5px 10px;
}

.header-button:hover,
.yoyaku-button:hover {
    color: #E7B55A;
}

.header-button:focus,
.yoyaku-button:focus {
    cursor: pointer;
}


/* フェードイン */


.main-about-anime {
    opacity: 0;
    transform: translateX(20px);
    animation: fadeIn 1s ease 0.3s forwards;
    /* animation: fade-in 3s;
    animation-fill-mode: forwards; */
}

@keyframes fadeIn {
    /* from {
        opacity: 0;
        transform: translateY(4rem);
    } */

    to {
        opacity: 1;
        transform: none;
        transform: translateY(0);
    }
}


.main-about {


    /* 個別の view timeline を設定 */

    view-timeline-name: --fadeTimeline;
    view-timeline-axis: block;

    /* アニメーションを timeline にバインド */
    animation: fadeIn linear both;
    animation-timeline: --fadeTimeline;
    animation-range: entry 0% cover 40%;
}


/* --Header-- */


.header-container {
    padding: 20px 30px;
}


.header-container-figure {
    text-align: center;
    margin-bottom: 20px;
}

.header-h1-img {
    width: 100px;
}


.header-link :first-child {
    text-align: right;
}

.header-button {
    margin-bottom: 20px;
}



.header-nav-ul {
    display: flex;
    justify-content: space-between;
}


.header-nav-item a:hover {
    color: #E7B55A;
}


/* --Main-top-- */

.main-top {
    background-image: url(../img/main_top.jpg);
    background-position: left;
    background-size: cover;
    height: 90vh;
}

.main-top h1 p {
    color: rgb(255, 255, 255);
    display: inline;
    font-size: 40px;
    padding: 50px 20px 0 0;
    text-shadow: 1px 1px 10px #030303;
    margin-top: 5px;
    display: flex;
    justify-content: right;
}



/* --Main-about-- */

.main-about {
    padding-top: 150px;
    padding-bottom: 200px;
}


.main-about-img {
    margin-bottom: 50px;
    margin: -30px;
    padding: 30px 0 70px 0;
}


.main-about-h3 {
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 25px;
}

/* --Main-menu-- */



.main-menu-div input:checked+label {
    background: var(--tab-color);
    color: #9ba5c2;
    padding-bottom: 200px;

}

.main-menu-div label:hover {
    cursor: pointer;
}

.main-menu-div {
    text-align: center;
}

.main-menu-div label {
    margin-right: 20px;
}

.main-menu-div .last {
    margin: 0;
}



.main-menu-div #before-veg:checked~.main-menu-alc-ul .main-menu-alc-ul-li:not(.before-veg-content),
.main-menu-div #fish:checked~.main-menu-alc-ul .main-menu-alc-ul-li:not(.fish-content),
.main-menu-div #meat:checked~.main-menu-alc-ul .main-menu-alc-ul-li:not(.meat-content),
.main-menu-div #dessert:checked~.main-menu-alc-ul .main-menu-alc-ul-li:not(.dessert-content) {
    display: none;
}

.main-menu-alc-ul-li p {
    text-align: left;
}

.label {
    font-size: 20px;

}




.main-menu-nav {
    text-align: center;
    margin-bottom: 200px;
}

.main-menu-ul-li:hover {
    color: #9ba5c2;
}

.main-menu-ul-li {
    margin-bottom: 25px;
}

.main-menu-ul-li p {
    font-size: 20px;
    margin-bottom: 10px;
}

.main-menu-ul-li img {
    width: 10px;
}


.main-menu-cose,
.main-menu-alc {
    margin-bottom: 200px;
}


.main-menu-h3 {
    margin-bottom: 150px;
}



.main-menu-h3-p {
    font-size: 36px;
}


.main-menu-alc-ul {
    padding-top: 200px;
}


.main-menu-cose-ul-li {
    margin-bottom: 150px;
}

.main-menu-cose-ul-li:last-child {
    margin-bottom: 0;
}


.main-menu-cose-ul-img {
    margin-bottom: 50px;
}


.h4 {
    margin-bottom: 30px;
}

.h4 p {
    font-size: 32px;
}

.h4 small {
    font-size: 20px;
}


.main-menu-cose-ul-li-p {
    font-size: 20px;
    margin-bottom: 50px;
}


.main-menu-alc-ul-li {
    margin-bottom: 50px;
}

.main-menu-alc-ul-li:last-child {
    margin-bottom: 0;
}


.main-menu-alc-ul-li-img {
    margin-bottom: 10px;
}


.main-menu-alc-ul-li-small {
    font-size: 12px;
}

.main-menu-alc-ul-li-small {
    font-size: 10px;
}

.main-menu-alc-ul-li-small::before,
.main-menu-alc-ul-li-small::after {
    content: '〜';
}





.main-menu-table {
    margin: 0 auto;
    margin-bottom: 150px;
}

.wine-bottom {
    margin-bottom: 50px;
}


.main-menu-table tr th:first-child {
    padding-top: 30px;
    width: 60%;
    padding-right: 35px;
}

.main-menu-table tr:first-child th:first-child {
    padding-top: 0;
    padding-bottom: 30px;
}



.wine-tr {
    border-bottom: 1px solid;
}

.wine-name {
    font-size: 24px;
}

.wine-grass,
.wine-2 {
    text-align: center;
}

.wine-2,
.wine-3 {
    width: 22%;
}

.wine-3 {
    text-align: right;
}

.wine-2 small {
    font-size: 12px;
}

.wine-2 {
    padding-right: 5px;
}


.wine-text {
    text-align: center;
}

.wine-text-small {
    font-size: 12px;
}




/* --Main-yoyaku-- */

.main-yoyaku {
    text-align: center;
}


.yoyaku-button {
    font-size: 28px;
    margin-bottom: 100px;
}


.yoyaku-call p {
    font-size: 28px;
}


/* --Main-info-- */

.main-info-table {
    /* text-align: center; */
    /* width: 300px; */
    margin: 0 auto;
}

.info-table-th,
.info-table-td {
    font-size: 20px;
}

.info-table-th {
    width: 35%;
    padding: 25px 10px;
}

.info-table-td {
    width: 65%;
}



/* --Footer-- */

.footer {
    background-color: #223670;
    color: rgb(255, 255, 255);
    text-align: center;
    padding: 100px 0 50px 0;
}


.footer-space {
    margin-bottom: 30px;
}

.footer-logo {
    width: 240px;
}


.footer-nav {
    margin-bottom: 100px;
}

.footer-nav-ul {
    display: flex;
    justify-content: center;
    gap: 30px;
}

.footer-nav-item a {
    font-size: 20px;
    color: #c7cde0;
}

.footer-nav-item a:hover {
    color: #9ba5c2;
}