/* ================================================
   LUMY RESTAURANT — Custom Header
   File: /wp-content/themes/your-child-theme/lumy-header/lumy-header.css
================================================ */

:root {
  --lumy-black:   #0a0a0a;
  --lumy-gold:    #aa7a5a;
  --lumy-goldl:   #d4b06a;
  --lumy-white:   #f5f2ed;
  --lumy-cream:   #ede8df;
  --lumy-gray:    #888;
  --lumy-text:    #2c2c2c;
  --lumy-border:  rgba(184,148,74,0.2);
  --lumy-dh:      88px;
  --lumy-mh:      72px;
}

body { overflow-x: hidden; }
body.lumy-menu-open { overflow: hidden; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━
   DESKTOP HEADER
━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.lumy-hd {
  display: flex;
  align-items: center;
  justify-content: space-around;
  position: fixed;
  z-index: 900;
  height: var(--lumy-dh);
  border-bottom: 1px solid var(--lumy-border);
  padding: 0 44px;
  transition: background 0.4s;
  width: 100%;
}
.lumy-hd.scrolled {
  background: rgba(10,10,10,0.96);
  backdrop-filter: blur(14px);
}

/* Logo */
.lumy-logo {
  display: flex; flex-direction: column;
  align-items: center; text-decoration: none;
  gap: 2px; flex-shrink: 0;
}
.lumy-logo  img {
    height: 70px!important;
}
.lumy-logo-bowl { font-size: 26px; line-height: 1; }
.lumy-logo-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 17px; font-weight: 600;
  letter-spacing: 5px; color: #f0ebe0; line-height: 1;
}
.lumy-logo-sub {
  font-size: 7.5px; letter-spacing: 3px;
  color: var(--lumy-gray); font-weight: 300;
}

/* Nav links */
.lumy-nav-primary { list-style: none; display: flex; gap: 38px; margin: 0;}
.lumy-nav-primary a {
  text-decoration: none; color: #f0ebe0;
  font-size: 11px; font-weight: 500;
  letter-spacing: 2.5px; text-transform: uppercase;
  position: relative; padding-bottom: 3px; transition: color 0.3s;
}
.lumy-nav-primary a::after {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 0; height: 1px; background: var(--lumy-gold);
  transition: width 0.35s;
}
.lumy-nav-primary a:hover { color: var(--lumy-goldl); }
.lumy-nav-primary a:hover::after,
.lumy-nav-primary .current-menu-item a::after { width: 100%; }
.lumy-nav-primary .current-menu-item a { color: var(--lumy-goldl); }

/* Right cluster */
.lumy-hd-right { display: flex; align-items: center; gap: 16px; flex-shrink: 0; }

.lumy-flags { display: flex; gap: 8px; align-items: center; }
.lumy-flags span, .lumy-flags a {
  font-size: 20px; cursor: pointer; opacity: 0.65;
  transition: opacity 0.2s, transform 0.2s;
  display: inline-block; text-decoration: none;
}
.lumy-flags span:hover, .lumy-flags a:hover,
.lumy-flags span.on, .lumy-flags a.on { opacity: 1; }

.lumy-btn-order {
  border: 1px solid #f0ebe0; background: transparent;
  color: #f0ebe0; font-family: 'Montserrat', sans-serif;
  font-size: 10px; font-weight: 600; letter-spacing: 2.5px;
  text-transform: uppercase; padding: 10px 22px;
  text-decoration: none; cursor: pointer;
  transition: background 0.3s, border-color 0.3s, color 0.3s;
  white-space: nowrap; display: inline-block;
}
.lumy-btn-order:hover {
  background: var(--lumy-gold);
  border-color: var(--lumy-gold); color: #fff;
}

