/* Autocomplete de Tipo de Peça */
.select-with-search {
  position: relative;
}

.search-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid var(--border-color);
  border-radius: 10px;
  margin-top: 4px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
  z-index: 1000;
  max-height: 260px;
  overflow: auto;
}

.search-dropdown .search-item {
  padding: 8px 10px;
  cursor: pointer;
}

.search-dropdown .search-item:hover {
  background: #f5f7ff;
}

.search-dropdown .search-item.active {
  background: #e6ecff;
}

.search-dropdown mark {
  background: #ffef9c;
  color: inherit;
  padding: 0 2px;
}

/* Header user dropdown */
.user-profile .user-dropdown {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% - 2px);
  background: #fff;
  border: 1px solid var(--border-color);
  border-radius: 12px;
  min-width: 240px;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.12);
  padding: 10px;
  z-index: 2000;
}

.user-profile {
  padding-bottom: 4px;
}

.user-profile:hover .user-dropdown {
  display: block;
}

.user-drop-header {
  padding: 6px 8px 10px 8px;
  border-bottom: 1px solid var(--border-light);
  margin-bottom: 8px;
}

.user-name {
  font-weight: 700;
  color: var(--primary-color);
}

.user-email {
  font-size: 0.85rem;
  color: var(--text-muted);
}

.user-drop-item {
  display: block;
  padding: 8px 8px;
  color: var(--text-color);
  text-decoration: none;
  border-radius: 8px;
}

.user-drop-item i {
  width: 18px;
}

.user-drop-item:hover {
  background: #fff7e6;
  color: var(--primary-color);
}

/* Conta: botão dourado sempre */
.user-area .nav-pill {
  background: var(--secondary-color) !important;
  color: #1A2B4D !important;
  border-color: var(--secondary-color) !important;
}

.user-area .nav-pill:hover {
  background: var(--secondary-color) !important;
  border-color: var(--secondary-color) !important;
}

/* Header layout: center nav, account on right */
.app-header .header-container {
  justify-content: space-between !important;
}

.app-header .main-nav {
  flex: 1 1 auto;
  justify-content: center !important;
}

.app-header .main-nav ul {
  justify-content: center !important;
}

.user-area {
  display: flex;
  align-items: center;
}

/* UI/UX utilities e refinamentos neutros (sem trocar cores) para páginas atuais */
/* Este arquivo NÃO altera palette; usa variáveis e estilos já existentes em static/style.css */

/* Header full-width claro (remover "janela"/gradiente) */
/* Header azul+dourado em toda a aplicação */
.app-header {
  background: var(--gradient-primary) !important;
  color: #fff !important;
  border-bottom: 3px solid var(--secondary-color) !important;
  box-shadow: var(--box-shadow-medium) !important;
}

.app-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0));
  pointer-events: none;
}

.app-header .app-logo a {
  color: #fff !important;
}

.app-header .main-nav a,
.app-header .auth-nav a {
  color: #fff !important;
  background: transparent !important;
  border-color: transparent !important;
}

.app-header .main-nav a:hover,
.app-header .auth-nav a:hover {
  color: var(--secondary-color) !important;
  background: transparent !important;
  border-color: var(--secondary-color) !important;
}

.nav-pill.active {
  background: var(--secondary-color) !important;
  color: #1A2B4D !important;
  border-color: var(--secondary-color) !important;
}

/* Header pills (estilo protótipo) */
.nav-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 8px;
  color: var(--text-color);
  text-decoration: none;
  border: 1px solid var(--border-color);
  background: #f7f8fb;
  transition: background .15s ease, box-shadow .15s ease, color .15s ease, border-color .15s ease;
}

.nav-pill:hover {
  background: #eff2f7;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04) inset;
}

.nav-pill.active {
  background: var(--secondary-color);
  color: #fff !important;
  border-color: var(--secondary-color);
}

