/* File: tailwind-nav-components.css */
/* Componenti di navigazione ottimizzati per dispositivi mobili */

/* Nav bar principale */
.tw-mobile-navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 1rem;
  position: sticky;
  top: 0;
  z-index: 40;
  background-color: var(--card-background, #ffffff);
  border-bottom: 1px solid var(--border-color, #e2e8f0);
  width: 100%;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

@media (max-width: 480px) {
  .tw-mobile-navbar {
    padding: 0.5rem 0.75rem;
  }
}

/* Bottom navigation */
.tw-mobile-tabs {
  display: flex;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--card-background, #ffffff);
  border-top: 1px solid var(--border-color, #e2e8f0);
  padding: 0.5rem 0;
  z-index: 50;
  justify-content: space-around;
  box-shadow: 0 -1px 3px rgba(0, 0, 0, 0.05);
  padding-bottom: calc(0.5rem + env(safe-area-inset-bottom, 0px));
}

.tw-mobile-tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0.25rem 0.5rem;
  font-size: 0.75rem;
  color: var(--secondary-text, #64748b);
  transition: color 0.2s ease;
}

.tw-mobile-tab.active {
  color: var(--primary-color, #4a6cf7);
}

.tw-mobile-tab-icon {
  margin-bottom: 0.25rem;
  font-size: 1.25rem;
}

/* Drawer navigation */
.tw-mobile-drawer {
  position: fixed;
  left: 0;
  top: 0;
  bottom: 0;
  width: 80%;
  max-width: 300px;
  background-color: var(--card-background, #ffffff);
  z-index: 60;
  transform: translateX(-100%);
  transition: transform 0.3s ease;
  overflow-y: auto;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  padding-top: env(safe-area-inset-top, 0px);
}

.tw-mobile-drawer.open {
  transform: translateX(0);
}

.tw-drawer-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 55;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.tw-drawer-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

/* Menu items */
.tw-menu-item {
  display: flex;
  align-items: center;
  padding: 0.75rem 1rem;
  color: var(--text-color, #2d3748);
  border-bottom: 1px solid var(--border-color, #e2e8f0);
  text-decoration: none;
}

.tw-menu-item.active {
  background-color: rgba(var(--primary-rgb, '74, 108, 247'), 0.1);
  color: var(--primary-color, #4a6cf7);
}

.tw-menu-icon {
  margin-right: 0.75rem;
}

/* Pill navigation (come generi) */
.tw-pill-nav {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  padding: 0.5rem 0.25rem;
  gap: 0.5rem;
  scrollbar-width: none;
  -ms-overflow-style: none;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  max-width: 100%;
}

.tw-pill-nav::-webkit-scrollbar {
  display: none;
}

.tw-pill {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  padding: 0.375rem 0.75rem;
  border-radius: 9999px;
  background-color: var(--tag-bg, #e2e8f0);
  color: var(--tag-text, #4a5568);
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  user-select: none;
  transition: background-color 0.2s ease, transform 0.1s ease;
}

.tw-pill:active {
  transform: scale(0.95);
}

.tw-pill.active {
  background-color: var(--primary-color, #4a6cf7);
  color: white;
}