/* Hamburger button */
.lumy-hbg {
  background: none; border: none; cursor: pointer;
  display: flex; flex-direction: column;
  align-items: center; gap: 5px; padding: 5px;
  position: relative; z-index: 1100;
}
.lumy-hbg-lines { display: flex; flex-direction: column; gap: 5px; }
.lumy-hbg span {
  display: block; width: 24px; height: 1.5px;
  background: #f0ebe0; border-radius: 1px;
  transition: transform 0.4s cubic-bezier(.4,0,.2,1), opacity 0.3s;
  transform-origin: center;
}
.lumy-hbg-label {
  font-size: 7px; letter-spacing: 2px; color: #f0ebe0;
  font-weight: 500; text-transform: uppercase;
  opacity: 0.7; transition: opacity 0.3s;
  font-family: 'Montserrat', sans-serif;
}
.lumy-hbg:hover .lumy-hbg-label { opacity: 1; }
.lumy-hbg.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.lumy-hbg.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.lumy-hbg.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━
   FULLSCREEN OVERLAY (Desktop)
━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.lumy-overlay {
  position: fixed; inset: 0;
  z-index: 1000;
  display: grid; grid-template-columns: 44% 56%;
  pointer-events: none; visibility: hidden;
}

.lumy-ov-left {
  position: relative; overflow: hidden;
  transform: translateX(-100%);
  transition: transform 0.7s cubic-bezier(0.76,0,0.24,1);
}
.lumy-ov-left img {
  width: 100%; height: 100%; object-fit: cover;
  transform: scale(1.06);
  transition: transform 1s cubic-bezier(0.4,0,0.2,1) 0.1s;
  display: block;
}
.lumy-ov-left::before {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(160deg, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.7) 100%);
}
.lumy-ov-logo {
  position: absolute; inset: 0; z-index: 2;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 10px;
  opacity: 0; transform: translateY(20px);
  transition: opacity 0.5s 0.45s, transform 0.5s 0.45s;
}
.lumy-ov-logo img {
    height: 200px!important;
}
.lumy-ov-logo-bowl { font-size: 52px; line-height: 1; }
.lumy-ov-logo-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 36px; font-weight: 300; letter-spacing: 8px;
  color: #fff; text-shadow: 0 2px 16px rgba(0,0,0,0.4);
}
.lumy-ov-logo-rule { width: 48px; height: 1px; background: rgba(255,255,255,0.5); }
.lumy-ov-logo-sub {
  font-size: 10px; letter-spacing: 4px;
  color: rgba(255,255,255,0.65); font-weight: 300;
  text-transform: uppercase; font-family: 'Montserrat', sans-serif;
}

.lumy-ov-right {
  background: #000;
  display: flex; flex-direction: column;
  justify-content: center; padding: 80px 72px 80px 80px;
  transform: translateX(100%);
  transition: transform 0.7s cubic-bezier(0.76,0,0.24,1) 0.05s;
  position: relative; overflow-y: auto;
}

