/* ============================================================
   PINTXO CHILD THEME — header.css
   Styles for: announcement bar, site header, logo, nav,
               mobile hamburger.
   ============================================================ */

/* ---------- CSS Variables (shared across header & footer) ---------- */
:root {
    --color-burgundy: #730804;
    --color-burgundy-light: #b24b46;
    --color-cream: #faf8f4;
    --color-white: #ffffff;
    --color-black: #111111;
    --color-text: #444444;
    --color-text-light: #777777;

    --font-script: 'Dancing Script', cursive;
    --font-body: 'Raleway', sans-serif;

    --transition: 0.3s ease;
}

body {
    font-family: var(--font-body);
    color: var(--color-text);
    background: var(--color-white);
    line-height: 1.7;
    margin: 0;
    padding: 0;
}

/* ---- Shared Button ---- */
.btn {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    padding: 14px 36px;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--transition), color var(--transition), border-color var(--transition);
    border: 2px solid transparent;
}

.btn--burgundy {
    background: var(--color-burgundy);
    color: var(--color-white);
    border-color: var(--color-burgundy);
}

.btn--burgundy:hover {
    background: var(--color-burgundy-light);
    transform: scale(1.04);
}

/* ---------- Reset (scoped to header elements) ---------- */
.announcement-bar *,
.site-header * {
    box-sizing: border-box;
}

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.announcement-bar {
    --announcement-speed: 30s;

    background: var(--color-black);
    color: var(--color-white);
    padding: 10px 0;
    font-family: var(--font-body);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    display: flex;
    align-items: center;
    position: relative;
    z-index: 1100;
    overflow: hidden;
}

.announcement-bar p,
.announcement-text {
    margin: 0;
}

.announcement-text {
    width: 100%;
    overflow: hidden;
    white-space: nowrap;
}

.announcement-track {
    display: flex;
    align-items: center;
    width: 200%;
    will-change: transform;
    animation: announcement-scroll var(--announcement-speed) linear infinite;
}

.announcement-item {
    flex: 0 0 50%;
    width: 50%;
    display: flex;
    align-items: center;
    white-space: nowrap;
}

.lang-toggle {
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px;
    background: var(--color-black);
    border: 1px solid rgba(255, 255, 255, 0.4);
    z-index: 2;
}

.lang-toggle__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    padding: 3px 8px;
    color: var(--color-white);
    text-decoration: none;
    font-family: var(--font-body);
    font-size: 0.7rem;
    letter-spacing: 0.1em;
    transition: background var(--transition), color var(--transition);
}

.lang-toggle__link:hover {
    background: rgb(36, 36, 36);
    color: var(--color-white);
}

.lang-toggle__link.is-active {
    background: var(--color-white);
    color: var(--color-black);
}

@keyframes announcement-scroll {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

/* ---- Social row ---- */
.header-social {
    display: flex;
    gap: 14px;
}

.header-social a {
    color: var(--color-black);
    font-size: 1rem;
    text-decoration: none;
    transition: color var(--transition);
}

.header-social a:hover {
    color: var(--color-burgundy);
}

/* ---- Main row ---- */
.header-main {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    padding: 8px 24px;
}

.icon-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    color: var(--color-black);
    padding: 6px;
    transition: color var(--transition);
    display: flex;
    align-items: center;
    line-height: 1;
}

.icon-btn:hover {
    color: var(--color-burgundy);
}

.header-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

