@charset "utf-8";
* { margin: 0; padding: 0; list-style: none; box-sizing: border-box; word-break: keep-all; } 
body { font-family: 'Interop', sans-serif; font-size: 14px; line-height: 1.25em; background: #fffbf6; color: #3c3017; color: #5b4a26; font-weight: 400; } 
a:link { color: #5b4a26; text-decoration: none; } 
a:visited { color: #5b4a26; }
/* a:visited { color: #000; }  */
ul li { list-style: none; } 
h1 { font-family: 'TTBookendBatangSB'; font-size: 30px; color: #3e2f1c; line-height: 1.3em; }
h2 { font-family: "Eulyoo1945-SemiBold"; font-size: 24px; color: #624b2d; line-height: 1.3em; }
p { line-height: 1.25em; }
.one-page-content { width: 90%; height: 100vh; margin-left: auto; }
.imgbox { background-repeat: no-repeat; background-size: cover; background-position: center center; } 
.viewmore { margin-right: -8px; transition: all .3s ease-in-out; }
.viewmore:hover { margin-right: 0; }
.viewmore i { opacity: 0; transition: all .3s ease-in-out; color: #5b4a26;  }
.viewmore:hover i {  opacity: 1; margin-left: 10px; }


header { position: fixed; left: 0; top: 0; display: flex; flex-direction: column; justify-content: space-between; align-items: center; width: 10%; height: 100%; padding: 40px 0; z-index: 99; transition: .3s ease-in-out; background: #fffbf6;  }
header .logo { width: 80px; height: auto; }
header .logo.logo-m { display: none; }
header .logo img { width: 100%; }
header .navbox> ul> li a { display: block; width: 100%; height: 100%; text-align: center; padding: 20px 0; color: #111; font-size: 16px;}
header .navbox> ul> li> a { font-weight: 500; font-family: 'TTBookendBatangSB'; }
header .navbox> ul> li a i { display: none; }
/*submenu*/
header .navbox> ul> li .submenu { opacity: 0; max-height: 0; overflow: hidden; transition: all .3s ease-in-out; }
header .navbox> ul> li .submenu li a { display: block; padding: 8px 0; transition: all .3s ease-in-out; font-size: 14px; color: #333; } 
header .navbox> ul> li .submenu li a:hover { opacity: .8; }
header .icons { display: flex; flex-direction: column; }  
header .icons .reserve { position: relative; margin-bottom: 15px; transition: .3s ease-in-out; }
header .icons .reserve::after { position: absolute; left: 50%; bottom: 0; transform: translate(-50%, 100%); content: "실시간예약"; font-size-adjust: 12px; font-family: 'Interop';  }
header .icons .reserve:hover a i { opacity: .7; }
header .icons .reserve:hover::after { opacity: .7; }
header .icons .call { display: none; }
header .icons li a { padding: 5px; cursor: pointer; }
header .icons li a i { font-size: 26px; line-height: 1.5em; }
header .icons li a span { display: none; }
header .icons #openIcon { display: none; }


main { position: relative;}
main .main-slide { width: 100%; height: 100%; overflow: hidden; }
main .txtbox { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); font-family: "Eulyoo1945-Regular"; font-weight: 300; font-size: 24px; color: #fffbf6; z-index: 1; line-height: 1.25em; text-align: center; text-shadow: 0 1px 2px rgba(0, 0, 0, .3); }
main .swiper-pagination { left: auto; right: 40px; top: 50%; bottom: auto; transform: translateY(-50%); color: #fffbf6; width: auto; display: flex; flex-direction: column; align-items: center; text-shadow: 0 1px 2px rgba(0, 0, 0, .3); }


footer { display: flex; flex-direction: column; }
/* footer.one-page-content { width: 90%;  margin-left: auto; } */
footer .imgbox { position: relative; width: 100%; height: 100%; margin-bottom: 60px; }
footer .imgbox .txtbox { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); color: #fffbf6; text-align: center; text-shadow: 0 1px 2px rgba(0, 0, 0, .1); width: 100%; }
footer .imgbox .txtbox p { margin-bottom: 70px; font-family: "Eulyoo1945-Regular"; line-height: 1.7em; }
footer .imgbox .txtbox a { color: #fffbf6; }
footer .imgbox .txtbox a i { color: #fffbf6; }
footer .f-infos { display: flex; justify-content: space-between; align-items: end; padding: 0 40px 40px; margin-top: auto; margin-bottom: 0; bottom: 0; color: #3c3017; }
footer .f-infos .lefts> :not(:last-child) { margin-bottom: 10px; }
footer .f-infos .lefts> :nth-child(4) { display: flex; align-items: center; }
footer .f-infos ul li .vline { display: block; width: 1px; height: 12px; background: #3c3017; margin: 0 5px; }
footer .f-infos .lefts li img { width: 20px; margin-left: 10px; }
footer .f-infos .rights { text-align: right; }
footer .f-infos .rights> :first-child { display: flex; align-items: center; justify-content: flex-end; }
footer .f-infos .rights li a { display: inline-block; width: auto; }
.who { transition: all .2s ease-in-out; } 
.who:hover { color: #ff5a53 !important; } 

@media screen and (max-width: 1440px) {  
    footer .imgbox { margin-bottom: 40px; }
}

@media screen and (max-width: 1024px) {  
    .one-page-content { width: 100%; height: 100vh; margin-left: auto; }

    header {  flex-direction: row; width: 100%; height: 80px; padding: 0 4%; background: none; }
    header.on { background: #fffbf6;}
    header .logo { display: none; }
    header .logo.logo-m { display: block; width: 120px; height: auto; filter: invert(100); }
    header.on .logo.logo-m { filter: invert(0); }
    header .navbox { visibility: hidden; position: absolute; left: 0; bottom: 0; transform: translateY(100%); width: 100%; height: 100vh; background: rgba(0, 0, 0, 0.2); }
    header .navbox ul { background: #fffbf6; max-height: 0; overflow: hidden; transition: all .3s ease-in-out; height: 80vh;}
    header .navbox> ul> li a { text-align: left; padding-left: 4%; }
    header .navbox> ul> li a i { display: inline-block; margin-left: 10px; transition: .3s ease-in-out; }
    header .navbox> ul> li.active a i { transform: rotate(180deg); }
    header .navbox> ul> li .submenu li a { padding-left: 8%; }
    header .icons { flex-direction: row; align-items: center; }  
    header .icons .reserve { margin-bottom: 0; }
    header .icons .reserve::after { display: none; }
    header .icons .call { display: block; } 
    header .icons> :not(:last-child) { margin-right: 15px; }
    header .icons li a { display: flex; flex-direction: column; align-items: center; color: #fffbf6; }
    header.on .icons li a { color: #5b4a26;}
    header .icons li a span { display: block; font-weight: 400; font-size: 12px;} 
    /*햄버거 버튼*/
    header .icons #openIcon { display: block; margin-left: 15px; }
    header .icons #openIcon { position: relative; display: flex; justify-content: end; width: 32px; height: 24px; cursor: pointer; } 
    header .icons #openIcon span { position: absolute; display: block; height: 2px; width: 32px; background: #fffbf6; ; cursor: pointer; transition: all .3s ease-in-out; } 
    header.on .icons #openIcon span { background-color: #5b4a26; } 
    header .icons #openIcon :first-child { top: 0; left: 0; } 
    header .icons #openIcon :nth-child(2) { top: 50%; transform: translateY(-50%); } 
    header .icons #openIcon :last-child { bottom: 0; left: 0; } 
    header .icons #openIcon.on { z-index: 999; } 
    header .icons #openIcon.on :first-child { transform: rotate(45deg) translateY(-50%); top: 50%; } 
    header .icons #openIcon.on :nth-child(2) { top: 50%; transform: translateY(-50%); opacity: 0; } 
    header .icons #openIcon.on :last-child { transform: rotate(-45deg) translateY(50%); bottom: 50%; } 

    main .swiper-pagination { right: 4%; }

    footer { padding: 80px 0 0; }
    footer .imgbox { height: 100%; }
    footer .f-infos { padding: 40px 4%; }
} 


@media screen and (max-width: 840px) {
    body { font-size: 14px; } 
    h1 { font-size: 24px; }
    h2 { font-size: 20px; }
    .one-page-content { height: auto; }

    header .icons> :not(:last-child) { margin: 0; }

    main.one-page-content { height: 80vh; }
    main .txtbox { font-size: 16px; line-height: 1.7em; }

    footer { padding: 0; font-size: 12px; }
    footer .imgbox { height: auto; aspect-ratio: 2.414; margin: 0; }
    footer .imgbox .txtbox p { margin-bottom: 40px; }
    footer .f-infos { display: block;  }
    footer .f-infos .lefts { margin-bottom: 30px; }
    footer .f-infos .lefts> :not(:last-child) { margin-bottom: 5px; }
    footer .f-infos ul li .vline { height: 10px; }
}


@media screen and (max-width: 600px) { 
    header .logo.logo-m { width: 100px; }
    header .icons> :not(:last-child) { margin-right: 8px; }
    header .navbox> ul> li a { font-size: 14px;}

    footer .imgbox { aspect-ratio: 1.414; }
}


@media screen and (max-width: 340px) { 
    header .icons #openIcon { margin-left: 10px;}
}
/* end */