.lumy-ov-close {
  position: absolute; top: 0; right: 0;
  background: none; border: none; cursor: pointer;
  display: flex; flex-direction: column;
  align-items: center; gap: 6px; padding: 6px 20px; z-index: 10;
  opacity: 0; transition: opacity 0.3s 0.5s;
}
.lumy-ov-close-x { width: 40px; height: 40px; position: relative; }
.lumy-ov-close-x::before, .lumy-ov-close-x::after {
  content: ''; position: absolute;
  top: 50%; left: 0; width: 100%; height: 1px;
  background: var(--lumy-gold);
}
.lumy-ov-close-x::before { transform: rotate(45deg); }
.lumy-ov-close-x::after  { transform: rotate(-45deg); }
.lumy-ov-close-lbl {
  font-size: 12px; letter-spacing: 2.5px; color: var(--lumy-gold);
  font-family: 'Montserrat', sans-serif; font-weight: 500; text-transform: uppercase;
}
.lumy-ov-close:hover .lumy-ov-close-x::before,
.lumy-ov-close:hover .lumy-ov-close-x::after { background: #fff; }
.lumy-ov-close:hover .lumy-ov-close-lbl { color: #fff; }

.lumy-ov-nav { list-style: none; margin:0 0 52px 0;}
.lumy-ov-nav li {
  border-bottom: 1px solid #aa7a5a; overflow: hidden;
}
.lumy-ov-nav li:first-child { border-top: 1px solid rgba(44,44,44,0.08); }
.lumy-ov-nav li a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 0; text-decoration: none;
  color: #fff;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(28px, 3.5vw, 44px); font-weight: 300; letter-spacing: 2px;
  transform: translateY(60px); opacity: 0;
  transition: transform 0.55s cubic-bezier(0.4,0,0.2,1),
              opacity 0.55s, color 0.25s, padding-left 0.25s;
}
.lumy-ov-nav li a .lumy-n {
  font-size: 10px; letter-spacing: 2px; color: var(--lumy-gray);
  font-family: 'Montserrat', sans-serif; font-weight: 400;
  align-self: flex-end; margin-bottom: 10px; transition: color 0.25s;
}
.lumy-ov-nav li a:hover { color: var(--lumy-gold); padding-left: 10px; }
.lumy-ov-nav li a:hover .lumy-n { color: var(--lumy-gold); }

.lumy-ov-footer {
  display: flex; align-items: center; gap: 24px;
  opacity: 0; transform: translateY(16px);
  transition: opacity 0.45s 0.6s, transform 0.45s 0.6s;
}
.lumy-ov-footer .lumy-btn-order {
  border-color: var(--lumy-gold); color: #fff;
}
.lumy-ov-footer .lumy-btn-order:hover {
  background: var(--lumy-gold); color: #fff;
}
.lumy-ov-divider { width: 1px; height: 30px; background: rgba(44,44,44,0.15); }

/* Open state */
.lumy-overlay.on { pointer-events: all; visibility: visible; }
.lumy-overlay.on .lumy-ov-left { transform: translateX(0); }
.lumy-overlay.on .lumy-ov-left img { transform: scale(1); }
.lumy-overlay.on .lumy-ov-logo { opacity: 1; transform: translateY(0); }
.lumy-overlay.on .lumy-ov-right { transform: translateX(0); }
.lumy-overlay.on .lumy-ov-close { opacity: 1; }
.lumy-overlay.on .lumy-ov-eyebrow { opacity: 1; transform: translateY(0); }
.lumy-overlay.on .lumy-ov-footer { opacity: 1; transform: translateY(0); }
.lumy-overlay.on .lumy-ov-nav li:nth-child(1) a { transform:translateY(0); opacity:1; transition-delay:0.28s; }
.lumy-overlay.on .lumy-ov-nav li:nth-child(2) a { transform:translateY(0); opacity:1; transition-delay:0.35s; }
.lumy-overlay.on .lumy-ov-nav li:nth-child(3) a { transform:translateY(0); opacity:1; transition-delay:0.42s; }
.lumy-overlay.on .lumy-ov-nav li:nth-child(4) a { transform:translateY(0); opacity:1; transition-delay:0.49s; }
.lumy-overlay.on .lumy-ov-nav li:nth-child(5) a { transform:translateY(0); opacity:1; transition-delay:0.56s; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━
   MOBILE HEADER (≤1024px)
━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.lumy-hm {
  display: none;
  position: fixed; inset: 0 0 auto 0;
  z-index: 900;
  background: var(--lumy-black);
  border-bottom: 1px solid var(--lumy-border);
  height: var(--lumy-mh);
}
.lumy-hm-inner {
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: stretch; height: 100%; overflow: hidden;
}
.lumy-hm-left { position: relative; overflow: hidden; }
.lumy-hm-left img {
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0.5; filter: brightness(0.7); display: block;
}
.lumy-hm-left::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to right, transparent 30%, var(--lumy-black) 90%);
}
.lumy-hm-center {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 0 18px; z-index: 1;
}
.lumy-hm-logo {
  text-decoration: none; display: flex;
  flex-direction: column; align-items: center; gap: 1px;
}

