:root { --nav-h: 56px; }

.navbar.fixed-top { height: var(--nav-h); }

/* ===== Top Nav ===== */
.melo-nav {
  --glass1: rgba(255,255,255,.82);
  --glass2: rgba(255,255,255,.62);
  --border: rgba(255,170,200,.55);
  --ink: #5a2740;

  background: linear-gradient(180deg, var(--glass1), var(--glass2)) !important;
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 6px 18px rgba(0,0,0,.10);
}

.melo-nav-inner {
  height: var(--nav-h);
  padding-inline: 14px;
  display: flex;
  align-items: center;
}

/* Brand */
.melo-brand { display:flex; align-items:center; gap:10px; text-decoration:none; }
.melo-brand .brand-logo{
  width:30px;height:30px;border-radius:999px;
  display:grid;place-items:center;
  background: radial-gradient(120% 120% at 30% 20%, #fff 0%, #ffe7ef 32%, #ffd2e2 65%, #ffc0d8 100%);
  border: 1px solid rgba(255,170,200,.55);
  box-shadow: 0 4px 10px rgba(200,80,120,.16), inset 0 1px 0 rgba(255,255,255,.9);
}
.melo-brand .brand-text{
  font-weight:800; letter-spacing:.4px; font-size:16px;
  background: linear-gradient(90deg, #b44e78, #7c3a57);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* Reusable pink pill */
.melo-pill{
  height: 36px; padding: 0 12px;
  display:inline-flex; align-items:center; gap:8px;
  border-radius: 999px; border:1px solid rgba(255,170,200,.55);
  background: linear-gradient(180deg, #fff, #ffeaf1);
  color: var(--ink); font-weight:800; font-size:12px;
  box-shadow: 0 6px 16px rgba(200,80,120,.14), inset 0 1px 0 rgba(255,255,255,.92);
}

/* Points pill */
.melo-points .pt-ico{ width:18px; height:18px; object-fit:contain; }
.melo-points .pt-num{ min-width: 2ch; }

/* Menu button */
.melo-menu { width: 44px; padding:0 10px; cursor:pointer; }
.melo-menu .bar{
  width: 18px; height: 2px; background:#7c3a57; display:block; border-radius:2px; margin:3px auto;
  transition: transform .18s ease, opacity .18s ease;
}
.melo-menu:hover{ background:#fff; }
.melo-menu:active{ transform: translateY(1px); }

/* ===== Drawer ===== */
.melo-drawer{
  --glass: rgba(255,255,255,.78);
  --glassb: rgba(255,255,255,.62);
  background: linear-gradient(180deg, var(--glass), var(--glassb));
  border-left: 1px solid rgba(255,170,200,.55);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
}
.melo-drawer .offcanvas-header{ border-bottom:1px solid rgba(255,170,200,.45); }
.melo-drawer .drawer-title{
  display:flex; align-items:center; gap:8px; color:#5a2740;
}

.drawer-list{ list-style:none; padding:12px 2px; margin:0; display:grid; gap:10px; }
.drawer-list a{
  display:block; padding:12px 14px; border-radius:14px; text-decoration:none;
  background: rgba(255,255,255,.86);
  border:1px solid rgba(255,170,200,.55);
  color:#5a2740; font-weight:800;
  transition: transform .12s ease, background-color .12s ease;
}
.drawer-list a:hover{ background:#fff; transform: translateY(-1px); }

@media (max-width: 600px){
  :root { --nav-h: 52px; }
  .melo-brand .brand-text{ font-size:15px; }
  .melo-brand .brand-logo{ width:28px;height:28px; }
  .melo-pill{ height:34px; }
}
/* === MELO Dark Rose Nav Override === */
/* 更深的梅紅玻璃，搭配黑底；字與icon走粉白，pill 用深色底＋粉邊 */
.melo-nav{
  background: linear-gradient(180deg, rgba(137, 49, 93, 0.86), rgba(20,8,14,.70)) !important;
  border-bottom: 1px solid rgba(255,130,170,.28) !important;
  box-shadow: 0 6px 18px rgba(0,0,0,.22);
  backdrop-filter: saturate(150%) blur(10px);
  -webkit-backdrop-filter: saturate(150%) blur(10px);
}
.melo-nav-inner{ padding-inline: 18px; }

.melo-brand .brand-logo{
  background: radial-gradient(120% 120% at 30% 20%, #ffecf4 0%, #ffd4e5 45%, #ffbad4 100%);
  border-color: rgba(255,130,170,.35);
  box-shadow: 0 4px 10px rgba(200,80,120,.20), inset 0 1px 0 rgba(255,255,255,.95);
}
.melo-brand .brand-text{
  background: linear-gradient(90deg, #ffd6e7, #ff9fbe);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  letter-spacing: .6px;
}

/* 深色 pill（比較不突兀） */
.melo-pill{
  background: linear-gradient(180deg, #2a0f1c, #3a1525);
  border-color: rgba(255,130,170,.35);
  color: #ffe5ef;
  box-shadow: 0 8px 20px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.06);
}
.melo-pill:hover{ background: linear-gradient(180deg, #331324, #45182d); }

/* 點數與漢堡細節 */
.melo-points .pt-ico{ filter: drop-shadow(0 0 2px rgba(255,180,210,.25)); }
.melo-points .pt-num{ color:#ffe9f2; }
.melo-menu .bar{ background:#ffd6e7; }

/* Drawer 也改深，與頁面一致 */
.melo-drawer{
  background: linear-gradient(180deg, rgba(20,8,14,.94), rgba(20,8,14,.86)) !important;
  border-left: 1px solid rgba(255,130,170,.28) !important;
  backdrop-filter: saturate(150%) blur(10px);
}
.melo-drawer .offcanvas-header{ border-bottom:1px solid rgba(255,130,170,.22); }
.melo-drawer .drawer-title{ color:#ffd9e9; }

.drawer-list a{
  background: rgba(46,18,29,.92);
  border: 1px solid rgba(255,130,170,.28);
  color: #ffe5ef;
}
.drawer-list a:hover{
  background: #4d1c30;
  transform: translateY(-1px);
}

/* Pink-tinted close button inside drawer */
.melo-drawer .btn-close.btn-close-white{
  filter: invert(1) grayscale(100%) brightness(200%) sepia(12%) hue-rotate(-10deg) saturate(150%);
  opacity: .9;
}
.melo-drawer .btn-close.btn-close-white:focus {
  box-shadow: 0 0 0 0.15rem rgba(255,150,190,.45);
  opacity: 1;
}
/* ===== Mobile vertical centering fix ===== */
@media (max-width: 600px){
  /* 移除 Bootstrap 預設 padding，改用我們自己的容器高度 */
  .navbar.melo-nav { padding: 0 !important; }
  .melo-nav .container-fluid,
  .melo-nav-inner{
    height: var(--nav-h);
    padding-inline: 16px !important;
    display: flex; align-items: center; /* 垂直置中 */
  }

  /* brand 本身不要額外上下 padding/行高 */
  .melo-brand{
    padding: 0 !important; margin: 0;
    line-height: 1; display: flex; align-items: center; gap: 10px;
  }
  .melo-brand .brand-logo img{ display:block; }
  .melo-brand .brand-text{ display:block; }

  /* 右側區域強制貼齊置中 */
  .melo-nav .ms-auto{ height: 100%; display: flex; align-items: center; gap: 8px; }

  /* pill / 菜單鈕的高度與垂直置中 */
  .melo-pill{ height: 36px; padding: 0 12px; display: inline-flex; align-items: center; }
  .melo-menu{ height: 36px; width: 48px; display: inline-flex; align-items: center; justify-content: center; }
  .melo-menu .bar{ margin: 3px 0; }

  /* 點數圖示避免基線下沉 */
  .melo-points .pt-ico{ display:block; }

  /* iOS 瀏海安全區，內容仍維持置中 */
  .navbar.fixed-top{
    height: calc(var(--nav-h) + env(safe-area-inset-top));
    padding-top: env(safe-area-inset-top);
  }
  .melo-nav-inner{ height: var(--nav-h); } /* 內容區高度不含安全區，保持計算簡單 */
}