/* ---- Logo ---- */
.logo {
    text-align: center;
    line-height: 1;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.logo-script {
    display: block;
    font-family: var(--font-script);
    font-size: 2.6rem;
    color: var(--color-black);
    letter-spacing: 0.02em;
    line-height: 1;
}

.logo-sub {
    display: block;
    font-family: var(--font-body);
    font-size: 0.6rem;
    letter-spacing: 0.35em;
    color: var(--color-text-light);
    margin-top: -4px;
}

.logo-image {
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.logo-image .custom-logo-link {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
}

.logo-image .custom-logo {
    display: block;
    width: auto;
    height: auto;
    max-width: 220px;
    max-height: 72px;
}

.header-left-spacer {
    justify-self: start;
    min-width: 1px;
}

.logo,
.logo-image {
    justify-self: center;
}

.header-actions {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-self: end;
}

/* ============================================================
   PRIMARY NAVIGATION
   ============================================================ */
.main-nav {
    position: relative;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.main-nav .nav-list,
.main-nav ul {
    display: flex;
    justify-content: center;
    gap: 28px;
    padding: 10px 24px;
    margin: 0;
    list-style: none;
}

.main-nav .nav-list li,
.main-nav ul li {
    margin: 0;
    padding: 0;
}

.main-nav .nav-list a,
.main-nav ul a {
    font-family: var(--font-body);
    font-size: 0.80rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    color: var(--color-black);
    text-decoration: none;
    transition: color var(--transition);
    padding-bottom: 2px;
    border-bottom: 1px solid transparent;
    display: inline-block;
}

.main-nav .nav-list a:hover,
.main-nav ul a:hover,
.main-nav .nav-list .current-menu-item>a,
.main-nav ul .current-menu-item>a,
.main-nav .nav-list .current_page_item>a,
.main-nav ul .current_page_item>a,
.main-nav .nav-list .current-menu-ancestor>a,
.main-nav ul .current-menu-ancestor>a {
    /* color: var(--color-burgundy); */
    border-bottom-color: var(--color-burgundy);
}

/* ============================================================
   HAMBURGER
   ============================================================ */
.hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    position: static;
    transform: none;
    margin-left: 8px;
}

.hamburger span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--color-black);
    transition: transform var(--transition), opacity var(--transition);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* Tablet */
@media (max-width: 900px) {

    .main-nav .nav-list,
    .main-nav ul {
        gap: 18px;
    }

    .main-nav .nav-list a,
    .main-nav ul a {
        font-size: 0.62rem;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .hide-mobile {
        display: none;
    }

    .hamburger {
        display: flex;
    }

    .header-left-spacer {
        display: none;
    }

    .header-main {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 4px 12px;
    }

    .logo,
    .logo-image {
        justify-self: auto;
    }

    .header-actions {
        justify-self: auto;
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .main-nav {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        z-index: 1100;
    }

    .main-nav .nav-list,
    .main-nav ul {
        display: none;
        flex-direction: column;
        align-items: center;
        gap: 16px;
        width: 100%;
        margin: 0;
        padding: 20px 0 24px;
        list-style: none;
        background: var(--color-white);
        box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
    }

    .main-nav.is-open .nav-list,
    .main-nav.is-open ul,
    .main-nav .nav-list.nav--open,
    .main-nav ul.nav--open {
        display: flex;
    }

    .main-nav .nav-list a,
    .main-nav ul a {
        font-size: 0.72rem;
        color: var(--color-black);
    }

    .main-nav .nav-list a:hover,
    .main-nav ul a:hover,
    .main-nav .nav-list .current-menu-item>a,
    .main-nav ul .current-menu-item>a,
    .main-nav .nav-list .current_page_item>a,
    .main-nav ul .current_page_item>a,
    .main-nav .nav-list .current-menu-ancestor>a,
    .main-nav ul .current-menu-ancestor>a {
        color: var(--color-burgundy);
        border-bottom-color: var(--color-burgundy);
    }

    .home .main-nav .nav-list,
    .home .main-nav ul {
        background: var(--color-white);
    }

    .home .main-nav .nav-list a,
    .home .main-nav ul a {
        color: var(--color-black);
    }

    .lang-toggle {
        right: 10px;
    }

    .lang-toggle__link {
        min-width: 36px;
        padding: 3px 6px;
        font-size: 0.64rem;
    }
}

/* Small mobile */
@media (max-width: 480px) {
    .logo-script {
        font-size: 2rem;
    }

    .announcement-bar {
        font-size: 0.68rem;
    }
}

/* ------------------------------------------------------------------------------------------------TEST HEADER TRANSPARENT*/
.site-header {
    position: absolute;
    top: calc(var(--announcement-offset, 0px) + var(--admin-bar-offset, 0px));
    left: 0;
    right: 0;
    z-index: 1000;
    background: transparent;
    border-bottom: none;
    box-shadow: none;
    transition: box-shadow var(--transition);
    font-family: var(--font-body);
}

.header-main {
    background: var(--color-white);
}

.main-nav {
    background: transparent;
}

.main-nav .nav-list a,
.main-nav ul a {
    color: var(--color-white);
    outline-style: none;
}

.main-nav .nav-list a:hover,
.main-nav ul a:hover,
.main-nav .nav-list .current-menu-item>a,
.main-nav ul .current-menu-item>a,
.main-nav .nav-list .current_page_item>a,
.main-nav ul .current_page_item>a,
.main-nav .nav-list .current-menu-ancestor>a,
.main-nav ul .current-menu-ancestor>a {
    /* color: var(--color-burgundy); */
    border-bottom-color: var(--color-burgundy);
}

.logo-script,
.logo-sub {
    color: var(--color-white);
}

.site-header.is-scrolled {
    position: fixed;
    top: var(--admin-bar-offset, 0px);
    left: 0;
    right: 0;
    background: var(--color-white);
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.1);
}

.site-header.is-scrolled .header-social a,
.site-header.is-scrolled .main-nav .nav-list a,
.site-header.is-scrolled .main-nav ul a {
    color: var(--color-black);
}

.site-header.is-scrolled .hamburger span {
    background: var(--color-black);
}

.site-header.is-scrolled .main-nav .nav-list a:hover,
.site-header.is-scrolled .main-nav ul a:hover,
.site-header.is-scrolled .main-nav .nav-list .current-menu-item>a,
.site-header.is-scrolled .main-nav ul .current-menu-item>a,
.site-header.is-scrolled .main-nav .nav-list .current_page_item>a,
.site-header.is-scrolled .main-nav ul .current_page_item>a,
.site-header.is-scrolled .main-nav .nav-list .current-menu-ancestor>a,
.site-header.is-scrolled .main-nav ul .current-menu-ancestor>a {
    color: var(--color-burgundy);
    border-bottom-color: var(--color-burgundy);
}

.site-header.is-scrolled .logo-script {
    color: var(--color-black);
}

.site-header.is-scrolled .logo-sub {
    color: var(--color-text-light);
}

/* Mobile */
@media (max-width: 768px) {

    .main-nav .nav-list a,
    .main-nav ul a {
        color: var(--color-black);
        transition: color var(--transition);
    }

    .site-header.is-scrolled {
        top: 0;
    }
}

/* ------------------------------------------------------------------------------------------------TEST HEADER TRANSPARENT*/

/* GLOBAL ADJUSTMENTS */
:where(.wp-site-blocks)>* {
    margin-block-start: 0;
}

html {
    scroll-behavior: smooth;
}

.reservations .ot-dtp-picker iframe,
.reservations iframe[src*="opentable"],
.reservations iframe[src*="widget/reservation"] {
    height: 70px !important;
}

.lp-hero .ot-dtp-picker iframe,
.lp-hero iframe[src*="opentable"],
.lp-hero iframe[src*="widget/reservation"],
.lp-visit .ot-dtp-picker iframe,
.lp-visit iframe[src*="opentable"],
.lp-visit iframe[src*="widget/reservation"] {
    height: 70px !important;
    margin-left: -15px;
}