@charset "UTF-8";
/*
 * Application Styles - Modern and Clean
 * Only specific files are imported to avoid conflicts
 */
/* Import only what we need */
/* line 1, app/assets/stylesheets/alerts.css */
.alert {
  padding: 1rem;
  margin-bottom: 1rem;
  border: 1px solid transparent;
  border-radius: 0.375rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  position: relative;
}

/* line 11, app/assets/stylesheets/alerts.css */
.alert-alert {
  color: #854d0e;
  background-color: #fef3c7;
  border-color: #fde68a;
}

/* ==============================================================
   SIDEBAR MODERNA - EFEITOS E ANIMAÇÕES AVANÇADAS
   ============================================================== */
/* Variáveis CSS customizadas */
/* line 6, app/assets/stylesheets/sidebar.css */
:root {
  --sidebar-width: 320px;
  --sidebar-collapsed-width: 80px;
  --sidebar-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --sidebar-border-radius: 16px;
  --sidebar-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  --sidebar-backdrop-blur: 20px;
}

/* Efeitos de glassmorphism na sidebar */
/* line 16, app/assets/stylesheets/sidebar.css */
.sidebar-wrapper {
  backdrop-filter: blur(var(--sidebar-backdrop-blur));
  -webkit-backdrop-filter: blur(var(--sidebar-backdrop-blur));
  box-shadow: var(--sidebar-shadow);
  border-right: 1px solid rgba(255, 255, 255, 0.1);
}

/* Garantir altura total e distribuição correta */
/* line 24, app/assets/stylesheets/sidebar.css */
.sidebar-container {
  height: 100vh;
  height: 100dvh;
  /* Para suporte a mobile */
}

/* line 29, app/assets/stylesheets/sidebar.css */
.sidebar-wrapper {
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

/* Layout da navegação */
/* line 37, app/assets/stylesheets/sidebar.css */
.sidebar-nav {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  /* Importante para flexbox */
}

/* Container dos itens de navegação */
/* line 45, app/assets/stylesheets/sidebar.css */
.nav-items-container {
  flex: 1;
  min-height: 0;
}

/* Posicionar logout no final */
/* line 51, app/assets/stylesheets/sidebar.css */
.logout-container {
  margin-top: auto;
}

/* Animações de hover nos itens de navegação */
/* line 56, app/assets/stylesheets/sidebar.css */
.nav-item {
  position: relative;
  overflow: hidden;
  transform: translateZ(0);
  transition: var(--sidebar-transition);
}

/* line 63, app/assets/stylesheets/sidebar.css */
.nav-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
  transition: left 0.5s ease;
}

/* line 74, app/assets/stylesheets/sidebar.css */
.nav-item:hover::before {
  left: 100%;
}

/* Efeito de ripple ao clicar */
/* line 79, app/assets/stylesheets/sidebar.css */
.nav-item::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  transform: translate(-50%, -50%);
  transition: width 0.3s ease, height 0.3s ease;
  pointer-events: none;
}

/* line 93, app/assets/stylesheets/sidebar.css */
.nav-item:active::after {
  width: 200px;
  height: 200px;
}

/* Animação do ícone de toggle */
/* line 99, app/assets/stylesheets/sidebar.css */
.toggle-btn i {
  transition: transform 0.3s ease;
}

/* line 103, app/assets/stylesheets/sidebar.css */
.toggle-btn:hover i {
  transform: scale(1.1);
}

/* Gradiente animado no avatar */
/* line 108, app/assets/stylesheets/sidebar.css */
.avatar-wrapper {
  position: relative;
  background: linear-gradient(45deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.2));
  transition: var(--sidebar-transition);
}

/* line 114, app/assets/stylesheets/sidebar.css */
.avatar-wrapper::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  background: linear-gradient(45deg, #ff6b6b, #4ecdc4, #45b7d1, #96ceb4);
  background-size: 300% 300%;
  animation: gradientShift 4s ease infinite;
  z-index: -1;
  opacity: 0;
  transition: opacity 0.3s ease;
}

/* line 127, app/assets/stylesheets/sidebar.css */
.user-profile:hover .avatar-wrapper::before {
  opacity: 1;
}

@keyframes gradientShift {
  0%, 100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

/* Efeito de pulsação no status online */
/* line 141, app/assets/stylesheets/sidebar.css */
.user-status {
  animation: pulse 2s infinite;
  box-shadow: 0 0 0 rgba(34, 197, 94, 0.7);
}

@keyframes pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.7);
  }
  70% {
    box-shadow: 0 0 0 10px rgba(34, 197, 94, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(34, 197, 94, 0);
  }
}

/* Animação do indicador ativo */
/* line 159, app/assets/stylesheets/sidebar.css */
.active-indicator {
  animation: slideIn 0.3s ease-out;
}