/* Títulos de página – estilo sóbrio, alinhado à dashboard */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.page-header .ux-title {
  font-size: 1.75rem;
  font-weight: 800;
  letter-spacing: 0.2px;
  margin: 0;
}

.page-header .ux-subtitle {
  margin-top: 4px;
  color: var(--text-light);
  font-size: 0.98rem;
}

/* Seções e tipografia (sem alterar cores globais) */
.ux-section {
  padding: 16px 0;
}

.ux-title {
  margin: 0;
  font-weight: 800;
  letter-spacing: 0.2px;
}

.ux-subtitle {
  margin-top: 6px;
  opacity: 0.9;
}

.ux-kpis {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.ux-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border-color);
  background: #fff;
}

.ux-text-muted {
  color: var(--text-light);
}

/* Grid/Flex helpers sem interferir no layout existente */
.ux-flex-gap-8 {
  display: flex;
  gap: 8px;
}

.ux-flex-gap-12 {
  display: flex;
  gap: 12px;
}

.ux-gap-8 {
  gap: 8px;
}

.ux-gap-12 {
  gap: 12px;
}

.ux-mt-2 {
  margin-top: 8px
}

.ux-mt-3 {
  margin-top: 12px
}

.ux-mt-4 {
  margin-top: 16px
}

.ux-mb-2 {
  margin-bottom: 8px
}

.ux-mb-3 {
  margin-bottom: 12px
}

.ux-mb-4 {
  margin-bottom: 16px
}

.ux-p-2 {
  padding: 8px
}

.ux-p-3 {
  padding: 12px
}

.ux-p-4 {
  padding: 16px
}

.ux-rounded {
  border-radius: 12px;
}

/* Layout full-page: remover "pop-up"/card e ocupar a tela toda para usuários logados */
.full-width {
  max-width: none !important;
  margin: 0 !important;
  padding: 0 16px;
}

.tool-main.no-chrome {
  padding-top: 16px;
}

.tool-main.no-chrome .tool-card {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* Desativar completamente efeitos de hover e barra superior dos tool-cards em full-page */
.tool-main.no-chrome .tool-card:hover {
  transform: none !important;
  box-shadow: none !important;
  background: transparent !important;
}

.tool-main.no-chrome .tool-card::before {
  display: none !important;
}

/* Também remover fundo gradiente do body se logado para evitar efeito de janela */
body:has(header.app-header + main.tool-main.no-chrome) {
  background: #f7f7fb !important;
}

/* PETICIONAR: refinamentos visuais mantendo as cores atuais */
/* Container mais definido, sem mudar a cor original de fundo */
.pecas-container {
  border: 1px solid var(--border-color);
  border-radius: 12px;
  overflow: hidden;
}

/* Cabeçalho com mais respiro, mantendo a cor original (#4c5c8a) herdada do template */
.pecas-header {
  padding: 16px 20px;
}

.pecas-header h3 {
  font-weight: 800;
  letter-spacing: 0.5px;
}

/* Área interna com espaçamentos consistentes; removemos aparência "chapada" */
.pecas-grid {
  background-color: transparent !important;
  padding: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  /* espaçamento entre itens/colunas */
}

.pecas-column {
  padding: 8px;
}

/* Itens mais "clicáveis" e com micro-interações; mantemos a estética clara atual */
.peca-item {
  border: 1px solid var(--border-color);
  border-left: 3px solid #8a6cef;
  /* mantém destaque original */
  background-color: #fff;
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  transition: transform 0.15s ease, box-shadow 0.2s ease, border-left-color 0.2s ease;
}

.peca-item:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
  border-left-color: var(--primary-color);
}

.peca-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background-color: #f4f4ff;
  color: #8a6cef;
}

.peca-text {
  font-weight: 600;
}

/* Cartão superior da página: melhorar legibilidade mantendo estilos atuais */
.tool-card {
  border-radius: 12px;
}

.tool-title {
  font-weight: 800;
}

.tool-subtitle {
  color: var(--text-light);
}