/* Substitui as variáveis de logo do GLPI pela logo Pedeai em todas as páginas
 * (login + navbar + menu lateral + qualquer outro lugar que use --glpi-logo*). */
:root {
  --glpi-logo:               url('/plugins/modernlogin/pedeai-logo.webp') !important;
  --glpi-logo-reduced:       url('/plugins/modernlogin/pedeai-logo.webp') !important;
  --glpi-logo-light:         url('/plugins/modernlogin/pedeai-logo.webp') !important;
  --glpi-logo-light-reduced: url('/plugins/modernlogin/pedeai-logo.webp') !important;
  --glpi-logo-dark:          url('/plugins/modernlogin/pedeai-logo.webp') !important;
  --glpi-logo-dark-reduced:  url('/plugins/modernlogin/pedeai-logo.webp') !important;
  --glpi-logo-light-login:   url('/plugins/modernlogin/pedeai-logo.webp') !important;
  --glpi-logo-dark-login:    url('/plugins/modernlogin/pedeai-logo.webp') !important;
}

/* Garante que o background-size cubra a área do span sem distorcer */
.glpi-logo {
  background-size: contain !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

/* ===== Tela de login (anonymous page) ===== */

body.welcome-anonymous {
  background: #f5f6f8 !important;
}

/* Card de login com mesma largura/estilo da tela de troca de senha. */
body.welcome-anonymous .container-tight {
  max-width: 30rem !important;
  width: 100% !important;
  padding: 1.5rem !important;
}

/* Esconde o wrapper da logo que ficava acima do card */
body.welcome-anonymous .container-tight > .text-center {
  display: none !important;
}

/* Card visual igual ao firstpassword. */
body.welcome-anonymous .card {
  border-radius: 14px !important;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.08) !important;
  border: 1px solid #e9ecef !important;
}

body.welcome-anonymous .card-body {
  padding: 2rem !important;
}

/* Logo dentro do card. */
body.welcome-anonymous .card-body::before {
  content: '';
  display: block;
  width: 160px;
  height: 50px;
  margin: 0 auto 1.5rem;
  background: url('/plugins/modernlogin/pedeai-logo.webp') no-repeat center / contain;
}

/* Título do form centralizado. */
body.welcome-anonymous .card-body h2,
body.welcome-anonymous .card-body .card-title {
  text-align: center !important;
  font-weight: 700 !important;
  color: #333 !important;
  margin-bottom: 1.25rem !important;
  font-size: 1.15rem !important;
}

/* Labels mais firmes. */
body.welcome-anonymous .form-label,
body.welcome-anonymous label {
  font-weight: 600 !important;
  color: #333 !important;
}

/* Inputs com mais respiro e foco verde. */
body.welcome-anonymous .form-control,
body.welcome-anonymous .form-select {
  border-radius: 8px !important;
  padding: 0.6rem 0.75rem !important;
}

body.welcome-anonymous .form-control:focus,
body.welcome-anonymous .form-select:focus {
  border-color: #00B334 !important;
  box-shadow: 0 0 0 .2rem rgba(0, 179, 52, .15) !important;
}

/* Botão Entrar full-width. */
body.welcome-anonymous .btn-primary {
  width: 100% !important;
  padding: 0.65rem 1rem !important;
  font-weight: 600 !important;
  border-radius: 8px !important;
  margin-top: 0.5rem !important;
}

/* Form ocupa toda a largura do card-body */
body.welcome-anonymous form .row {
  margin: 0 !important;
  --bs-gutter-x: 0 !important;
}
body.welcome-anonymous form .col-md-5 {
  flex: 0 0 100% !important;
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
}

/* Espaço entre os campos. */
body.welcome-anonymous form .mb-3,
body.welcome-anonymous form .form-group {
  margin-bottom: 1rem !important;
}

/* ===== Sidebar (preview de cor) ===== */
aside.navbar-vertical,
aside.navbar-vertical .navbar-collapse,
.page-sidebar,
#header {
  background-color: #333333 !important;
  --tblr-navbar-bg: #333333 !important;
  --tblr-bg-surface: #333333 !important;
  /* Sobrescreve a cor primária só dentro da sidebar: amarelo forte claro */
  --tblr-primary: #F0B72F !important;
  --tblr-primary-rgb: 240, 183, 47 !important;
  --tblr-link-color: #F0B72F !important;
  --tblr-link-color-rgb: 240, 183, 47 !important;
}

/* ===== Visão simplificada (helpdesk): topbar com a mesma cor da sidebar do central =====
 * GLPI usa --glpi-mainmenu-bg / --glpi-mainmenu-fg na .topbar; sobrescrevendo
 * essas duas variáveis no body.helpdesk a topbar já fica #333 com texto amarelo. */
body.helpdesk {
  --glpi-mainmenu-bg: #333333 !important;
  --glpi-mainmenu-fg: #ffffff !important;
}

