@import url("https://use.typekit.net/tih6yhd.css");

/* ===== CSS VARIABLES ===== */
:root {
    /* Typekit Fonts */
    --font-orpheus: "orpheuspro", serif;
    --font-grotesk: "neue-haas-grotesk-text", sans-serif;
}

/* ===== GLOBAL STYLES ===== */
html { scroll-behavior: smooth; }
body { font-family: var(--font-grotesk); color: #fff; background-color: #000; font-size: 18px; }
.page-wrapper { overflow: hidden; }

/* ===== TYPOGRAPHY ===== */
h1, h2, h3, h4, h5, h6 { position: relative; margin: 0px 0px; background: none; line-height: 1.2em; color: var(--heading-color); font-family: var(--font-orpheus); font-weight: 400; text-transform: uppercase; }
h1 { font-size: var(--font-60); }
h2 { font-size: var(--font-45); }
h3 { font-size: var(--font-35); }
h4 { font-size: var(--font-25); }
h5 { font-size: var(--font-21); }
h6 { font-size: var(--font-16); }
.heavy-title-white { width: 100%; color: #fff; text-transform: uppercase; font-family: var(--font-orpheus); font-weight: 700; text-align: center; letter-spacing: 10px; font-size: 48px; margin-bottom: 40px; }
.heavy-title-gold { width: 100%; color: #d7b06e; text-transform: uppercase; font-family: var(--font-orpheus); font-weight: 700; text-align: center; letter-spacing: 10px; font-size: 48px; margin-bottom: 40px; }
.heavy-title { font-family: var(--font-grotesk); font-weight: 700; font-size: 45px; }
.heavy-title--gold { color: #d7b06e; }

/* ===== HOVER EFFECTS ===== */
a:hover { color: #fbc03c; text-decoration: underline; }

/* ===== HEADER / NAVIGATION ===== */
.fixed-top-bar { position: fixed; top: 0; left: 0; width: 100%; z-index: 1000; padding: 15px 0; transition: all 0.3s ease; background-color: rgba(0, 0, 0, 0.2); }
.fixed-top-bar.scrolled { background-color: rgba(0, 0, 0, 0.95); backdrop-filter: blur(10px); }
.fixed-top-bar .auto-container:nth-child(1) { padding: 8px 0px; display: flex; justify-content: flex-end; align-items: center; }
.fixed-top-bar .auto-container:nth-child(2) { position: relative; display: flex; justify-content: space-evenly; align-items: center; padding: 0 15px; }
.fixed-top-bar .logo img { max-height: 75px; max-width: 400px; }
.fixed-top-bar .logo-mobile { max-width:70px; display: none; }
.fixed-top-bar .nav-toggler { position: absolute; right: 0; width: 80px; display: flex; align-items: center; background-color: transparent; }
.fixed-top-bar .nav-toggler button { background-color: transparent; border: none; outline: none; }
.fixed-top-bar .header-link a { color: #fff; }
.fixed-top-bar .header-link a:hover { color: #fbc03c; text-decoration: none; }
.fixed-top-bar, .main-header { background-color: rgba(0, 0, 0, 0.2); }
.main-header { margin-top: 105px; }
.header-link { color: #fff; text-transform: uppercase; font-size: 14px; min-width: 100px; text-align: center; }

/* ===== HAMBURGER MENU ANIMATION (REVERSED) ===== */
.hamburger { transform: scaleX(-1); }
.hamburger span { transition: all 0.3s ease; }
body.mobile-menu-visible .hamburger .top-bun { transform: scaleX(-1) translateY(8px) rotate(45deg); }
body.mobile-menu-visible .hamburger .meat { opacity: 0; transform: scaleX(-1) scaleX(0); }
body.mobile-menu-visible .hamburger .bottom-bun { transform: scaleX(-1) translateY(-8px) rotate(-45deg); }

/* ===== SOCIAL ICONS ===== */
.social-icons { width: 100%; display: flex; flex-wrap: wrap; }
.social-icons .social-icon { font-size: 22px; margin: 0 10px; }
.social-icons .social-icon-login a { color: #fff; }
.social-icons .social-icon-login { display: none; margin: 0 20px 0px 10px; }

/* ===== MOBILE SOCIAL ICONS ===== */
.mobile-social-icons {display: none;}
.mobile-social-icons .social-icon {display:flex;justify-content:center;align-items:center;width:36px;height:36px;border-radius:36px; font-size: 22px; margin: 0 10px; background-color: rgba(255, 255, 255, 0.1); }

/* ===== HERO VIDEO SECTION ===== */
.bg-video-wrap { position: relative; overflow: hidden; width: 100%; }
#bg-video { min-width: 100vw; height: 100%; z-index: 1; }
.overlay { width: 100%; height: 100%; position: absolute; top: 0; bottom:0; left: 0; right:0; background: rgba(0, 0, 0, 0.5); z-index: 2; }
.bg-video-wrap .auto-container { text-align: center; color: #fff; position: absolute; top: 0; bottom: 0; left: 0; right: 0; margin: auto; z-index: 3; width: 100%; }
.bg-video-wrap .content-box { position: relative; display: table; vertical-align: middle; width: 100%; padding-top: 350px; padding-bottom: 300px; z-index: 10; }
.bg-video-wrap .content { position: relative; display: table-cell; width: 100%; vertical-align: middle; z-index: 5; }
.bg-video-wrap .inner { position: relative; display: block; max-width: 950px; width: 100%; margin: 0 auto; text-align: center; z-index: 5; }
.bg-video-wrap .subtitle { position: relative; text-transform: uppercase; font-weight: 700; color: var(--main-color); font-size: var(--font-12); letter-spacing: 0.4em; margin-bottom: var(--margin-bottom-10); -webkit-transform: translateY(30px); -ms-transform: translateY(30px); transform: translateY(30px); }
.bg-video-wrap .pattern-image { position: relative; width: 100px; margin: 0 auto; -webkit-transform: translateY(30px); -ms-transform: translateY(30px); transform: translateY(30px); }
.bg-video-wrap .subtitle, .bg-video-wrap .pattern-image { -webkit-transform: translate(0); -ms-transform: translate(0); transform: translate(0); -webkit-transition: all 1000ms ease 500ms; -ms-transition: all 1000ms ease 500ms; -o-transition: all 1000ms ease 500ms; -moz-transition: all 1000ms ease 500ms; transition: all 1000ms ease 500ms; }
.bg-video-wrap h1 span { position: relative; display: inline-block; vertical-align: top; }
.bg-video-wrap .text { position: relative; display: block; font-size: var(--font-20); margin-top: var(--margin-top-10); -webkit-transform: translateY(30px); -ms-transform: translateY(30px); transform: translateY(30px); }
.bg-video-wrap .links-box { position: relative; display: block; padding-top: var(--padding-top-40); -webkit-transform: translateY(30px); -ms-transform: translateY(30px); transform: translateY(30px); }
.bg-video-wrap .links-box .link { position: relative; display: inline-block; vertical-align: top; }
.bg-video-wrap .overlay { z-index: 2; }
.bg-video-wrap .auto-container { z-index: 3; position: relative; }
.triangle-left, .triangle-right { position: absolute; bottom: 0; width: 50%; height: 150px; z-index: 4; pointer-events: none; }
.triangle-left { left: 0; }
.triangle-right { right: 0; }

/* ===== ABOUT US SECTION ===== */
#about-us { padding: 150px 0px; }
#about-us .logo-cont { padding: 60px 0px; }

/* ===== STORY SECTIONS ===== */
.story-section { position: relative; padding-top: var(--padding-top-80); padding-bottom: var(--padding-bottom-30); background-color: #000; }
.story-section .left-bg { position: absolute; left: 0; top: 50%; margin-top: -95px; }
.story-section .text-col { position: relative; }
.story-section .text-col .inner { position: relative; display: block; text-align: center; }
.story-section .text-col .title-box { margin-bottom: var(--margin-bottom-30); }
.story-section .booking-info, .membership-contact .booking-info { position: relative; text-align: center; }
.story-section .booking-info .bk-title { position: relative; font-weight: 700; text-transform: capitalize; margin-bottom: 5px; }
.story-section .booking-info .bk-no { position: relative; font-size: var(--font-24); color: var(--main-color); line-height: 1em; margin-bottom: var(--margin-bottom-30); }
.story-section .booking-info .bk-no a { color: var(--main-color); padding-bottom: var(--padding-bottom-5); }
.story-section .booking-info .bk-no a:before { position: absolute; content: ""; left: 5px; right: 5px; bottom: 0px; height: 5px; opacity: 0; transform: scale(0.2, 1); -webkit-transition: all 500ms ease; -moz-transition: all 500ms ease; -ms-transition: all 500ms ease; -o-transition: all 500ms ease; transition: all 500ms ease; border-top: 1px solid var(--main-color); border-bottom: 1px solid var(--main-color); }
.story-section .booking-info .bk-no a:hover::before { opacity: 1; transform: scale(1, 1); }
.hidden-bar .booking-info .bk-no a:hover::before { opacity: 1; }
.story-section .image-col { position: relative; margin-bottom: var(--margin-bottom-40); }
.story-section .image-col .inner { position: relative; display: block; }
.story-section .image-col .round-stamp { position: absolute; right: -60px; top: -65px; z-index: 3; }
.story-section .image-col .round-stamp:before { position: absolute; content: ""; left: 0px; top: 0px; right: 0px; bottom: 0px; background: url(../images/resource/badge-1-bg.png) no-repeat; }
.story-section .image-col .images { position: relative; padding-left: var(--padding-left-90); }
.story-section .image-col .images img { position: relative; display: block; width: 100%; z-index: 1; }
.story-section .image-col .images .image:nth-child(2) { position: absolute !important; left: 0 !important; top: auto !important; bottom: -160px !important; width: 285px; padding-top: var(--padding-top-50); padding-bottom: var(--padding-bottom-50); z-index: 2; }
.story-section .image-col .images .image:nth-child(2):before { content: ""; position: absolute; left: 50%; margin-left: -70px; width: 140px; top: 0; bottom: 0; background: url(../images/background/pattern-8.svg) center repeat; }

/* ===== CULINARY SECTION ===== */
#culinary { background-image: url(../images/resource/lines-culinary.svg); background-position: center; background-repeat: no-repeat; background-size: cover; }
#culinary p { text-align: center; }

/* ===== EXPERIENCE SECTION ===== */
#experience { padding: 140px 0px; }
#experience p { text-align: center; }

/* ===== FEATURED SECTION ===== */
#featured { background-image: url(../images/resource/lines-featured.svg); background-position: center; background-repeat: no-repeat; background-size: cover; }

/* ===== GALLERY SECTIONS ===== */
.gallery-section { margin: 50px 0px; }
[id$="-gallery-owl"] { padding: 0px 10px; }
[id$="-gallery"] .owl-nav { position: absolute; top: 0%; left: 0; width: 100%; display: flex; justify-content: space-between; align-items: center; pointer-events: none; transform: translateY(200%); }
[id$="-gallery"] .owl-nav button.owl-prev, [id$="-gallery"] .owl-nav button.owl-next { pointer-events: all; background: rgba(0, 0, 0, 0.5); color: #fff; border: none; font-size: 2rem; width: 48px; height: 48px; border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: background 0.2s; }
[id$="-gallery"] .owl-nav button.owl-prev:hover, [id$="-gallery"] .owl-nav button.owl-next:hover { background: #fbc03c; color: #222; }
[id$="-gallery"] .item .gallery-image { padding: 6px; border: 1px solid #d7b06e; }
[id$="-gallery"] .item img { border-radius: 0 !important; }
[id$="-gallery"] .gallery-title { color: #fff; text-align: center; padding: 10px 10px 5px; font-family: var(--font-grotesk); text-transform: uppercase; font-size: 16px; margin-top: -4px; }
[id$="-gallery"] .gallery-caption { display: flex; align-items: center; font-style: italic; text-align: center; line-height: 20px; padding: 0px 16px; font-size: 14px; }
#featured-gallery .owl-nav { transform: translateY(260%); }
#featured-gallery .item .gallery-image { padding: 20px; border: none; background-color: #040303; }
#featured-gallery .item img { border-radius: 0 !important; box-shadow: none !important; }
#featured-gallery .gallery-caption { min-height: 120px; align-items: start; padding: 10px 20px; font-size: 16px; font-style: normal; background-color: #040303; text-align: left; }

/* ===== BUTTONS ===== */
.links-box .link a.theme-btn { min-height: 60px; display: flex; align-items: center; justify-content: center; }
.links-box.wow { animation-fill-mode: forwards !important; }

/* ===== SCROLL TO TOP BUTTON ===== */
.scroll-to-top { position: fixed; bottom: 30px; right: 30px; width: 50px; height: 50px; border: 1px solid #d7b06e; background-color: rgba(0, 0, 0, 0.5); display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 999; opacity: 0; visibility: hidden; transition: all 0.3s ease; }
.scroll-to-top.active { opacity: 1; visibility: visible; }
.scroll-to-top:hover { background-color: #fbc03c; transform: translateY(-3px); box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4); }
.scroll-to-top .icon { color: #d7b06e; font-size: 20px; display: flex; align-items: center; justify-content: center; }
.scroll-to-top:hover .icon { color: #000; }

/* ===== HIDDEN SIDEBAR (RIGHT SIDE) ===== */
.hidden-bar { position: fixed !important; top: 0 !important; right: 0 !important; left: auto !important; bottom: 0 !important; width: 100% !important; max-width: 360px !important; background: #040303; height: 100% !important; overflow-y: auto !important; z-index: 9999 !important; visibility: hidden !important; -ms-transform: translateX(400px) !important; transform: translateX(400px) !important; transition: all 500ms ease-in !important; -webkit-transition: all 500ms ease-in-out !important; -ms-transition: all 500ms ease-in-out !important; -o-transition: all 500ms ease-in-out !important; -moz-transition: all 500ms ease-in-out !important; }
.hidden-bar .inner-box { background-color: transparent !important; }
.hidden-bar.visible-sidebar { opacity: 1 !important; visibility: visible !important; -ms-transform: translateX(0px) !important; transform: translateX(0px) !important; }


/* ===== MEDIA QUERIES ===== */
@media (max-height: 800px) {
    .bg-video-wrap .banner-title { font-size: 60px; line-height: 65px; }
}

@media (max-height: 740px) {
    .bg-video-wrap .banner-title { font-size: 40px; line-height: 45px; }
}

@media (max-height: 610px) {
    .bg-video-wrap .content { vertical-align: top; padding-top: 60px; }
}

@media only screen and (max-width: 1599px) {
    .banner-section .slide-item h1, h1, .inner-banner .inner h1, .bg-video-wrap .banner-title { font-size: 65px; }
}

@media only screen and (max-width: 1499px) {
    /* #about-us { padding-bottom: 0; } */
    h2, .featured-section .text-col h2 { font-size: 50px; }
}

@media (max-width: 1234px) {
    section { padding-left: 20px !important; padding-right: 20px !important; }
    .main-footer { padding: 60px 20px 80px; }
}

@media only screen and (max-width: 1199px) {
    .banner-section .slide-item h1, h1, .inner-banner .inner h1, .bg-video-wrap .banner-title { font-size: 60px; }
    .bg-video-wrap .banner-title { line-height: 65px; }
    h2, .featured-section .text-col h2 { font-size: 44px; }
    h3 { font-size: 30px; }
    h4 { font-size: 22px; }
    /* #about-us { padding-bottom: 0; } */
    .story-section { padding-top: 100px; }
    .story-section .text-col .inner { padding-right: 0; }
    .story-section { padding-bottom: 120px; }
    #about-us.story-section .text-col { margin-bottom: 0 !important; }
}

@media only screen and (max-width: 991px) {
    /* #about-us { padding-bottom: 0; } */
    .banner-section .slide-item h1, h1, .inner-banner .inner h1, .bg-video-wrap .banner-title { font-size: 54px; }
    h2, .featured-section .text-col h2 { font-size: 40px; }
    h3 { font-size: 26px; }
    .story-section { padding-top: 70px; }
    .story-section .image-col .images .image:nth-child(2) { bottom: -130px; }
    .story-section { padding-bottom: 100px; }
    #about-us.story-section .text-col { margin-bottom: 0 !important; }
}

@media (max-width: 976px) {
    .fixed-top-bar { padding-top: 0px; }
    .fixed-top-bar .header-link { display: none; }
    .fixed-top-bar .nav-toggler { right: 20px; }
    .social-icons .social-icon { font-size: 18px; margin: 0 8px; }
    .social-icons .social-icon-login { display: block; }
}

@media only screen and (max-width: 767px) {
    .fixed-top-bar { padding: 0; }
    .fixed-top-bar .auto-container:nth-child(1) { display: none; }

    .fixed-top-bar .logo img { display: none; }
    .fixed-top-bar .logo-mobile { display: block; }
    
    .fixed-top-bar .auto-container:nth-child(2) { justify-content: space-between; padding: 20px; }
    .fixed-top-bar .logo img { height: 45px; max-width: 250px; }
    .mobile-social-icons { display: flex;flex-wrap: wrap;}
    .fixed-top-bar .nav-toggler {position:relative; right:0; width: 30px; }

    .banner-section .slide-item h1, h1, .inner-banner .inner h1, .bg-video-wrap .banner-title { font-size: 48px; }

    .triangle-left, .triangle-right { height: 80px; }
    .main-header { margin-top: 75px; }
    h2, .featured-section .text-col h2 { font-size: 36px; }
    h3 { font-size: 24px; }
    #about-us.story-section .text-col { margin-bottom: 0 !important; }

    .scroll-to-top {bottom: 20px !important;right: 20px !important;width: 45px !important;height: 45px !important;}
}

@media only screen and (max-width: 599px) {
    .banner-section .slide-item h1, h1, .inner-banner .inner h1, .bg-video-wrap .banner-title { font-size: 40px; }
    .bg-video-wrap .banner-title { line-height: 66px; }
    h2, .featured-section .text-col h2 { font-size: 30px; }
    h3 { font-size: 22px; }
    /* #about-us { padding-bottom: 0; } */
    #about-us.story-section .text-col { margin-bottom: 0 !important; }
}

@media only screen and (max-width: 479px) {
    .banner-section .slide-item h1, h1, .inner-banner .inner h1, .bg-video-wrap .banner-title { font-size: 36px; line-height: 56px; }
    h2, .featured-section .text-col h2 { font-size: 28px; }
    h3 { font-size: 20px; }
    .story-section .image-col .images .image:nth-child(2) { width: 150px; bottom: -120px !important; }
    .story-section .image-col .images { padding-left: 50px; }
    .story-section .text-col { margin-bottom: 0px; }
    .story-section { padding-bottom: 5px; }
    .heavy-title-white {font-size:38px;}
    .heavy-title-gold {font-size:38px;}
    #about-us.story-section .text-col { margin-bottom: 0 !important; }
    /* #about-us { padding-bottom: 0; } */
}

@media (max-width: 420px) {
    .mobile-social-icons .social-icon {width:24px;height:24px;}
}

@media only screen and (max-width: 399px) {
    .bg-video-wrap .banner-title { line-height: 50px; }
    /* #about-us { padding-bottom: 0; } */
    #about-us.story-section .text-col { margin-bottom: 0 !important; }
}

@media (min-width: 768px) and (max-width: 1199px) {
    .triangle-left, .triangle-right { height: 100px; }
}

@media (min-width: 1200px) {
    .triangle-left, .triangle-right { height: 150px; }
}