/* Category Popup (Bottom Sheet) Styles */
.cat-popup-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 1000; opacity: 0; visibility: hidden; transition: all 0.3s; backdrop-filter: blur(2px); display: flex; align-items: flex-end; }
.cat-popup-overlay.active { opacity: 1; visibility: visible; }
.cat-popup-sheet { background: white; width: 100%; border-radius: 20px 20px 0 0; transform: translateY(100%); transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); max-height: 85vh; display: flex; flex-direction: column; }
.cat-popup-overlay.active .cat-popup-sheet { transform: translateY(0); }
.cat-popup-header { padding: 20px; border-bottom: 1px solid var(--light-gray); display: flex; justify-content: space-between; align-items: center; position: relative; }
.cat-popup-header::before { content: ""; position: absolute; top: 8px; left: 50%; transform: translateX(-50%); width: 40px; height: 4px; border-radius: 4px; background: #ddd; }
.cat-popup-title { font-family: 'Bebas Neue', 'Heebo', sans-serif; font-size: 24px; letter-spacing: 1px; }
.cat-popup-close { background: none; border: none; font-size: 28px; cursor: pointer; color: var(--gray); line-height: 1; padding: 0 8px; }
.cat-popup-content { padding: 0; overflow-y: auto; flex: 1; }

.cat-popup-item { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid #f0f0f0; text-decoration: none; color: var(--black); transition: background 0.2s; }
.cat-popup-item:active { background: var(--cream); }
.cat-popup-item-name { font-weight: 700; font-size: 14px; }
.cat-popup-item-arrow { color: var(--gray); font-size: 12px; }

@media (min-width: 769px) {
  .cat-popup-overlay { display: none !important; }
}
