/* ═══════════ MENU VIEW ═══════════ */
.menu-layout{display:flex;flex:1;overflow:hidden}
.menu-left{
  width:88px;flex-shrink:0;background:rgba(254,252,247,.5);
  border-right:1px solid var(--border-subtle);overflow-y:auto;
  scrollbar-width:none;
}
.menu-left::-webkit-scrollbar{display:none}
.menu-left-title{padding:14px 8px 10px;font-size:10px;color:var(--text-muted);text-align:center;letter-spacing:1px}
.cat-item{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:12px 6px;margin:2px 6px;border-radius:var(--r-sm);
  font-size:11px;cursor:pointer;color:var(--text-secondary);
  transition:all var(--dur) var(--ease-out);font-weight:500;
}
.cat-item .cat-emoji{font-size:20px}
.cat-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}
.menu-right{flex:1;overflow-y:auto;padding:16px 14px}
.menu-cat-title{font-size:16px;font-weight:700;margin-bottom:14px}
#menu-grid{display:flex;flex-direction:column;gap:10px}

/* 菜单骨架屏 */
.dish-skeleton{
  background:var(--bg-card);border:1px solid var(--border-subtle);
  border-radius:var(--r);display:flex;gap:12px;padding:12px;
  overflow:hidden;
}
.dish-skeleton .skel-img{width:80px;height:80px;border-radius:var(--r-sm);background:var(--bg-deep);animation:shimmer 1.6s infinite}
.dish-skeleton .skel-body{flex:1;display:flex;flex-direction:column;gap:8px;justify-content:center}
.dish-skeleton .skel-line{height:12px;border-radius:6px;background:var(--bg-deep);animation:shimmer 1.6s infinite}
.dish-skeleton .skel-line.short{width:60%}
.dish-skeleton .skel-line.price{width:80px;height:16px}
@keyframes shimmer{
  0%{opacity:.4}50%{opacity:.8}100%{opacity:.4}
}

/* 菜品卡片 */
.dish-card{
  background:var(--bg-card);border:1px solid var(--border-subtle);
  border-radius:var(--r);display:flex;gap:12px;padding:12px;
  cursor:pointer;transition:all var(--dur) var(--ease-out);
  box-shadow:var(--shadow-bubble);animation:cardIn .4s var(--ease-out)both;
}
@keyframes cardIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.dish-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.dish-card:active{transform:scale(.98);border-color:var(--accent)}
.dish-card-img{
  width:80px;height:80px;min-width:80px;border-radius:var(--r-sm);
  background:var(--bg-deep);display:flex;align-items:center;
  justify-content:center;overflow:hidden;
}
.dish-card-img .placeholder-icon{font-size:30px}
.dish-card-body{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-width:0}
.dish-card-title{display:flex;justify-content:space-between;align-items:center}
.dish-card-name{font-size:15px;font-weight:600}
.dish-card-price{font-size:17px;font-weight:700;color:var(--accent)}
.dish-card-desc{font-size:12px;color:var(--text-muted);margin:3px 0}
.dish-tag{display:inline-block;padding:2px 10px;border-radius:var(--r-full);font-size:10px;font-weight:500;margin-right:4px}
.dish-tag.spicy{background:rgba(220,38,38,.08);color:var(--danger)}
.dish-tag.mild{background:rgba(22,163,74,.08);color:var(--success)}
.dish-meta{display:flex;flex-wrap:wrap;gap:4px}
.dish-add-btn{
  align-self:flex-end;width:34px;height:34px;border-radius:50%;
  border:2px solid var(--accent);background:transparent;color:var(--accent);
  font-size:18px;cursor:pointer;display:flex;align-items:center;
  justify-content:center;transition:all var(--dur) var(--ease-out);font-family:inherit;
}
.dish-add-btn:active{background:var(--accent);color:#fff;transform:scale(.9)}
.dish-qty-row{display:flex;align-items:center;gap:8px;margin-top:6px}
.dish-qty-minus,.dish-qty-plus{
  width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border-default);
  background:var(--bg-card);display:flex;align-items:center;
  justify-content:center;cursor:pointer;font-size:16px;font-family:inherit;
}
.dish-qty-num{font-size:15px;font-weight:600;min-width:24px;text-align:center}
.dish-note-input{
  flex:1;padding:5px 10px;border:1px solid var(--border-default);
  border-radius:var(--r-xs);background:var(--bg-card);font-size:12px;font-family:inherit;
}
.dish-qty-badge{
  position:absolute;top:3px;right:3px;min-width:22px;height:22px;
  border-radius:50%;background:var(--accent);color:#fff;
  font-size:11px;font-weight:700;display:flex;align-items:center;
  justify-content:center;animation:badgePop .3s var(--ease-spring);
}
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}