@keyframes slideIn {
  from {
    height: 0;
    opacity: 0;
  }
  to {
    height: 2rem;
    opacity: 1;
  }
}

/* Micro-interações nos ícones */
/* line 175, app/assets/stylesheets/sidebar.css */
.nav-icon {
  transition: var(--sidebar-transition);
}

/* line 179, app/assets/stylesheets/sidebar.css */
.nav-item:hover .nav-icon {
  transform: scale(1.1) rotate(5deg);
}

/* Estados da sidebar colapsada */
/* line 184, app/assets/stylesheets/sidebar.css */
.sidebar-container.collapsed {
  width: 80px !important;
}

/* line 188, app/assets/stylesheets/sidebar.css */
.sidebar-container.collapsed .sidebar-wrapper {
  width: 80px !important;
}

/* line 192, app/assets/stylesheets/sidebar.css */
.sidebar-container.collapsed .logo-text,
.sidebar-container.collapsed .nav-text,
.sidebar-container.collapsed .footer-content .nav-text {
  opacity: 0;
  pointer-events: none;
  transform: translateX(-10px);
}

/* line 200, app/assets/stylesheets/sidebar.css */
.sidebar-container.collapsed .nav-icon {
  margin-right: -5px !important;
}

/* line 204, app/assets/stylesheets/sidebar.css */
.sidebar-container.collapsed .nav-item {
  justify-content: center;
  padding: 12px !important;
}

/* line 209, app/assets/stylesheets/sidebar.css */
.sidebar-container.collapsed .active-indicator {
  display: none;
}

/* Tooltip para o modo colapsado */
/* line 214, app/assets/stylesheets/sidebar.css */
.nav-item.tooltip-enabled {
  position: relative;
}

/* line 218, app/assets/stylesheets/sidebar.css */
.nav-item.tooltip-enabled::after {
  content: attr(data-tooltip);
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  background: linear-gradient(135deg, rgba(0, 0, 0, 0.9), rgba(31, 41, 55, 0.9));
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  color: white;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.025em;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
  margin-left: 8px;
  z-index: 1000;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
}

/* line 242, app/assets/stylesheets/sidebar.css */
.sidebar-container.collapsed .nav-item.tooltip-enabled:hover::after {
  opacity: 1;
}

/* Scrollbar customizada */
/* line 247, app/assets/stylesheets/sidebar.css */
.sidebar-nav::-webkit-scrollbar {
  width: 6px;
}

/* line 251, app/assets/stylesheets/sidebar.css */
.sidebar-nav::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 3px;
}

/* line 256, app/assets/stylesheets/sidebar.css */
.sidebar-nav::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.1));
  border-radius: 3px;
}

/* line 261, app/assets/stylesheets/sidebar.css */
.sidebar-nav::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.3), rgba(255, 255, 255, 0.2));
}

/* line 265, app/assets/stylesheets/sidebar.css */
.sidebar-nav {
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.2) transparent;
}

/* Efeito de brilho no logo */
/* line 271, app/assets/stylesheets/sidebar.css */
.logo-avatar {
  position: relative;
  overflow: hidden;
}

/* line 276, app/assets/stylesheets/sidebar.css */
.logo-avatar::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  transform: rotate(45deg);
  animation: shine 3s infinite;
}

@keyframes shine {
  0% {
    transform: translateX(-100%) translateY(-100%) rotate(45deg);
  }
  50% {
    transform: translateX(100%) translateY(100%) rotate(45deg);
  }
  100% {
    transform: translateX(-100%) translateY(-100%) rotate(45deg);
  }
}

/* Botão mobile melhorado */
/* line 301, app/assets/stylesheets/sidebar.css */
.mobile-menu-btn {
  transition: all 0.3s ease;
}

/* line 305, app/assets/stylesheets/sidebar.css */
.mobile-menu-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}

/* line 310, app/assets/stylesheets/sidebar.css */
.mobile-menu-btn:active {
  transform: scale(0.95);
}

/* Responsividade mobile - SEM overlay fosco */
@media (max-width: 1024px) {
  /* line 316, app/assets/stylesheets/sidebar.css */
  .sidebar-container {
    transform: translateX(-100%);
    transition: transform 0.3s ease-in-out;
  }
  /* line 321, app/assets/stylesheets/sidebar.css */
  .sidebar-container.mobile-open {
    transform: translateX(0);
  }
  /* Melhorar backdrop para mobile */
  /* line 326, app/assets/stylesheets/sidebar.css */
  .sidebar-container {
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
  }
}

/* Modo escuro */
@media (prefers-color-scheme: dark) {
  /* line 334, app/assets/stylesheets/sidebar.css */
  :root {
    --sidebar-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
  }
}