body.helpdesk header.navbar,
body.helpdesk header.navbar.topbar,
body.helpdesk .topbar {
  background-color: #333333 !important;
  --tblr-navbar-bg: #333333 !important;
  --tblr-primary: #ffffff !important;
  --tblr-primary-rgb: 255, 255, 255 !important;
  --tblr-link-color: #ffffff !important;
  --tblr-link-color-rgb: 255, 255, 255 !important;
}

/* Texto/ícones do menu em branco; itens inativos mantêm a opacidade 0.7 do GLPI. */
body.helpdesk header.navbar .nav-link,
body.helpdesk header.navbar .nav-link i,
body.helpdesk header.navbar .menu-label,
body.helpdesk header.navbar .navbar-brand,
body.helpdesk header.navbar .navbar-toggler,
body.helpdesk .topbar .nav-link,
body.helpdesk .topbar .nav-link i,
body.helpdesk .topbar .menu-label {
  color: #ffffff !important;
}

/* Item ativo cheio (sem a opacidade 0.7 aplicada aos inativos pelo GLPI). */
body.helpdesk .topbar .nav-item.active a.nav-link,
body.helpdesk .topbar .nav-link.active,
body.helpdesk header.navbar .nav-item.active a.nav-link,
body.helpdesk header.navbar .nav-link.active {
  color: #ffffff !important;
  opacity: 1 !important;
}

/* Oculta o item "Reservas" do menu na visão simplificada (helpdesk). */
body.helpdesk header.navbar #navbar-menu li.nav-item:has(a[href*="reservationitem.php"]),
body.helpdesk .topbar #navbar-menu li.nav-item:has(a[href*="reservationitem.php"]) {
  display: none !important;
}

/* Item ativo e pai expandido em amarelo (texto + ícone, inclusive SVG) */
aside.navbar-vertical .nav-link.active,
aside.navbar-vertical .nav-link.active *,
aside.navbar-vertical .nav-item.active > .nav-link,
aside.navbar-vertical .nav-item.active > .nav-link *,
aside.navbar-vertical .nav-link[aria-expanded="true"],
aside.navbar-vertical .nav-link[aria-expanded="true"] *,
aside.navbar-vertical .nav-item.show > .nav-link,
aside.navbar-vertical .nav-item.show > .nav-link *,
.page-sidebar .nav-link.active,
.page-sidebar .nav-link.active *,
.page-sidebar .nav-link[aria-expanded="true"],
.page-sidebar .nav-link[aria-expanded="true"] * {
  color: #F0B72F !important;
  fill: #F0B72F !important;
  stroke: #F0B72F !important;
}

/* ===== Fonte padrão Nunito ===== */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;500;600;700;800&display=swap');

:root {
  --tblr-font-sans-serif: 'Nunito', system-ui, -apple-system, Segoe UI, Roboto, sans-serif !important;
}

html, body, .navbar, .btn, .form-control, .form-select, input, select, textarea, button, table {
  font-family: 'Nunito', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif !important;
}

/* ===== Loading: substitui spinners pelo Loading.png =====
 * Sem rotação. Dimensiona-se ao contêiner (1em = font-size do pai),
 * com limite máx. para não estourar caixas pequenas (ex.: botões). */
.spinner-border,
.spinner-grow,
.fa-spin,
svg.fa-spin {
  border: none !important;
  background-image: url('/plugins/modernlogin/Loading.png') !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
  color: transparent !important;
  animation: none !important;
  display: inline-block !important;
  width: 1em !important;
  height: 1em !important;
  max-width: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  vertical-align: -0.125em;
}

.spinner-border::after,
.spinner-grow::after,
.fa-spin::before { content: '' !important; }

svg.fa-spin > * { visibility: hidden !important; }

/* ===== Listagens (chamados, etc.): texto #333333, exceto sidebar ===== */
.page-body,
.page-body table,
.page-body .table,
.page-body thead,
.page-body tbody,
.page-body tr,
.page-body th,
.page-body td,
.page-body .list-group-item,
.page-body .card-table,
.page-body a:not(.btn) {
  color: #333333 !important;
}

/* ===== Botões: cor primária verde ===== */
:root {
  --tblr-primary: #00B334 !important;
  --tblr-primary-rgb: 0, 179, 52 !important;
  --tblr-primary-fg: #ffffff !important;
  --tblr-link-color: #00B334 !important;
  --tblr-link-color-rgb: 0, 179, 52 !important;
}

