/* Bubbas Menu Frontend */
.bubbas-menu{
  position: relative;

  --bm-primary: #0e2b44;
  --bm-accent: #caa54a;
  --bm-header-bg: #0e2b44;
  --bm-header-text: #ffffff;
  --bm-logo-width: 72px;
  --bm-logo-height: 72px;
  --bm-title-size: 28px;
  --bm-section-size: 16px;
  --bm-item-size: 14px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 8px 28px rgba(0,0,0,.08);
}

.bubbas-menu__header{
  display:flex;
  gap:16px;
  align-items:center;
  padding: 18px 18px 16px;
  background: var(--bm-header-bg);
  color: var(--bm-header-text);
}
.bubbas-menu[data-header-style="rustic"] .bubbas-menu__header{
  background: linear-gradient(135deg, var(--bm-header-bg), color-mix(in srgb, var(--bm-header-bg) 90%, transparent));
}

.bubbas-menu__logo{
  width: var(--bm-logo-width);
  height: var(--bm-logo-height);
  object-fit:contain;
  border-radius: 14px;
  background: rgba(255,255,255,.08);
  padding:10px;
  border:1px solid rgba(255,255,255,.15);
}
.bubbas-menu__title{
  margin:0;
  font-size: var(--bm-title-size);
  line-height: 1.15;
}
.bubbas-menu__meta{
  margin-top:6px;
  font-size: 13px;
  opacity: .92;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.bubbas-menu__version{
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
  padding: 2px 8px;
  border-radius: 999px;
}

.bubbas-menu__content{
  padding: 18px;
}
.bubbas-menu__section{
  margin: 0 0 18px;
}
.bubbas-menu__section-title{
  margin: 0 0 10px;
  font-size: var(--bm-section-size);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--bm-primary);
  border-bottom: 2px solid rgba(202,165,74,.45);
  padding-bottom: 6px;
}
.bubbas-menu__items{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 18px;
}
.bubbas-menu__item{
  padding: 10px 10px 8px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  background: #fff;
}
.bubbas-menu__item.is-highlight{
  border-color: rgba(202,165,74,.65);
  box-shadow: 0 8px 20px rgba(202,165,74,.15);
}
.bubbas-menu__item-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.bubbas-menu__item-name{
  font-weight: 650;
  color: #111;
  line-height: 1.2;
  font-size: var(--bm-item-size);
}
.bubbas-menu__item-price{
  font-weight: 700;
  color: var(--bm-primary);
  white-space:nowrap;
  font-size: var(--bm-item-size);
}
.bubbas-menu__gf{
  color: var(--bm-accent);
  font-weight: 800;
  margin-left: 4px;
}
.bubbas-menu__badge{
  display:inline-block;
  margin-left: 6px;
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  opacity:.85;
}
.bubbas-menu__item-desc{
  margin-top: 6px;
  font-size: 13px;
  color: rgba(0,0,0,.72);
  line-height: 1.35;
}
.bubbas-menu__item-allergens{
  margin-top: 6px;
  font-size: 11px;
  color: rgba(0,0,0,.6);
  line-height: 1.35;
}

.bubbas-menu__footer{
  border-top: 1px solid rgba(0,0,0,.08);
  padding: 14px 18px;
  background: #fafafa;
}
.bubbas-menu__footline{
  font-size: 13px;
  color: rgba(0,0,0,.72);
  line-height: 1.35;
}
.bubbas-menu__footline + .bubbas-menu__footline{ margin-top: 6px; }
.bubbas-menu__contact{ font-weight: 600; }

@media (max-width: 900px){
  .bubbas-menu__items{ grid-template-columns: 1fr; }
  .bubbas-menu__logo{ width:60px; height:60px; }
  .bubbas-menu__title{ font-size: 24px; }
}

/* Print friendly */
@media print {
  .bubbas-menu{
    box-shadow:none;
    border: none;
  }
  .bubbas-menu__header{
    background: #fff !important;
    color:#000 !important;
    border-bottom: 2px solid #000;
  }
  .bubbas-menu__version{ border-color:#000; }
}


.bubbas-menu__download{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
  color:#fff;
  text-decoration:none;
  font-weight:650;
}
.bubbas-menu__download:hover{ background: rgba(255,255,255,.20); }
@media print{ .bubbas-menu__download{ display:none !important; } }


.bubbas-menu[data-bg-url]:not([data-bg-url=""])::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: var(--bm-bg-image);
  background-size: var(--bm-bg-size, cover);
  background-position: var(--bm-bg-position, center);
  background-repeat: var(--bm-bg-repeat, no-repeat);
  background-attachment: var(--bm-bg-attachment, fixed);
  opacity: var(--bm-bg-opacity, 0.15);
  pointer-events:none;
  z-index:0;
}
.bubbas-menu > *{ position: relative; z-index:1; }