/* Animação de entrada suave */
/* line 340, app/assets/stylesheets/sidebar.css */
.sidebar-container {
  animation: slideInLeft 0.5s ease-out;
}

@keyframes slideInLeft {
  from {
    transform: translateX(-100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

/* Remover efeitos desnecessários em mobile */
@media (max-width: 1024px) {
  /* line 357, app/assets/stylesheets/sidebar.css */
  .sidebar-container {
    animation: none;
  }
  /* line 361, app/assets/stylesheets/sidebar.css */
  .nav-item::before,
.logo-avatar::before {
    display: none;
  }
}

/* Garantir que elementos não transbordem */
/* line 368, app/assets/stylesheets/sidebar.css */
.sidebar-wrapper * {
  box-sizing: border-box;
}

/* Ajuste fino para o user profile */
/* line 373, app/assets/stylesheets/sidebar.css */
.user-profile {
  transition: all 0.3s ease;
}

/* line 377, app/assets/stylesheets/sidebar.css */
.sidebar-container.collapsed .user-info,
.sidebar-container.collapsed .user-status {
  opacity: 0;
  pointer-events: none;
  transform: translateX(-10px);
  transition: all 0.3s ease;
}

/* line 385, app/assets/stylesheets/sidebar.css */
.sidebar-container.collapsed .user-profile {
  justify-content: center;
}

/* ==============================================================
   LIGHT MODE - Background #F2F2F2, dark text and borders
   ============================================================== */
/* line 392, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .sidebar-wrapper {
  border-right-color: rgba(0, 0, 0, 0.08);
}

/* line 396, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .sidebar-header,
.sidebar-container.sidebar-light .sidebar-profile {
  border-color: rgba(0, 0, 0, 0.08) !important;
}

/* line 401, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .logo-text h2,
.sidebar-container.sidebar-light .logo-text p {
  color: #111827 !important;
}

/* line 406, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .logo-text p {
  color: #4b5563 !important;
}

/* line 410, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .close-mobile-btn i {
  color: #4b5563 !important;
}

/* line 414, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .close-mobile-btn:hover i {
  color: #111827 !important;
}

/* line 418, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .close-mobile-btn:hover {
  background: rgba(0, 0, 0, 0.06) !important;
}

/* line 422, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .nav-item {
  color: #374151 !important;
}

/* line 426, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .nav-item:hover {
  background: rgba(0, 0, 0, 0.06) !important;
  color: #111827 !important;
}

/* line 431, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .nav-item.bg-white\/15 {
  background: rgba(0, 0, 0, 0.08) !important;
  color: #111827 !important;
}

/* line 436, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .nav-icon {
  color: #6b7280 !important;
}

/* line 440, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .nav-item:hover .nav-icon,
.sidebar-container.sidebar-light .nav-item.bg-white\/15 .nav-icon {
  color: #111827 !important;
}

/* line 445, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .active-indicator {
  background: #111827 !important;
}

/* line 449, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .user-name {
  color: #111827 !important;
}

/* line 453, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .user-email {
  color: #6b7280 !important;
}

/* line 457, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .avatar-wrapper.ring-2 {
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.1);
}

/* line 461, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light.collapsed .nav-icon {
  color: #6b7280 !important;
}

/* line 465, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .nav-text {
  color: inherit;
}

/* line 469, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .logout-container .nav-item {
  color: #374151 !important;
}

/* line 473, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .logout-container .nav-item:hover {
  background: rgba(239, 68, 68, 0.12) !important;
  color: #dc2626 !important;
}

/* line 478, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .logout-container .nav-item:hover .nav-icon {
  color: #dc2626 !important;
}

/* line 482, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .footer-content .nav-text {
  color: #6b7280 !important;
}

/* line 486, app/assets/stylesheets/sidebar.css */
.sidebar-container.sidebar-light .footer-content .nav-icon {
  color: #6b7280 !important;
}

/* Custom Fonts */
@font-face {
  font-family: 'Drephonic';
  src: url(/assets/fonts/drephonic.otf) format("opentype"), url(/assets/fonts/drephonic.ttf) format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* Custom styles - Most styles should use Tailwind classes */
/* Avatar styles - Consider using Tailwind classes: rounded-full w-12 h-12 object-cover */
/* line 23, app/assets/stylesheets/application.scss */
.rounded-avatar {
  border-radius: 50%;
  width: 50px;
  height: 50px;
  object-fit: cover;
}

/* Sidebar responsive behavior */
@media (min-width: 992px) {
  /* line 32, app/assets/stylesheets/application.scss */
  .sidenav {
    transform: translateX(0);
    position: fixed;
    width: 250px;
    height: 100%;
    top: 0;
    left: 0;
  }
}
