/* ============================================================
   Banana Leaf — public stylesheet
   Token-driven, with five distinct homepage themes (body.design-N).
   Colours come from PHP theme_css(): --bl-primary/secondary/dark/light/accent
   ============================================================ */

:root{
  --bl-primary:#1f7a3d; --bl-secondary:#f4a300; --bl-dark:#13261a;
  --bl-light:#fbf7ef; --bl-accent:#c0392b;

  --ink:#1a1f1c; --muted:#6b746e; --line:#e7e3d8;

  /* Derived palette tokens — all computed from the admin colours above,
     so changing the palette in admin updates every one of them.
     theme_css() re-declares --bl-primary…--bl-accent at runtime; these
     color-mix() values cascade from those, so nothing is hardcoded. */
  --bl-on-gold:color-mix(in srgb, var(--bl-dark) 86%, #000 14%);  /* dark text on gold */
  --bl-on-gold-soft:color-mix(in srgb, var(--bl-dark) 60%, var(--bl-secondary) 40%);
  --bl-on-dark:color-mix(in srgb, var(--bl-light) 88%, var(--bl-dark));   /* light text on dark */
  --bl-on-dark-dim:color-mix(in srgb, var(--bl-light) 60%, var(--bl-dark)); /* dimmer light text on dark */
  --bl-placeholder:color-mix(in srgb, var(--muted) 70%, transparent);
  --bl-ok:#2e9d5b; --bl-ok-soft:color-mix(in srgb,#2e9d5b 22%,transparent);
  --bl-bad:var(--bl-accent); --bl-bad-soft:color-mix(in srgb,var(--bl-accent) 14%,#fff);
  --bl-bad-ink:color-mix(in srgb,var(--bl-accent) 70%,#000);
  --bl-whatsapp:#25d366;

  --radius:16px; --radius-sm:10px; --shadow:0 18px 50px -22px rgba(0,0,0,.28);
  --shadow-sm:0 8px 24px -12px rgba(0,0,0,.18);
  --ff-display:'Playfair Display',Georgia,serif;
  --ff-body:'Poppins',system-ui,-apple-system,sans-serif;
  --ff-heading:var(--ff-display);
  --ff-subheading:var(--ff-display);
  --ff-button:var(--ff-body);
  --ff-link:var(--ff-body);
  --ff-nav:var(--ff-body);
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:var(--ff-body); color:var(--ink);
  background:var(--bl-light); line-height:1.65; font-weight:400;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
h1,h2,h4{font-family:var(--ff-heading); line-height:1.12; margin:0 0 .4em; font-weight:700; letter-spacing:-.01em}
h3{font-family:var(--ff-subheading)}
h1{font-size:clamp(2.4rem,5.2vw,4.2rem)}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:clamp(1.2rem,2vw,1.6rem)}
p{margin:0 0 1rem}
.container{max-width:var(--maxw); margin:0 auto; padding:0 24px; width:100%}
.section{padding:clamp(56px,8vw,110px) 0}
.eyebrow{font-family:var(--ff-body); font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  font-size:.74rem; color:var(--bl-primary); margin-bottom:14px; display:inline-block}
.lead{font-size:1.12rem; color:var(--muted); max-width:60ch}
.center{text-align:center}
.mx-auto{margin-left:auto; margin-right:auto}
.muted{color:var(--muted)}

/* ---------- Buttons (fixed contrast: text always readable) ---------- */
.btn,.bl-btn{
  --btn-bg:var(--bl-primary); --btn-fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  font-family:var(--ff-button); font-weight:600; font-size:.96rem;
  padding:.85em 1.7em; border-radius:999px; border:1.5px solid transparent;
  background:var(--btn-bg); color:var(--btn-fg); cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .2s, color .2s;
  box-shadow:0 10px 22px -12px color-mix(in srgb,var(--btn-bg) 70%,transparent);
  line-height:1; white-space:nowrap;
}
.btn:hover,.bl-btn:hover{transform:translateY(-2px); box-shadow:0 16px 30px -14px color-mix(in srgb,var(--btn-bg) 75%,transparent); color:var(--btn-fg)}
.btn-primary{--btn-bg:var(--bl-primary); --btn-fg:#fff}
.btn-secondary{--btn-bg:var(--bl-secondary); --btn-fg:var(--bl-on-gold)}
.btn-accent{--btn-bg:var(--bl-accent); --btn-fg:#fff}
.btn-dark{--btn-bg:var(--bl-dark); --btn-fg:#fff}
.btn-ghost{--btn-bg:transparent; --btn-fg:var(--bl-dark); border-color:currentColor; box-shadow:none}
.btn-ghost:hover{--btn-bg:var(--bl-dark); --btn-fg:#fff}
/* button icons always match the button text colour (prevents icon == background) */
.btn i,.bl-btn i{color:inherit}
.btn-light{--btn-bg:#fff; --btn-fg:var(--bl-dark)}
.btn-lg{padding:1.05em 2.1em; font-size:1.05rem}

/* ---------- Marquee (seamless, accent background, auto-contrast text) ---------- */
.bl-marquee{background:var(--bl-marq-bg,var(--bl-accent)); color:var(--bl-marq-fg,var(--bl-light));
  overflow:hidden; white-space:nowrap; font-size:.85rem; letter-spacing:.04em}
.bl-marq-track{display:flex; width:max-content; will-change:transform;
  animation:bl-scroll var(--bl-marq-dur,26s) linear infinite}
.bl-marq-group{display:flex; align-items:center; padding:9px 0; flex:0 0 auto}
.bl-marq-item{padding:0 .35em}
.bl-marq-sep{padding:0 1.1em; color:var(--bl-marq-fg,var(--bl-light)); opacity:.55}
.bl-marquee:hover .bl-marq-track{animation-play-state:paused}
@keyframes bl-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.bl-marq-track{animation:none}}

/* ---------- Topbar ---------- */
.bl-topbar{background:color-mix(in srgb,var(--bl-dark) 96%,#000); color:var(--bl-light); font-size:.84rem}
.bl-topbar .container{display:flex; justify-content:space-between; align-items:center; padding-top:9px; padding-bottom:9px}
.bl-topbar a{color:var(--bl-light); transition:color .2s}
.bl-topbar a:hover{color:var(--bl-secondary)}
.bl-topbar i{color:var(--bl-secondary); margin-right:4px}
.bl-langs{display:flex; gap:4px}
.bl-langs a{padding:2px 5px; border-radius:6px; text-transform:uppercase; font-weight:600; font-size:.72rem; opacity:.65}
.bl-langs a.active,.bl-langs a:hover{background:var(--bl-primary); color:#fff; opacity:1}

/* ---------- Navbar ---------- */
.bl-nav{position:sticky; top:0; z-index:200; background:rgba(255,255,255,.9);
  backdrop-filter:blur(14px); border-bottom:1px solid var(--line); transition:box-shadow .3s}
.bl-nav.scrolled{box-shadow:0 10px 30px -18px rgba(0,0,0,.25)}
.bl-nav .container{display:flex; align-items:center; justify-content:space-between; padding-top:12px; padding-bottom:12px}
.bl-logo img{height:52px; width:auto; object-fit:contain}
.bl-menu{display:flex; align-items:center; gap:6px; list-style:none; margin:0; padding:0}

.bl-menu a{font-family:var(--ff-nav); padding:9px 15px; border-radius:999px; font-weight:500; font-size:.95rem; color:var(--ink); transition:color .2s, background .2s; position:relative}
.bl-menu a:not(.btn):hover{color:var(--bl-primary)}
.bl-menu a.active:not(.btn){color:var(--bl-primary)}
.bl-menu a.active:not(.btn)::after{content:""; position:absolute; left:15px; right:15px; bottom:2px; height:2px; background:var(--bl-secondary); border-radius:2px}
.bl-burger{display:none; background:none; border:0; font-size:1.5rem; color:var(--bl-dark); cursor:pointer}
.bl-menu-head,.bl-menu-close,.bl-menu-contact,.bl-menu-backdrop{display:none}
.bl-menu-cta .btn{color:var(--bl-light);}

/* ---------- Secondary bar (subnav) ---------- */
.bl-subnav{position:sticky; top:0; z-index:190;
  background:color-mix(in srgb, var(--bl-dark) 96%, #000 4%);
  border-bottom:1px solid color-mix(in srgb, var(--bl-secondary) 28%, transparent)}
.bl-subnav .container{display:flex; align-items:center; justify-content:center;
  flex-wrap:wrap; gap:0; padding-top:0; padding-bottom:0}
.bl-subnav-link{position:relative; display:inline-flex; align-items:center; gap:7px;
  font-family:var(--ff-nav); font-weight:500; font-size:.82rem; letter-spacing:.04em;
  color:var(--bl-on-dark-dim); padding:11px 22px; transition:color .2s}
/* hairline gold separators between items */
.bl-subnav-link + .bl-subnav-link::before{content:""; position:absolute; left:0; top:50%;
  transform:translateY(-50%); width:1px; height:14px;
  background:color-mix(in srgb, var(--bl-secondary) 35%, transparent)}
.bl-subnav-link::after{content:""; position:absolute; left:22px; right:22px; bottom:6px;
  height:1.5px; background:var(--bl-secondary); border-radius:2px;
  transform:scaleX(0); transform-origin:center; transition:transform .25s var(--ease)}
.bl-subnav-link:hover{color:var(--bl-secondary)}
.bl-subnav-link:hover::after{transform:scaleX(1)}
@media(max-width:640px){
  .bl-subnav .container{gap:0}
  .bl-subnav-link{padding:9px 15px; font-size:.78rem}
}

/* ---------- Hero (base, themes override) ---------- */
.bl-hero{position:relative; display:flex; align-items:center; min-height:78vh;
  background-size:cover; background-position:center; color:#fff; overflow:hidden}
.bl-hero::before{content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,18,12,.34),rgba(10,18,12,.72))}
.bl-hero .container{position:relative; z-index:2; padding-top:80px; padding-bottom:80px}
.bl-hero h1{color:#fff; max-width:16ch; text-shadow:0 2px 30px rgba(0,0,0,.3)}
.bl-hero p{font-size:1.18rem; max-width:48ch; color:rgba(255,255,255,.92)}
.bl-hero .hero-cta{display:flex; gap:14px; flex-wrap:wrap; margin-top:28px}
.bl-hero .status-pill{display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.3); padding:7px 16px; border-radius:999px; font-size:.85rem; font-weight:500; margin-bottom:22px; backdrop-filter:blur(6px); color:#fff}
.status-dot{width:9px; height:9px; border-radius:50%; background:var(--bl-ok); box-shadow:0 0 0 4px var(--bl-ok-soft)}
.status-dot.closed{background:var(--bl-bad); box-shadow:0 0 0 4px var(--bl-bad-soft)}

/* ---------- Cards & grids ---------- */
.grid{display:grid; gap:26px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm);
  border:1px solid var(--line); transition:transform .35s var(--ease), box-shadow .35s var(--ease)}
.card:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.card .pad{padding:24px}
.card img.cover{height:210px; width:100%; object-fit:cover}

.feature{padding:30px 26px; border-radius:var(--radius); background:#fff; border:1px solid var(--line); transition:transform .35s var(--ease), box-shadow .35s var(--ease)}
.feature:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.feature .ic{width:58px; height:58px; border-radius:16px; display:grid; place-items:center; font-size:1.4rem;
  background:color-mix(in srgb,var(--bl-primary) 12%,#fff); color:var(--bl-primary); margin-bottom:18px}

.section-head{max-width:680px; margin:0 auto clamp(34px,5vw,56px); text-align:center}

/* ---------- Menu (premium restaurant layout) ---------- */
.menu-tabs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:46px}
.menu-tabs a{font-family:var(--ff-nav);font-size:.9rem;font-weight:600;letter-spacing:.02em;padding:.6em 1.3em;border-radius:999px;
  border:1.5px solid var(--line);color:var(--ink);transition:all .2s var(--ease)}
.menu-tabs a:hover{border-color:var(--bl-primary);color:var(--bl-primary)}
.menu-tabs a.active{background:var(--bl-primary);border-color:var(--bl-primary);color:#fff}

.menu-cat{max-width:880px;margin:0 auto clamp(40px,6vw,72px);scroll-margin-top:130px}
.menu-cat-head{text-align:center;margin-bottom:34px}
.menu-cat-head .eyebrow{display:block}
.menu-sub-title{display:flex;align-items:center;gap:14px;font-size:1.15rem;font-weight:600;margin:30px 0 6px}
.menu-sub-title::after{content:"";flex:1;height:1px;background:var(--line)}

.dish{display:flex;gap:18px;padding:18px 0;align-items:flex-start}
.dish + .dish{border-top:1px solid color-mix(in srgb,var(--line) 70%,transparent)}
.dish .d-thumb{width:72px;height:72px;border-radius:12px;object-fit:cover;flex:none}
.dish .d-main{flex:1;min-width:0}
.dish .d-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.dish .d-name{font-family:var(--ff-subheading);font-weight:600;font-size:1.1rem;overflow-wrap:anywhere}
.dish .d-dots{flex:1;border-bottom:2px dotted color-mix(in srgb,var(--ink) 22%,transparent);transform:translateY(-4px);min-width:24px}
.dish .d-price{font-weight:700;color:var(--bl-primary);white-space:nowrap;font-size:1.05rem;margin-left:auto}
.dish .d-price s{color:var(--muted);font-weight:400;margin-right:7px;font-size:.92em}
.dish .d-desc{color:var(--muted);font-size:.92rem;margin:.3em 0 0;max-width:60ch}
.dish .d-desc2,.dish .d-desc3{font-size:.86rem;margin-top:.15em;opacity:.85}
.dish .d-meta{display:flex;align-items:center;gap:10px;margin-top:8px;flex-wrap:wrap}
.tag{display:inline-block;font-size:.62rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:3px 9px;border-radius:999px;background:var(--bl-secondary);color:var(--bl-on-gold);vertical-align:middle}
.tag.new{background:var(--bl-primary);color:#fff}
.tag.chef{background:var(--bl-dark);color:#fff}
.tag.popular{background:var(--bl-accent);color:#fff}
/* small inline diet dots */
.diet{display:inline-flex;align-items:center;gap:5px;font-size:.74rem;font-weight:600;color:var(--muted)}
.diet .dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.diet.veg .dot{background:var(--bl-ok)}.diet.vegan .dot{background:color-mix(in srgb,var(--bl-ok) 80%,#000)}
.diet.spicy .dot,.diet.medium .dot,.diet.non .dot{background:var(--bl-accent)}
.allergens-row{display:inline-flex;gap:4px;align-items:center;flex-wrap:wrap}
.allergen{width:16px;height:16px;display:inline-block;vertical-align:middle;opacity:.65}
.allergen-label{font-size:.7rem;color:var(--muted);margin-right:2px}

/* ---------- Info strip ---------- */
.bl-infostrip{background:var(--bl-primary); color:#fff}
.bl-infostrip .container{display:grid; grid-template-columns:repeat(3,1fr); gap:20px; padding:34px 24px}
.bl-infostrip .item{display:flex; gap:14px; align-items:flex-start}
.bl-infostrip i{font-size:1.4rem; color:var(--bl-secondary); margin-top:3px}
.bl-infostrip h4{font-family:var(--ff-body); font-weight:600; margin:0 0 3px; color:#fff; font-size:1rem}
.bl-infostrip p{margin:0; color:rgba(255,255,255,.85); font-size:.92rem}
.bl-infostrip a i {color: var(--bl-light);}

/* ---------- Footer (FIXED: logo not forced white) ---------- */
.bl-footer{background:var(--bl-dark); color:var(--bl-on-dark-dim); padding:70px 0 0}
.bl-footer .cols{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:46px}
.bl-footer .f-logo{height:64px; width:auto; object-fit:contain; margin-bottom:18px}
.bl-footer h5{color:#fff; font-family:var(--ff-body); font-weight:600; font-size:1.02rem; margin:0 0 16px; letter-spacing:.02em}
.bl-footer a{color:var(--bl-on-dark-dim); transition:color .2s}
.bl-footer a:hover{color:var(--bl-secondary)}
.bl-footer ul{list-style:none; margin:0; padding:0; display:grid; gap:10px}
.bl-social{display:flex; gap:10px; margin-top:18px;flex-flow: wrap;}
.bl-social a{width:40px; height:40px; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.08); color:#fff; transition:background .25s, transform .25s}
.bl-social a:hover{background:var(--bl-secondary); color:var(--bl-dark); transform:translateY(-3px)}
.bl-footbar{border-top:1px solid rgba(255,255,255,.1); padding:20px 0; font-size:.85rem;
  display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap}
.bl-footbar a{color:var(--bl-secondary)}

/* ---------- Floating food icons ---------- */
.bl-foodicons{position:fixed; left:16px; bottom:16px; z-index:120; display:flex; flex-direction:column; gap:8px; align-items:flex-start}
.bl-foodicons span{display:inline-flex; align-items:center; gap:6px; background:#fff; color:var(--bl-dark);
  padding:6px 12px; border-radius:999px; font-size:.78rem; font-weight:600; box-shadow:var(--shadow-sm)}
.bl-foodicons span img{height:20px; width:auto}
/* image-only badge: no pill chrome, image at 120px wide */
.bl-foodicons span.img-only{background:none; box-shadow:none; padding:0; border-radius:0}
.bl-foodicons span.img-only img{width:80px; height:auto}

/* ---------- WhatsApp float ---------- */
.bl-wa{position:fixed; right:18px; bottom:18px; z-index:130; width:58px; height:58px; border-radius:50%;
  background:var(--bl-whatsapp); color:#fff; display:grid; place-items:center; font-size:1.7rem; box-shadow:0 12px 30px -8px rgba(37,211,102,.6)}
.bl-wa::after{content:""; position:absolute; inset:0; border-radius:50%; background:var(--bl-whatsapp); z-index:-1; animation:bl-pulse 2.4s infinite}
@keyframes bl-pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.9);opacity:0}}

/* ---------- Popup ---------- */
.bl-popup-mask{position:fixed; inset:0; background:rgba(8,14,10,.6); z-index:400; display:flex; align-items:center; justify-content:center; padding:20px; backdrop-filter:blur(4px); transition:opacity .4s var(--ease), backdrop-filter .4s var(--ease)}
.bl-popup{background:#fff; border-radius:var(--radius); max-width:460px; width:100%; overflow:hidden; box-shadow:var(--shadow); position:relative; animation:pop .4s var(--ease); transition:transform .4s var(--ease), opacity .4s var(--ease)}
@keyframes pop{from{transform:scale(.9) translateY(20px); opacity:0}to{transform:none; opacity:1}}
.bl-popup-mask.is-closing{opacity:0; backdrop-filter:blur(0)}
.bl-popup-mask.is-closing .bl-popup{transform:scale(.92) translateY(16px); opacity:0; animation:none}
.bl-popup .pad{padding:30px}
.bl-popup .x{position:absolute; top:12px; right:14px; background:rgba(0,0,0,.4); color:#fff; border:0; width:32px; height:32px; border-radius:50%; cursor:pointer; font-size:1rem}

/* ---------- Closed screen ---------- */
.bl-closed{min-height:100vh; display:grid; place-items:center; text-align:center; color:#fff; position:relative;
  background:var(--bl-dark) center/cover; padding:40px}
.bl-closed::before{content:""; position:absolute; inset:0; background:rgba(10,18,12,.7)}
.bl-closed .inner{position:relative; z-index:2; max-width:560px}
.bl-closed img{height:90px; margin:0 auto 24px}

/* ---------- Lightbox ---------- */
.lb-mask{position:fixed; inset:0; background:rgba(0,0,0,.92); z-index:500; display:none; align-items:center; justify-content:center; padding:30px}
.lb-mask img{max-width:92%; max-height:92%; border-radius:12px}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1; transform:none}

/* ============================================================ RESPONSIVE ============================================================ */
@media(max-width:900px){
  /* backdrop-filter on .bl-nav creates a containing block that traps the
     position:fixed menu; drop it on mobile so the panel covers the viewport */
  .bl-nav{backdrop-filter:none}
  .bl-menu{position:fixed; inset:0 0 0 auto; width:min(340px,88vw); background:#fff; flex-direction:column;
    align-items:stretch; padding:0; gap:0; transform:translateX(100%); transition:transform .35s var(--ease);
    box-shadow:-20px 0 60px -20px rgba(0,0,0,.4); z-index:400; overflow-y:auto}
  .bl-menu.open{transform:none}
  .bl-menu-head{display:flex; align-items:center; justify-content:space-between; padding:18px 20px;
    border-bottom:1px solid var(--line); position:sticky; top:0; background:#fff; z-index:2}
  .bl-menu-logo{height:38px; width:auto; object-fit:contain}
  .bl-menu-close{background:var(--bl-light); color:var(--bl-dark); border:0; width:38px; height:38px;
    border-radius:10px; font-size:1.2rem; cursor:pointer; display:grid; place-items:center}
  .bl-menu li{width:100%}
  .bl-menu a{color: var(--bl-light);}
  .bl-menu a:not(.btn){display:flex; align-items:center; justify-content:space-between; width:100%;
    padding:10px 15px; border-bottom:1px solid var(--line); border-radius:0; font-size:1.05rem; font-weight:500; color:var(--ink)}
  .bl-menu a:not(.btn) i{color:var(--muted); font-size:.85rem}
  .bl-menu a.active:not(.btn){color:var(--bl-primary)}
  .bl-menu a.active:not(.btn)::after{display:none}
  .bl-menu a.active:not(.btn) i{color:var(--bl-primary)}
  .bl-menu-cta{padding:20px 22px 8px}
  .bl-menu-cta .btn{width:100%; justify-content:center; padding:.95em 1em}
  .bl-menu-contact{padding:8px 22px 24px; display:flex; flex-direction:column; gap:14px;background-color: var(--bl-light);margin-top: 10px;}
  .bl-menu-contact > a{display:flex; align-items:center; gap:10px; color:var(--bl-primary); font-weight:600; padding:0; border:0; justify-content:flex-start}
  .bl-menu-contact > a i{color:var(--bl-secondary); font-size:1rem}
  .bl-menu-social{display:flex; gap:10px;flex-wrap:wrap;}
  .bl-menu-social a{width:40px; height:40px; border-radius:50%; display:grid; place-items:center;
    background:var(--bl-secondary); color:var(--bl-dark); font-size:1rem; border:1px solid var(--secondary)}
  .bl-menu-social a:hover{background:var(--bl-accent); color:#fff; border-color:var(--bl-accent)}
  .bl-menu-social a:not(.btn) {display:grid;align-items:center;justify-content:center;}
  .bl-menu-social a:not(.btn) i {color: var(--bl-dark);font-size: 20px;}
  .bl-menu-social a:not(.btn):hover i {color: var(--bl-light);}
  .bl-menu-backdrop{position:fixed; inset:0; background:rgba(8,14,10,.5); z-index:390; display:none}
  .bl-menu-backdrop.show{display:block}
  .bl-burger{display:block; z-index:300}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .bl-infostrip .container{grid-template-columns:1fr; gap:18px}
  .bl-footer .cols{grid-template-columns:1fr; gap:30px}
  .bl-topbar .container{flex-direction:column; align-items:center; gap:6px}
  .bl-topbar .container div{font-size: 20px;}
  .bl-langs{flex-wrap:wrap}
  .bl-topbar .container .bl-langs {position: fixed; background: var(--bl-light); padding: 3px; border-radius: 5px; left: 0; bottom: 0; z-index: 390;}
  .bl-topbar a {color: var(--bl-primary);}
  .bl-topbar a.m-phone-tb {color: var(--line);}
  .bl-foodicons {left: 5px; bottom: 36px;}
  .hero-cta {display: grid;gap: 9px;}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important; transition:none !important}
  .reveal{opacity:1; transform:none}
}

/* ============= DESIGN 1 — "Delici": warm, elegant, serif-led ============= */

body.design-1 h1,body.design-1 h2{font-family:var(--ff-heading)}
.d1-hero{position:relative;min-height:92vh;display:flex;align-items:center;background-size:cover;background-position:center;color:#fff}
.d1-hero .container{position:relative;z-index:2;padding:90px 24px}
.d1-hero h1{color:#fff;font-size:clamp(2.6rem,5.5vw,4.6rem);margin:.1em 0 .35em}
.d1-hero p{color:rgba(255,255,255,.9);font-size:1.15rem}
.d1-hero-fade{position:absolute;left:0;right:0;bottom:0;height:120px;background:linear-gradient(transparent,var(--bl-light));z-index:1}
.d1-script{font-family:var(--ff-subheading);font-style:italic;font-size:1.5rem;color:var(--bl-secondary);display:block}
.d1-script-sm{font-family:var(--ff-subheading);font-style:italic;font-size:1.25rem;color:var(--bl-primary);display:block;margin-bottom:6px}
.d1-about{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.d1-about-imgs{position:relative;padding:0 30px 40px 0}
.d1-about-imgs .d1-img-main{width:100%;height:440px;object-fit:cover;border-radius:6px}
.d1-about-imgs .d1-img-float{position:absolute;right:0;bottom:0;width:55%;height:230px;object-fit:cover;border-radius:6px;border:8px solid var(--bl-light);box-shadow:var(--shadow)}
.d1-badge{position:absolute;top:18px;left:-18px;background:var(--bl-secondary);color:var(--bl-on-gold);font-weight:700;font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;padding:10px 18px;border-radius:4px;box-shadow:var(--shadow-sm)}
.d1-dishes{display:grid;grid-template-columns:1fr 1fr;gap:14px 46px;max-width:980px;margin:0 auto}
.d1-dish{display:flex;gap:16px;padding:14px 0;align-items:center}
.d1-dish img{width:150px;height:150px;border-radius:10px;object-fit:cover;flex:none;border:2px solid var(--bl-secondary)}
.d1-dish-body{flex:1;min-width:0}
.d1-quote{padding:clamp(70px,10vw,120px) 0;background-size:cover;background-position:center;background-attachment:fixed}
.d1-dish-body .d-head{display:flex;align-items:baseline;gap:10px;flex-wrap:nowrap;}
.d1-dish-body .d-name{font-family:var(--ff-subheading);font-weight:600;font-size:1.1rem;color:var(--bl-dark);white-space:nowrap;}
.d1-dish-body .d-dots{flex:1;border-bottom:2px dotted color-mix(in srgb,var(--ink) 22%,transparent);transform:translateY(-4px);min-width:18px;}
.d1-dish-body .d-price{font-weight:700;color:var(--bl-primary);white-space:nowrap;font-size:1.05rem;}
.d1-dish-body .d-price s{color:var(--muted);font-weight:400;margin-right:6px;font-size:.9em;}
.d1-dish-body .d-desc{color:var(--muted);font-size:.9rem;line-height:1.5;margin:.35em 0 0;}
@media(max-width:900px){.d1-about{grid-template-columns:1fr;gap:30px}.d1-about-imgs{padding:0 20px 30px 0}.d1-dishes{grid-template-columns:1fr;gap:0}.d1-quote{background-attachment:scroll}}

/* ============= DESIGN 2 — "Banana Leaf Royale": espresso + gold ============= */
body.design-2{background:var(--bl-light);color:var(--ink)}
body.design-2 .section{background:var(--bl-light)}
body.design-2 .bl-nav{background:rgba(21,17,10,.92);border-bottom:1px solid rgba(200,162,74,.22)}
body.design-2 .bl-menu a{color:var(--bl-on-dark)}
body.design-2 .bl-menu a:hover{color:var(--bl-secondary)}
body.design-2 .bl-burger{color:#fff}

/* shared gold eyebrow — small-caps tracked label echoing the engraved logo */
.d2-eyebrow{display:inline-block;font-family:var(--ff-body);font-weight:600;font-size:.74rem;
  letter-spacing:.32em;text-transform:uppercase;color:var(--bl-secondary);margin-bottom:14px}
.d2-eyebrow--dark{color:var(--bl-primary)}

/* filigree divider — thin gold rules around a centered diamond glyph */
.d2-divider{display:flex;align-items:center;justify-content:center;gap:16px;margin:0 auto 48px;max-width:240px}
.d2-divider span{height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--bl-primary))}
.d2-divider span:last-child{background:linear-gradient(90deg,var(--bl-primary),transparent)}
.d2-diamond{width:9px;height:9px;flex:0 0 auto;background:var(--bl-primary);transform:rotate(45deg);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--bl-primary) 22%,transparent)}

/* HERO — framed plate of food, gold double-rule frame */
.d2-hero{position:relative;min-height:94vh;display:flex;align-items:center;justify-content:center;
  background-size:cover;background-position:center;color:#fff;text-align:center;padding:90px 18px}
.d2-hero-frame{position:relative;z-index:2;max-width:880px;padding:clamp(34px,5vw,64px) clamp(22px,4vw,56px);
  border:1px solid rgba(231,206,142,.45);outline:1px solid rgba(231,206,142,.18);outline-offset:8px}
.d2-hero h1{color:#fff;font-size:clamp(2.6rem,6vw,5rem);margin:.12em 0 .38em;letter-spacing:-.015em}
.d2-hero p{color:rgba(255,255,255,.9);font-size:1.16rem;max-width:54ch;margin:0 auto 1.8rem}
.d2-hero .hero-cta{justify-content:center}
.d2-scroll{position:absolute;left:50%;bottom:26px;translate:-50% 0;z-index:2;width:24px;height:38px;
  border:1.5px solid rgba(231,206,142,.6);border-radius:14px}
.d2-scroll span{position:absolute;left:50%;top:7px;translate:-50% 0;width:3px;height:7px;border-radius:2px;
  background:var(--bl-secondary);animation:d2scroll 1.6s var(--ease) infinite}
@keyframes d2scroll{0%{opacity:0;top:7px}40%{opacity:1}80%{opacity:0;top:18px}100%{opacity:0}}

/* ABOUT — stacked images with inset, cream background */
.d2-about{background:#fff}
.d2-about-imgs{position:relative;padding-bottom:34px;padding-right:34px}
.d2-img-main{width:100%;height:480px;object-fit:cover;border-radius:6px;box-shadow:var(--shadow)}
.d2-img-inset{position:absolute;right:0;bottom:0;width:46%;height:230px;object-fit:cover;border-radius:6px;
  border:5px solid #fff;box-shadow:var(--shadow)}
.d2-signature{font-family:var(--ff-display);font-style:italic;font-size:1.25rem;color:var(--bl-primary);margin:.2em 0 1.1em}

/* DARK BAND (features) */
.d2-band{background:var(--bl-dark);color:var(--bl-on-dark);padding:clamp(64px,9vw,120px) 0;
  background-image:radial-gradient(circle at 50% -10%,rgba(200,162,74,.14),transparent 60%)}
.d2-band .muted{color:rgba(243,234,214,.66)}
.d2-feat{text-align:center;padding:14px 18px}
.d2-feat .ic{width:64px;height:64px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;
  font-size:1.5rem;color:var(--bl-secondary);border:1px solid rgba(231,206,142,.4);
  background:radial-gradient(circle,rgba(200,162,74,.16),transparent 72%)}
.d2-feat h3{color:#fff;font-size:1.18rem;margin-bottom:.4em}

/* DISHES — plated cards */
.d2-dish{background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.d2-dish:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.d2-dish-media{aspect-ratio:4/3;overflow:hidden}
.d2-dish-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.d2-dish:hover .d2-dish-media img{transform:scale(1.07)}
.d2-dish-body{padding:20px 22px 24px;position:relative}
.d2-dish-body h3{font-size:1.2rem;margin-bottom:.35em}
.d2-dish-desc{color:var(--muted);font-size:.9rem;margin:0 0 .2em;min-height:2.6em}
.d2-dish-price{display:inline-block;margin-top:10px;font-family:var(--ff-display);font-weight:700;
  font-size:1.15rem;color:var(--bl-primary)}
.d2-dish-price::before{content:"";display:inline-block;width:22px;height:1px;background:var(--bl-primary);
  vertical-align:middle;margin-right:9px;opacity:.6}

/* STATS strip */
.d2-stats{background:var(--bl-dark);padding:46px 0;border-top:1px solid rgba(231,206,142,.18)}
.d2-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.d2-stat .n{display:block;font-family:var(--ff-display);font-size:clamp(2rem,4vw,2.8rem);color:var(--bl-secondary);line-height:1}
.d2-stat .l{display:block;margin-top:8px;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(243,234,214,.7)}

/* QUOTE — parallax */
.d2-quote{padding:clamp(72px,11vw,130px) 0;background-size:cover;background-position:center;background-attachment:fixed}
.d2-quote-mark{font-size:2rem;color:var(--bl-secondary);margin-bottom:.4em}
.d2-quote-text{color:#fff;font-style:italic;font-weight:500;font-size:clamp(1.4rem,2.6vw,2.1rem);line-height:1.4}
.d2-quote-author{color:var(--bl-secondary);letter-spacing:.16em;text-transform:uppercase;font-size:.8rem;margin-top:1.2em}
@media(max-width:900px){.d2-quote{background-attachment:scroll}}

/* GALLERY grid */
.d2-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.d2-gallery-item{display:block;overflow:hidden;border-radius:6px;aspect-ratio:1/1;padding:0;border:0;background:none;cursor:zoom-in;width:100%}
.d2-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),filter .4s}
.d2-gallery-item:hover img{transform:scale(1.08);filter:brightness(1.06)}

/* CTA — framed on dark photo */
.d2-cta{background-size:cover;background-position:center;padding:clamp(70px,10vw,120px) 18px}
.d2-cta-frame{max-width:640px;margin:0 auto;padding:clamp(34px,5vw,60px) 30px;
  border:1px solid rgba(231,206,142,.45);outline:1px solid rgba(231,206,142,.18);outline-offset:7px}

@media(max-width:760px){
  .d2-stats-row{grid-template-columns:repeat(2,1fr);gap:30px 16px}
  .d2-gallery{grid-template-columns:repeat(2,1fr)}
  .d2-img-inset{position:static;width:100%;height:200px;margin-top:14px;border-width:0}
  .d2-about-imgs{padding:0}
}

/* ============= DESIGN 3 — "Resca": classic, refined ============= */

.d3-hero{position:relative;min-height:88vh;display:flex;align-items:center;background-size:cover;background-position:center;color:#fff}
.d3-hero .container{position:relative;z-index:2;padding:90px 24px}
.d3-hero h1{color:#fff;font-size:clamp(2.6rem,5.5vw,4.4rem)}
.d3-hero p{color:rgba(255,255,255,.9);font-size:1.12rem}
.d3-eyebrow{font-family:var(--ff-nav);letter-spacing:.28em;text-transform:uppercase;font-size:.78rem;color:var(--bl-secondary);font-weight:600}
.d3-divider{display:flex;align-items:center;justify-content:center;gap:12px;margin:14px 0 20px;color:var(--bl-secondary)}
.d3-divider span{height:1px;width:60px;background:currentColor;opacity:.5}
.d3-frame{padding:16px;border:1px solid var(--line);border-radius:4px}
.d3-frame img{width:100%;height:430px;object-fit:cover;border-radius:2px}
.d3-menu{display:grid;grid-template-columns:1fr 1fr;gap:8px 48px;max-width:980px;margin:0 auto}
.d3-dish{padding:14px 0;border-bottom:1px dashed var(--line)}
.d3-quote{padding:clamp(70px,10vw,120px) 0;background-size:cover;background-position:center}
@media(max-width:900px){.d3-menu{grid-template-columns:1fr;gap:0}.d3-frame img{height:300px}}

/* ============= DESIGN 4 — "Cafino": modern café ============= */
body.design-4{--bl-light:#fff}
.d4-hero{display:grid;grid-template-columns:1.05fr 1fr;gap:50px;align-items:center;padding:60px 0}
.d4-hero img{border-radius:24px;height:520px;width:100%;object-fit:cover;box-shadow:var(--shadow)}
.d4-hero h1{font-size:clamp(2.4rem,5vw,4rem)}
.d4-stat{font-family:var(--ff-heading);font-size:2.8rem;color:var(--bl-primary);font-weight:700;line-height:1}
.d4-dish{display:flex;gap:16px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;align-items:center;transition:transform .3s var(--ease),box-shadow .3s}
.d4-dish:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.d4-dish img{width:96px;height:96px;border-radius:12px;object-fit:cover;flex:none}
.d4-dish-body{flex:1;min-width:0}
.d4-mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:170px;gap:14px}
.d4-mosaic img{width:100%;height:100%;object-fit:cover;border-radius:14px}
.d4-mosaic img.big{grid-column:span 2;grid-row:span 2}
.d4-cta{padding:clamp(70px,10vw,120px) 0;background-size:cover;background-position:center}
@media(max-width:900px){.d4-hero{grid-template-columns:1fr}.d4-hero img{height:340px}.d4-mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}.d4-mosaic img.big{grid-column:span 2;grid-row:span 1}}

/* ============= DESIGN 5 — "Barab": contemporary, big type ============= */

.d5-hero{position:relative;min-height:92vh;display:flex;align-items:center;background-size:cover;background-position:center;color:#fff}
.d5-hero .container{position:relative;z-index:2;padding:90px 24px}
.d5-hero h1{color:#fff;font-size:clamp(3rem,7vw,5.6rem);line-height:1;margin:.1em 0 .35em}
.d5-hero p{color:rgba(255,255,255,.9);font-size:1.15rem}
.d5-eyebrow{display:inline-block;font-family:var(--ff-nav);letter-spacing:.26em;text-transform:uppercase;font-size:.78rem;color:var(--bl-secondary);font-weight:600;margin-bottom:8px}
.d5-feats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.d5-feat{display:flex;gap:14px;align-items:flex-start}
.d5-feat .ic{width:50px;height:50px;border-radius:14px;flex:none;display:grid;place-items:center;font-size:1.3rem;background:color-mix(in srgb,var(--bl-primary) 12%,#fff);color:var(--bl-primary)}
.d5-feat h3{font-size:1.05rem;margin-bottom:2px}
.d5-gallery{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.d5-gallery img{width:100%;height:150px;object-fit:cover;border-radius:10px;transition:transform .3s}
.d5-gallery img:hover{transform:scale(1.04)}
@media(max-width:900px){.d5-feats{grid-template-columns:1fr 1fr}.d5-gallery{grid-template-columns:repeat(3,1fr)}}

/* ---------- Public forms (reservation, etc.) ---------- */
.bl-panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:clamp(26px,4vw,44px)}
.bl-form{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.bl-form .full{grid-column:1/-1}
.bl-field label{display:block;font-family:var(--ff-nav);font-weight:600;font-size:.88rem;margin-bottom:8px;color:var(--ink)}
.bl-field label .req{color:var(--bl-accent);margin-left:2px}
.bl-input,.bl-select,.bl-textarea{
  width:100%;font-family:var(--ff-body);font-size:1rem;color:var(--ink);background:#fff;
  padding:.85em 1.05em;border:1.5px solid var(--line);border-radius:12px;transition:border-color .2s,box-shadow .2s;outline:none}
.bl-input:focus,.bl-select:focus,.bl-textarea:focus{border-color:var(--bl-primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--bl-primary) 14%,transparent)}
.bl-input::placeholder,.bl-textarea::placeholder{color:var(--bl-placeholder)}
.bl-textarea{resize:vertical;min-height:110px}
.bl-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b746e' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.bl-radio{display:flex;gap:22px;padding-top:8px}
.bl-radio label{display:inline-flex;align-items:center;gap:8px;font-weight:500;cursor:pointer;margin:0}
.bl-radio input{width:18px;height:18px;accent-color:var(--bl-primary)}
.bl-alert{background:color-mix(in srgb,var(--bl-accent) 9%,#fff);border:1px solid color-mix(in srgb,var(--bl-accent) 30%,#fff);color:var(--bl-accent);padding:14px 18px;border-radius:12px;margin-bottom:22px;font-size:.94rem}
.bl-success{text-align:center}
.bl-success .ico{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;margin:0 auto 20px;background:color-mix(in srgb,var(--bl-primary) 14%,#fff);color:var(--bl-primary);font-size:2.3rem}
@media(max-width:640px){.bl-form{grid-template-columns:1fr}}

/* ============================================================
   MOBILE PRIORITY INFO — phones only, first content on every page
   ============================================================ */
.bl-mobile-info{display:none}
.d-none{display:none}
@media(min-width:768px){.d-md-inline{display:inline}}
@media(max-width:760px){
  .bl-mobile-info{display:block; background:var(--bl-light); padding:18px 0 8px; border-bottom:1px solid var(--line)}
  .bl-mobile-info .container{display:flex; flex-direction:column; gap:12px}
  .mi-phone{display:flex; align-items:center; justify-content:center; gap:10px; background:var(--bl-primary);
    color:#fff; font-weight:700; font-size:1.15rem; padding:14px; border-radius:14px; box-shadow:var(--shadow-sm)}
  .mi-phone i{color:var(--bl-secondary)}
  .mi-btns{display:grid; grid-template-columns:1fr 1fr; gap:10px}
  .mi-btns .btn{width:100%; padding:.95em .6em; font-size:.95rem}
  .mi-card{background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px 18px; box-shadow:var(--shadow-sm)}
  .mi-card h4{font-family:var(--ff-body); font-size:.95rem; font-weight:700; margin:0 0 10px; color:var(--bl-dark); display:flex; align-items:center; gap:8px}
  .mi-card h4 i{color:var(--bl-primary)}
  .mi-hours{list-style:none; margin:0; padding:0; display:grid; gap:5px}
  .mi-hours li{display:flex; justify-content:space-between; font-size:.88rem; color:var(--muted)}
  .mi-hours li.today{color:var(--bl-primary); font-weight:700}
  .mi-note{margin:0; font-size:.9rem; color:var(--muted)}
  .mi-row{display:flex; align-items:flex-start; gap:12px; background:#fff; border:1px solid var(--line);
    border-radius:12px; padding:13px 16px; font-size:.92rem; color:var(--ink); box-shadow:var(--shadow-sm); word-break:break-word}
  .mi-row i{color:var(--bl-primary); width:18px; text-align:center; margin-top:2px; flex:none}
  .bl-hero .container {padding-top: 20px;padding-bottom: 20px;}
  .bl-hero,.d1-hero,.d2-hero,.d3-hero,.d5-hero{min-height:auto !important;}
}

/* ============================================================
   ORDER ONLINE
   ============================================================ */
.menu-sub-title{font-family:var(--ff-subheading);font-weight:600;color:var(--bl-primary);font-size:1.05rem;margin:18px 0 6px}

/* per-dish add controls */
.ol-add{display:flex;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap}
.ol-qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.ol-qty button{width:34px;height:34px;border:0;background:#fff;font-size:1.1rem;color:var(--bl-dark);cursor:pointer;line-height:1}
.ol-qty button:hover{color: var(--bl-primary);font-weight:400;}
.ol-qty .ol-num{min-width:30px;text-align:center;font-weight:700}
.btn.sm{padding:.5em 1em;font-size:.9rem}

/* floating cart button */
.ol-cart-fab{position:fixed;right:18px;bottom:18px;z-index:400;display:flex;align-items:center;gap:10px;
  background:var(--bl-primary);color:#fff;border-radius:999px;padding:13px 20px;box-shadow:0 12px 30px -8px rgba(0,0,0,.45);cursor:pointer;font-weight:700}
.ol-cart-fab i{font-size:1.15rem}
.ol-cart-fab .ol-cart-count{position:absolute;top:-6px;left:-6px;background:var(--bl-accent);color:#fff;border-radius:50%;
  min-width:22px;height:22px;display:grid;place-items:center;font-size:.72rem;font-weight:800;padding:0 5px}
.ol-cart-fab .ol-cart-total{font-size:.98rem}

/* cart slide-over */
.ol-cart-panel{position:fixed;top:0;right:0;bottom:0;width:min(400px,92vw);background:#fff;z-index:402;
  transform:translateX(100%);transition:transform .32s var(--ease);display:flex;flex-direction:column;box-shadow:-20px 0 60px -25px rgba(0,0,0,.5)}
.ol-cart-panel.open{transform:none}
.ol-cart-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;background:var(--bl-dark);color:#fff}
.ol-cart-head h3{margin:0;font-size:1.15rem}
.ol-cart-close{background:rgba(255,255,255,.12);color:#fff;border:0;width:38px;height:38px;border-radius:10px;font-size:1.1rem;cursor:pointer}
.ol-cart-body{flex:1;overflow-y:auto;padding:16px 20px}
.ol-empty{color:var(--muted);text-align:center;padding:30px 0}
.ol-cart-item{display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.ol-ci-name{font-weight:600}
.ol-ci-cat{font-size:.78rem;color:var(--muted);margin:2px 0}
.ol-ci-price{font-size:.85rem;color:var(--bl-dark)}
.ol-ci-qty{display:flex;align-items:center;gap:6px;flex:none}
.ol-ci-qty button{width:28px;height:28px;border:1px solid var(--line);background:#fff;border-radius:7px;cursor:pointer;font-size:1rem}
.ol-ci-qty .ol-ci-rm{border-color:transparent;color:var(--bl-accent)}
.ol-cart-foot{padding:18px 22px;border-top:1px solid var(--line);background:var(--bl-light)}
.ol-cart-totalrow{display:flex;justify-content:space-between;font-weight:800;font-size:1.15rem;margin-bottom:12px}
.ol-cart-backdrop{position:fixed;inset:0;background:rgba(8,14,10,.5);z-index:401;display:none}
.ol-cart-backdrop.show{display:block}
.btn.disabled{opacity:.5;pointer-events:none}

/* checkout */
.ol-checkout{max-width:1000px}
.ol-co-title{margin:0 0 22px}
.ol-co-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:28px;align-items:start}
.ol-co-summary,.ol-co-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}
.ol-co-summary h3,.ol-co-form h3{margin:0 0 14px;font-size:1.15rem}
.ol-co-item{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.ol-co-item .nm{font-weight:600}
.ol-co-item .ct{font-size:.76rem;color:var(--muted)}
.ol-co-item .ln{text-align:right;white-space:nowrap;color:var(--muted)}
.ol-coupon-msg{font-size:.82rem;min-height:18px}
.ol-coupon-msg.ok{color:var(--bl-primary)}
.ol-coupon-msg.err{color:var(--bl-accent)}
.ol-co-totals{margin-top:14px;border-top:1px solid var(--line);padding-top:12px}
.ol-co-totals .row{display:flex;justify-content:space-between;padding:5px 0;font-size:.92rem;color:var(--muted)}
.ol-co-totals .row.total{font-size:1.2rem;font-weight:800;color:var(--bl-primary);border-top:2px solid var(--line);margin-top:6px;padding-top:10px}
.ol-f{margin-bottom:16px}
.ol-checkout .input{
  width:100%;font-family:var(--ff-body);font-size:1rem;color:var(--ink);background:#fff;
  padding:.8em 1em;border:1.5px solid var(--line);border-radius:11px;transition:border-color .2s,box-shadow .2s;outline:none}
.ol-checkout .input:focus{border-color:var(--bl-primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--bl-primary) 14%,transparent)}
.ol-checkout textarea.input{resize:vertical;min-height:90px}
.ol-checkout .input::placeholder{color:var(--bl-placeholder)}
.ol-f label{display:block;font-weight:600;font-size:.88rem;margin-bottom:5px}
.ol-f .req{color:var(--bl-accent)}
.ol-f2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ol-radios{display:flex;gap:10px;flex-wrap:wrap}
.ol-radio{display:flex;align-items:center;gap:8px;border:1.5px solid var(--line);border-radius:11px;padding:12px 14px;cursor:pointer;font-size:.92rem;font-weight:600;flex:1;min-width:130px;transition:border-color .15s,background .15s}
.ol-radio:hover{border-color:var(--bl-primary)}
.ol-radio:has(input:checked){border-color:var(--bl-primary);background:color-mix(in srgb,var(--bl-primary) 7%,#fff)}
.ol-radio input{accent-color:var(--bl-primary);width:17px;height:17px;flex:none}
.ol-coupon{display:flex;gap:8px;margin:16px 0 4px}
.ol-coupon .input{flex:1;text-transform:uppercase}
.ol-hint{font-size:.82rem;color:var(--bl-primary);margin:6px 0 0;font-weight:600}
.ol-readymsg{background:color-mix(in srgb,var(--bl-secondary) 18%,#fff);border:1px solid var(--bl-secondary);color:var(--bl-on-gold-soft);
  border-radius:12px;padding:12px 16px;font-weight:700;font-size:.95rem;margin:6px 0 16px;display:none}
.ol-error{background:var(--bl-bad-soft);border:1px solid var(--bl-accent);color:var(--bl-bad-ink);border-radius:10px;padding:12px 16px;margin-bottom:12px;font-size:.9rem}
.ol-timebox{position:fixed;right:18px;bottom:18px;z-index:150;background:var(--bl-dark);color:#fff;border-radius:14px;
  padding:14px 18px;box-shadow:0 12px 30px -10px rgba(0,0,0,.5);display:flex;gap:22px}
.ol-timebox span{display:block;font-size:.7rem;color:var(--bl-on-dark-dim);text-transform:uppercase;letter-spacing:.05em}
.ol-timebox strong{font-size:1.1rem;font-variant-numeric:tabular-nums}

/* thank you */
.ol-thanks{max-width:680px}
.ol-thanks-head{text-align:center;margin-bottom:26px}
.ol-check{font-size:3.4rem;color:var(--bl-primary);margin-bottom:8px}
.ol-readyby{display:inline-block;margin-top:14px;background:color-mix(in srgb,var(--bl-secondary) 18%,#fff);
  border:1px solid var(--bl-secondary);color:var(--bl-on-gold-soft);border-radius:999px;padding:10px 20px;font-weight:700}
.ol-thanks-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.ol-tc-head{display:flex;justify-content:space-between;align-items:center;background:var(--bl-dark);color:#fff;padding:14px 20px}
.ol-tc-items{padding:8px 20px}
.ol-tc-row{display:flex;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}
.ol-tc-row .nm{font-weight:600}
.ol-tc-row .ct{font-size:.78rem;color:var(--muted)}
.ol-tc-row .ln{text-align:right;white-space:nowrap;color:var(--muted)}
.ol-tc-row .ln strong{display:block;color:var(--bl-dark)}
.ol-tc-totals{padding:14px 20px;background:var(--bl-light)}
.ol-tc-totals .row{display:flex;justify-content:space-between;padding:4px 0;color:var(--muted)}
.ol-tc-totals .row.total{font-size:1.2rem;font-weight:800;color:var(--bl-primary);border-top:2px solid var(--line);margin-top:6px;padding-top:8px}
.ol-tc-note{padding:14px 20px;margin:0;font-size:.88rem;color:var(--muted)}
.ol-thanks-actions{display:flex;gap:12px;justify-content:center;margin-top:24px;flex-wrap:wrap}

@media(max-width:820px){
  .ol-co-grid{grid-template-columns:1fr}
  .ol-timebox {right: 5px; bottom: 5px; padding: 5px 12px; display: grid; gap: 0; align-items: center; border-radius: 7px;}
  .ol-cart-fab{bottom:14px;right:14px}
  .ol-timebox div {display: flex;gap: 10px;}
  .ol-timebox span {display: flex;align-items: center;}
}

/* Order Online CTA button */
.btn-order{background:var(--bl-accent);color:#fff;border:none}
.btn-order:hover{filter:brightness(1.08)}
.mi-order-btn{width:100%;justify-content:center}

/* ============================================================
   ORDER ONLINE — category sidebar + mobile menu overlay
   ============================================================ */
.ol-layout{display:grid;grid-template-columns:248px 1fr;gap:32px;align-items:start}
.ol-side{position:sticky;top:96px;align-self:start;max-height:calc(100vh - 120px);overflow-y:auto;
  background:#fff;border:1px solid var(--bl-light);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm)}
.ol-side-title{font-family:var(--ff-heading);font-size:1.1rem;color:var(--bl-dark);padding:6px 10px 12px;border-bottom:1px solid var(--line);margin-bottom:8px}
.ol-side-nav{display:flex;flex-direction:column}
.ol-side-cat{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:10px;
  font-weight:600;color:var(--ink);font-size:.95rem;transition:background .15s,color .15s}
.ol-side-cat:hover{background:var(--bl-light)}
.ol-side-cat.active{background:var(--bl-secondary);color:var(--bl-dark);}
.ol-side-cat.active .ol-side-count{background:rgba(0, 0, 0, 0.25);color:var(--bl-dark);}
.ol-side-count{background:var(--bl-light);color:var(--muted);border-radius:999px;font-size:.72rem;font-weight:700;padding:2px 8px;min-width:24px;text-align:center}
.ol-side-subs{display:flex;flex-direction:column;margin:2px 0 6px}
.ol-side-sub{padding:7px 12px 7px 26px;font-size:.86rem;color:var(--muted);border-left:2px solid var(--line);margin-left:14px;transition:color .15s,border-color .15s}
.ol-side-sub:hover{color:var(--bl-primary);border-color:var(--bl-primary)}
.ol-items{min-width:0}
.menu-cat{scroll-margin-top:90px}
.menu-sub-title{scroll-margin-top:90px}

/* mobile MENU floating button + overlay */
.ol-menu-fab{display:none;position:fixed;right:16px;bottom:84px;z-index:400;flex-direction:column;align-items:center;justify-content:center;
  width:62px;height:62px;border-radius:50%;background:var(--bl-dark);color:#fff;border:0;cursor:pointer;box-shadow:0 10px 26px -8px rgba(0,0,0,.5);gap:2px}
.ol-menu-fab i{font-size:1.1rem}
.ol-menu-fab span{font-size:.6rem;font-weight:700;letter-spacing:.05em}
.ol-menu-panel{position:fixed;top:0;left:0;bottom:0;width:min(330px,86vw);background:var(--bl-dark);color:#fff;z-index:402;
  transform:translateX(-100%);transition:transform .3s var(--ease);display:flex;flex-direction:column;overflow-y:auto}
.ol-menu-panel.open{transform:none}
.ol-menu-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;font-family:var(--ff-heading);font-size:1.2rem;border-bottom:1px solid rgba(255,255,255,.1)}
.ol-menu-head button{background:rgba(255,255,255,.12);color:#fff;border:0;width:36px;height:36px;border-radius:9px;font-size:1.1rem;cursor:pointer}
.ol-menu-nav{display:flex;flex-direction:column;padding:8px 0}
.ol-menu-cat{display:flex;align-items:center;justify-content:space-between;padding:15px 22px;font-weight:600;color:#fff;font-size:1rem;border-bottom:1px solid rgba(255,255,255,.06)}
.ol-menu-count{color:var(--bl-on-dark-dim);font-size:.85rem}
.ol-menu-sub{padding:11px 22px 11px 38px;color:var(--bl-on-dark-dim);font-size:.88rem;border-bottom:1px solid rgba(255,255,255,.04)}
.ol-menu-sub:hover,.ol-menu-cat:hover{background:rgba(255,255,255,.06)}
.ol-menu-backdrop{position:fixed;inset:0;background:rgba(8,14,10,.55);z-index:401;display:none}
.ol-menu-backdrop.show{display:block}

/* refined cart FAB (pill, VIEW CART) */
.ol-cart-fab .ol-cart-total{font-size:.92rem;font-weight:800;letter-spacing:.03em}

@media(max-width:900px){
  .ol-layout{grid-template-columns:1fr;gap:0}
  .ol-side{display:none}
  .ol-menu-fab{display:flex}
}

/* contact page social media */
.contact-social{margin-top:26px;padding-top:22px;border-top:1px solid var(--line)}
.contact-social-icons{display:flex;gap:12px;flex-wrap:wrap}
.contact-social-icons a{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:var(--bl-light);border:1px solid var(--line);color:var(--bl-dark);font-size:1.15rem;transition:.18s}
.contact-social-icons a:hover{background:var(--bl-primary);color:#fff;border-color:var(--bl-primary);transform:translateY(-2px)}

/* ============================================================
   GALLERY — masonry grid + rich lightbox
   ============================================================ */
.gallery-masonry{columns:3;column-gap:16px}
.gm-item{position:relative;margin:0 0 16px;break-inside:avoid;border-radius:16px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);background:#000}
.gm-item img{display:block;width:100%;height:auto;transition:transform .5s var(--ease),opacity .3s;opacity:.97}
.gm-item:hover img{transform:scale(1.06);opacity:1}
.gm-zoom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem;
  background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.4));opacity:0;transition:opacity .3s}
.gm-item:hover .gm-zoom{opacity:1}
@media(max-width:900px){.gallery-masonry{columns:2;column-gap:12px}.gm-item{margin-bottom:12px}}
@media(max-width:560px){.gallery-masonry{columns:1}}

/* lightbox */
.lb2{position:fixed;inset:0;z-index:1000;background:rgba(8,10,9,.94);display:none;flex-direction:column;
  -webkit-user-select:none;user-select:none}
.lb2.open{display:flex}
.lb2-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;color:#fff;gap:12px}
.lb2-count{font-size:.95rem;font-weight:600;letter-spacing:.04em;opacity:.85}
.lb2-tools{display:flex;gap:6px;flex-wrap:wrap}
.lb2-tools button{width:42px;height:42px;border-radius:10px;border:0;background:rgba(255,255,255,.12);color:#fff;font-size:1rem;cursor:pointer;transition:background .15s}
.lb2-tools button:hover{background:var(--bl-primary)}
.lb2-stage{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;cursor:grab}
.lb2-stage:active{cursor:grabbing}
.lb2-stage img{max-width:92vw;max-height:78vh;object-fit:contain;transition:transform .15s ease-out;border-radius:6px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb2-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;border:0;
  background:rgba(255,255,255,.14);color:#fff;font-size:1.3rem;cursor:pointer;z-index:2;transition:background .15s}
.lb2-nav:hover{background:var(--bl-primary)}
.lb2-prev{left:18px}.lb2-next{right:18px}
@media(max-width:600px){
  .lb2-nav{width:44px;height:44px;font-size:1.05rem}
  .lb2-prev{left:8px}.lb2-next{right:8px}
  .lb2-tools button{width:38px;height:38px}
  .lb2-stage img{max-width:96vw;max-height:70vh}
}


/* Order Online — offline (outside opening hours) */
.ol-offline-banner{display:flex;align-items:flex-start;gap:14px;background:color-mix(in srgb,var(--bl-secondary) 16%,#fff);
  border:1px solid var(--bl-secondary);border-radius:14px;padding:16px 20px;margin-bottom:26px;color:#5c4500}
.ol-offline-banner i{font-size:1.4rem;color:var(--bl-secondary);margin-top:2px}
.ol-offline-banner strong{display:block;font-size:1.05rem;margin-bottom:2px;color:var(--bl-dark)}
.ol-offline-banner span{font-size:.93rem;line-height:1.55}
/* when not accepting orders, hide the add-to-cart controls (menu stays browsable) */
.ol-noorder .ol-add{display:none}
