/* =========================================================
   Restaura – custom overrides & new components
   ========================================================= */

/* ── GLOBAL ────────────────────────────────────────────── */
body { overflow-x: hidden; }

/* ── HEADER overlays banner as one seamless background ── */
/* Pull header out of flow so it sits on top of the banner image */
header {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
}
.lgx-header {
    background: transparent !important;
}

/* ── LOGO – remove hanging padding ────────────────────── */
.lgx-header .lgx-navbar .lgx-logo-fixed a img,
.lgx-header .menu-onscroll .lgx-navbar .lgx-logo-fixed a img {
    padding: 0;
    background: transparent;
}

/* ── BANNER STRIP ─────────────────────────────────────── */
/* Full-width semi-transparent overlay behind banner text */
.lgx-banner-strip {
    position: relative;
    padding: 32px 0;
    overflow: visible;
}
.lgx-banner-strip::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    height: 100%;
    background: rgba(0, 0, 0, 0.48);
    pointer-events: none;
}
.lgx-banner-strip .lgx-banner-info {
    position: relative; /* keep text above ::before */
}
.lgx-banner-strip .lgx-btn span {
    color: #fff !important;
}
.lgx-banner-strip .lgx-btn:hover,
.lgx-banner-strip .lgx-btn:hover span {
    color: #282b2e !important;
}

/* ── GALLERY ──────────────────────────────────────────── */
#lgx-gallery {
    padding: 0;
    margin: 0;
}
.lgx-gallery-carousel-outer {
    position: relative;
    overflow: hidden;
    padding: 0;
}
.lgx-gallery-track {
    display: flex;
    cursor: grab;
    user-select: none;
}
.lgx-gallery-track.is-dragging {
    cursor: grabbing;
}
.lgx-gallery-item {
    min-width: 25%;
    padding: 0;
    box-sizing: border-box;
    overflow: hidden;
}
@media (max-width: 991px) { .lgx-gallery-item { min-width: 33.333%; } }
@media (max-width: 767px) { .lgx-gallery-item { min-width: 50%; } }
@media (max-width: 479px) { .lgx-gallery-item { min-width: 100%; } }
.lgx-gallery-item img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
    pointer-events: none;
}
.lgx-gallery-item:hover img {
    transform: scale(1.1);
}
.lgx-gallery-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: #fff;
    font-size: 52px;
    line-height: 1;
    cursor: pointer;
    z-index: 10;
    padding: 0 8px;
    opacity: 0;
    transition: opacity 0.25s ease;
    text-shadow: 0 2px 6px rgba(0,0,0,0.6);
}
.lgx-gallery-carousel-outer:hover .lgx-gallery-btn { opacity: 1; }
.lgx-gallery-btn-prev { left: 0; }
.lgx-gallery-btn-next { right: 0; }

/* ── ABOUT – center the content column ────────────────── */
#lgx-about .col-md-7 {
    float: none;
    margin: 0 auto;
}

/* ── NAVBAR – white links ──────────────────────────────── */
.lgx-nav > li > a,
.lgx-nav > li > a:hover,
.lgx-nav > li > a:focus { color: #fff !important; }

/* ── BANNER – larger CTA ───────────────────────────────── */
.lgx-banner-info .text {
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.01em;
}

/* ── ABOUT – bolder description ─────────────────────────── */
.lgx-about-content .about {
    font-weight: 600;
    font-size: 17px;
    line-height: 1.8;
}

/* ── FOOTER – section titles and hours in primary color ── */
.lgx-footer .lgx-footer-single .title {
    color: var(--lgx-primary);
}
.lgx-footer .opening-time-single span:last-child {
    color: var(--lgx-primary);
}

/* ── FOOTER – slightly larger text ─────────────────────── */
.lgx-footer address,
.lgx-footer .lgx-address-info li,
.lgx-footer .list-unstyled li,
.lgx-footer .list-unstyled a { font-size: 15px; }

/* ── FOOTER HOURS ─────────────────────────────────────── */
.lgx-footer-hours {
    flex: 2 !important;
    min-width: 280px;
    padding-left: 40px;
}
.lgx-footer-hours > .title {
    text-align: center;
}
/* Menu column - centered between logo and hours */
.lgx-footer-area .lgx-footer-single:nth-child(2) {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.lgx-hours-tabs {
    display: flex;
    gap: 6px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}
.lgx-hours-tab {
    flex: 1;
    background: rgba(255,255,255,0.07);
    color: inherit;
    border: 1px solid rgba(255,255,255,0.18);
    border-bottom: 2px solid rgba(255,255,255,0.18);
    padding: 9px 14px 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    border-radius: 2px;
    transition: background 0.2s, border-color 0.2s;
    text-align: center;
    white-space: nowrap;
    letter-spacing: 0.02em;
}
.lgx-hours-tab:hover:not(.active) {
    background: rgba(255,255,255,0.13);
    border-color: rgba(255,255,255,0.35);
}
.lgx-hours-tab.active {
    background: rgba(255,255,255,0.15);
    border-color: rgba(255,255,255,0.35);
    border-bottom-color: var(--lgx-primary);
}
.lgx-hours-panel        { display: none; }
.lgx-hours-panel.active { display: block; }
.lgx-hours-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 40px;
}
.lgx-footer-single .opening-time-single { margin-bottom: 0.2rem; }
.lgx-hours-grid .opening-time-single {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0;
    font-size: 16px;
    font-weight: 500;
    white-space: nowrap;
    gap: 6px;
}
.lgx-hours-exceptions {
    margin-top: 10px;
    padding-top: 8px;
    border-top: 1px solid rgba(255,255,255,0.15);
}
.lgx-hours-exceptions-label {
    font-size: 11px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #f44336;
    margin-bottom: 4px;
}
.lgx-hours-exceptions-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4px 14px;
    margin-top: 6px;
}
.lgx-exception-item {
    display: flex;
    flex-direction: column;
    gap: 1px;
}
.lgx-exception-date {
    font-size: 16px;
    font-weight: 500;
    white-space: nowrap;
}
.lgx-exception-value {
    font-size: 16px;
    white-space: nowrap;
    font-weight: 600;
    color: var(--lgx-primary);
}
.lgx-exception-closed {
    color: #f44336;
}
@media (max-width: 767px) {
    .lgx-footer-hours { padding-left: 0; }
    .lgx-footer-area .lgx-footer-single:nth-child(2) { align-items: center; }
    .lgx-footer-single  { text-align: center; }
    .lgx-footer-single address { text-align: center; }
    .lgx-footer-single .lgx-address-info { display: flex; flex-direction: column; align-items: center; }
    .lgx-footer-single .list-unstyled li { text-align: center; }
    .lgx-hours-tabs     { flex-direction: column; }
    .lgx-hours-tab      { text-align: center; flex: none; }
    .lgx-hours-grid     { grid-template-columns: 1fr; }
    .lgx-hours-grid .opening-time-single { justify-content: center; gap: 10px; }
    .lgx-hours-exceptions-label { text-align: center; }
    .lgx-hours-exceptions-grid { grid-template-columns: repeat(2, 1fr); }
}