.lumy-hm-logo img {
    height: 60px!important;
}
.lumy-hm-bowl { font-size: 19px; }
.lumy-hm-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 13px; font-weight: 600;
  letter-spacing: 4px; color: #f0ebe0; white-space: nowrap; line-height: 1;
}
.lumy-hm-sub {
  font-size: 6.5px; letter-spacing: 3px;
  color: var(--lumy-gray); font-weight: 300;
  font-family: 'Montserrat', sans-serif;
}
.lumy-hm-right {
  display: flex; align-items: center;
  justify-content: flex-end; padding-right: 18px;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━
   MOBILE FULLSCREEN OVERLAY
━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.lumy-mob-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: var(--lumy-white);
  background-image: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(232,220,200,0.35) 0%, transparent 70%);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  pointer-events: none; visibility: hidden;
  opacity: 0; transition: opacity 0.4s;
}
.lumy-mob-overlay.on {
  pointer-events: all; visibility: visible; opacity: 1;
}
.lumy-mob-close {
  position: absolute; top: 24px; right: 24px;
  background: none; border: none; cursor: pointer;
  display: flex; flex-direction: column;
  align-items: center; gap: 5px; padding: 6px;
}
.lumy-mob-close-x { width: 20px; height: 20px; position: relative; }
.lumy-mob-close-x::before, .lumy-mob-close-x::after {
  content: ''; position: absolute;
  top: 50%; left: 0; width: 100%; height: 1px;
  background: var(--lumy-text);
}
.lumy-mob-close-x::before { transform: rotate(45deg); }
.lumy-mob-close-x::after  { transform: rotate(-45deg); }
.lumy-mob-close-lbl {
  font-size: 7px; letter-spacing: 2.5px; color: var(--lumy-text);
  font-family: 'Montserrat', sans-serif; font-weight: 500; text-transform: uppercase;
}
.lumy-mob-nav { list-style: none; text-align: center; margin:  0 0 32px 0; }
.lumy-mob-nav li a {
  display: block; padding: 14px 20px; text-decoration: none;
  color: var(--lumy-text); font-family: 'Cormorant Garamond', serif;
  font-size: clamp(26px, 8vw, 36px); font-weight: 300;
  letter-spacing: 3px; text-transform: uppercase;
  transform: translateY(30px); opacity: 0;
  transition: transform 0.5s, opacity 0.5s, color 0.2s;
}
.lumy-mob-nav li a:hover { color: var(--lumy-gold); }
.lumy-mob-overlay.on .lumy-mob-nav li:nth-child(1) a { transform:translateY(0); opacity:1; transition-delay:0.10s; }
.lumy-mob-overlay.on .lumy-mob-nav li:nth-child(2) a { transform:translateY(0); opacity:1; transition-delay:0.17s; }
.lumy-mob-overlay.on .lumy-mob-nav li:nth-child(3) a { transform:translateY(0); opacity:1; transition-delay:0.24s; }
.lumy-mob-overlay.on .lumy-mob-nav li:nth-child(4) a { transform:translateY(0); opacity:1; transition-delay:0.31s; }
.lumy-mob-lang {
  display: flex; gap: 12px; margin-bottom: 12px;
  opacity: 0; transition: opacity 0.4s 0.45s;
}
.lumy-mob-overlay.on .lumy-mob-lang { opacity: 1; }
.lumy-mob-lang span { font-size: 24px; cursor: pointer; opacity: 0.65; transition: opacity 0.2s; }
.lumy-mob-lang span:hover { opacity: 1; }
.lumy-mob-actions {
  position: absolute; bottom: 0; left: 0; right: 0;
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid rgba(44,44,44,0.1);
}
.lumy-mob-action-btn {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 14px 6px; gap: 6px; text-decoration: none;
  border: none; cursor: pointer; background: transparent;
  border-right: 1px solid rgba(44,44,44,0.1);
  transition: background 0.2s; font-family: 'Montserrat', sans-serif;
}
.lumy-mob-action-btn:last-child { border-right: none; }
.lumy-mob-action-btn:hover { background: rgba(184,148,74,0.08); }
.lumy-mob-action-btn.gold { background: var(--lumy-gold); }
.lumy-mob-action-btn.gold:hover { background: var(--lumy-goldl); }
.lumy-mob-action-btn .icon { font-size: 20px; line-height: 1; }
.lumy-mob-action-btn .lbl {
  font-size: 8.5px; letter-spacing: 1px; color: var(--lumy-text);
  text-align: center; font-weight: 500;
}
.lumy-mob-action-btn.gold .lbl { color: #fff; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE
━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (max-width: 1024px) {
  body { padding-top: var(--lumy-mh); }
  .lumy-hd { display: none !important; }
  .lumy-hm { display: block !important; }
  .lumy-overlay { display: none !important; }
}
@media (min-width: 1025px) {
  .lumy-mob-overlay { display: none !important; }
}