.btn-primary,
.btn-primary:visited {
  background-color: #00B334 !important;
  border-color: #00B334 !important;
  color: #ffffff !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active,
.btn-primary:focus-visible {
  background-color: #009129 !important;
  border-color: #009129 !important;
  color: #ffffff !important;
  box-shadow: 0 0 0 .25rem rgba(0, 179, 52, .25) !important;
}

.btn-outline-primary {
  color: #00B334 !important;
  border-color: #00B334 !important;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
  background-color: #00B334 !important;
  border-color: #00B334 !important;
  color: #ffffff !important;
}

/* ===== Tela de troca obrigatória de senha =====
 * Esconde navegação e estiliza como card central. */
/* Esconde toda a navegação (sidebar, topbar, footer). */
body.modernlogin-updatepassword aside,
body.modernlogin-updatepassword aside.navbar-vertical,
body.modernlogin-updatepassword .page-sidebar,
body.modernlogin-updatepassword .navbar-vertical,
body.modernlogin-updatepassword header,
body.modernlogin-updatepassword header.navbar,
body.modernlogin-updatepassword .topbar,
body.modernlogin-updatepassword .page-header,
body.modernlogin-updatepassword .page-footer,
body.modernlogin-updatepassword footer,
body.modernlogin-updatepassword .breadcrumb,
body.modernlogin-updatepassword nav[aria-label="breadcrumb"],
body.modernlogin-updatepassword #goto-menu,
body.modernlogin-updatepassword .modal,
body.modernlogin-updatepassword .modal-backdrop {
  display: none !important;
}

body.modernlogin-updatepassword .page-wrapper,
body.modernlogin-updatepassword .page,
body.modernlogin-updatepassword .page-body {
  margin: 0 !important;
  padding: 0 !important;
  min-height: 100vh !important;
  background: #f5f6f8 !important;
}

body.modernlogin-updatepassword {
  background: #f5f6f8 !important;
}

body.modernlogin-updatepassword .page-body {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.modernlogin-updatepassword .container-tight {
  max-width: 30rem !important;
  width: 100% !important;
  padding: 1.5rem !important;
}

body.modernlogin-updatepassword .main-content-card,
body.modernlogin-updatepassword .card {
  border-radius: 14px !important;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.08) !important;
  border: 1px solid #e9ecef !important;
}

body.modernlogin-updatepassword .card-body {
  padding: 2rem !important;
}

body.modernlogin-updatepassword .card-body::before {
  content: '';
  display: block;
  width: 160px;
  height: 50px;
  margin: 0 auto 1.5rem;
  background: url('/plugins/modernlogin/pedeai-logo.webp') no-repeat center / contain;
}

body.modernlogin-updatepassword h2,
body.modernlogin-updatepassword .card-title {
  text-align: center !important;
  font-weight: 700 !important;
  color: #333 !important;
  margin-bottom: 1.25rem !important;
}

body.modernlogin-updatepassword label.col-form-label {
  font-weight: 600 !important;
  color: #333 !important;
}

body.modernlogin-updatepassword .form-control {
  border-radius: 8px !important;
  padding: 0.6rem 0.75rem !important;
}

body.modernlogin-updatepassword .form-control:focus {
  border-color: #00B334 !important;
  box-shadow: 0 0 0 .2rem rgba(0, 179, 52, .15) !important;
}

body.modernlogin-updatepassword .btn-primary {
  width: 100% !important;
  padding: 0.65rem 1rem !important;
  font-weight: 600 !important;
  border-radius: 8px !important;
  margin-top: 0.5rem !important;
}

body.modernlogin-updatepassword .modernlogin-pwd-error {
  color: #c00 !important;
  font-size: 0.85em !important;
  margin-top: 4px !important;
}

/* Barra de força de senha. */
.ml-strength-bar {
  width: 100%;
  height: 6px;
  background: #eef0f3;
  border-radius: 999px;
  overflow: hidden;
}
.ml-strength-bar-fill {
  height: 100%;
  width: 0%;
  border-radius: 999px;
  transition: width .2s ease, background-color .2s ease;
  background: transparent;
}
.ml-strength-bar-fill.empty { background: transparent; }
.ml-strength-bar-fill.bad   { background: #e03131; }
.ml-strength-bar-fill.mid   { background: #f59f00; }
.ml-strength-bar-fill.good  { background: #00B334; }

.ml-strength-label {
  font-size: 0.8rem;
  margin-top: 4px;
  color: #6c757d;
  text-align: right;
}

/* Checklist de regras. */
.ml-rules {
  list-style: none;
  padding: 0;
  margin: 0 0 0.75rem 0;
  font-size: 0.85rem;
}
.ml-rules li {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #6c757d;
  padding: 2px 0;
}
.ml-rules li .ml-rule-dot {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #e9ecef;
  border: 1.5px solid #ced4da;
  flex-shrink: 0;
  position: relative;
}
.ml-rules li.ok { color: #00B334; }
.ml-rules li.ok .ml-rule-dot {
  background: #00B334;
  border-color: #00B334;
}
.ml-rules li.ok .ml-rule-dot::after {
  content: '';
  position: absolute;
  left: 3px;
  top: 0px;
  width: 4px;
  height: 8px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.ml-rules li.ko { color: #e03131; }
.ml-rules li.ko .ml-rule-dot {
  background: #fff;
  border-color: #e03131;
}

/* Esconde toasts/avisos com o aviso de troca obrigatória aqui dentro
 * para não duplicar mensagem visual (a página já é auto-explicativa). */
body.modernlogin-updatepassword .toast-container {
  display: none !important;
}

