:root{--cor-primaria: #4F46E5;--cor-primaria-hover: #4338CA;--cor-primaria-clara: #EEF2FF;--cor-fundo: #F8FAFC;--cor-card: #FFFFFF;--cor-borda: #E2E8F0;--cor-texto-principal: #1E293B;--cor-texto-secundario: #64748B;--cor-texto-claro: #94A3B8;--cor-erro: #EF4444;--cor-erro-fundo: #FEF2F2;--cor-sucesso: #22C55E;--cor-aviso: #F59E0B;--sombra-card: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--sombra-elevada: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--raio-sm: 6px;--raio-md: 10px;--raio-lg: 16px;--transicao: .2s ease;--fonte: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif}[data-tema=escuro]{--cor-primaria: #818CF8;--cor-primaria-hover: #6366F1;--cor-primaria-clara: #1E1B4B;--cor-fundo: #0F172A;--cor-card: #1E293B;--cor-borda: #334155;--cor-texto-principal: #F1F5F9;--cor-texto-secundario: #94A3B8;--cor-texto-claro: #475569;--cor-erro: #F87171;--cor-erro-fundo: #450A0A;--cor-sucesso: #4ADE80;--cor-aviso: #FCD34D;--sombra-card: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--sombra-elevada: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -1px rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--fonte);font-size:16px;line-height:1.5;color:var(--cor-texto-principal);background-color:var(--cor-fundo);-webkit-font-smoothing:antialiased;transition:background-color .2s ease,color .2s ease}a{color:var(--cor-primaria);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}ul,ol{list-style:none}button,input,select,textarea{font-family:inherit;font-size:inherit}.carregando-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--cor-fundo);gap:1rem}.carregando-spinner{width:48px;height:48px;border:4px solid var(--cor-borda);border-top-color:var(--cor-primaria);border-radius:50%;animation:girar .8s linear infinite}.carregando-texto{color:var(--cor-texto-secundario);font-size:.875rem}.botao-tema{width:36px;height:36px;border-radius:var(--raio-md);border:1px solid var(--cor-borda);background:transparent;color:var(--cor-texto-secundario);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background var(--transicao),color var(--transicao),border-color var(--transicao)}.botao-tema:hover{background:var(--cor-primaria-clara);color:var(--cor-primaria);border-color:var(--cor-primaria)}.botao-tema svg{width:18px;height:18px}.login-botao-tema{position:absolute;top:1rem;right:1rem;z-index:10}.login-pagina{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,#eef2ff,#f8fafc,#e0e7ff)}[data-tema=escuro] .login-pagina{background:linear-gradient(135deg,#1e1b4b,#0f172a,#1e1b4b)}.login-card{width:100%;max-width:420px;background:var(--cor-card);border-radius:var(--raio-lg);box-shadow:0 8px 24px #4f46e51f,var(--sombra-elevada);padding:2.5rem 2rem;border:1px solid var(--cor-borda)}.login-cabecalho{text-align:center;margin-bottom:2rem}.login-logo{display:inline-flex;margin-bottom:1rem}.login-logo svg{width:52px;height:52px;filter:drop-shadow(0 4px 8px rgba(79,70,229,.3))}.login-logo img{max-width:180px;height:auto;filter:drop-shadow(0 4px 8px rgba(79,70,229,.3))}.login-titulo{font-size:1.625rem;font-weight:700;color:var(--cor-texto-principal);letter-spacing:-.02em;margin-bottom:.25rem}.login-subtitulo{font-size:.875rem;color:var(--cor-texto-secundario)}.login-formulario{display:flex;flex-direction:column;gap:1.25rem}.campo-input::placeholder{color:var(--cor-texto-claro)}.campo-input:disabled{background-color:var(--cor-fundo);cursor:not-allowed;opacity:.7}.login-erro{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background-color:var(--cor-erro-fundo);border:1px solid #FECACA;border-radius:var(--raio-md);color:var(--cor-erro);font-size:.875rem;font-weight:500;animation:aparecer .2s ease}.login-erro svg{width:18px;height:18px;flex-shrink:0}.btn-entrar{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1rem;background-color:var(--cor-primaria);color:#fff;font-size:.9375rem;font-weight:600;border:none;border-radius:var(--raio-md);cursor:pointer;transition:background-color var(--transicao),transform var(--transicao),box-shadow var(--transicao);margin-top:.25rem}.btn-entrar:hover:not(:disabled){background-color:var(--cor-primaria-hover);box-shadow:0 4px 12px #4f46e559;transform:translateY(-1px)}.btn-entrar:active:not(:disabled){transform:translateY(0)}.btn-entrar:disabled{opacity:.7;cursor:not-allowed}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:girar .7s linear infinite;flex-shrink:0}.login-rodape{margin-top:1.25rem;text-align:center;padding-top:1.25rem;border-top:1px solid var(--cor-borda)}.login-rodape p{font-size:.875rem;color:var(--cor-texto-secundario)}.login-rodape a{color:var(--cor-primaria);font-weight:500}@media (max-width: 480px){.login-card{padding:2rem 1.5rem}.login-titulo{font-size:1.375rem}}.card-unidade{display:flex;flex-direction:column;gap:.5rem;width:100%;padding:1.25rem;background:var(--cor-card);border:1.5px solid var(--cor-borda);border-radius:var(--raio-lg);text-align:left;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease,background-color .2s ease;box-shadow:var(--sombra-card)}.card-unidade:hover{box-shadow:var(--sombra-elevada);transform:translateY(-2px);border-color:#cbd5e1}.card-unidade:active{transform:translateY(0)}.card-unidade--alerta{background-color:#fef2f2;border-color:#ef4444;animation:pulsar-alerta 2.5s ease-in-out infinite}.card-unidade--alerta:hover{border-color:#dc2626;background-color:#fee2e2}[data-tema=escuro] .card-unidade--alerta{background-color:#2d0a0a;border-color:#ef4444}[data-tema=escuro] .card-unidade--alerta:hover{background-color:#3d1010;border-color:#dc2626}[data-tema=escuro] .card-unidade--alerta .card-unidade-rodape{border-top-color:#7f1d1d}[data-tema=escuro] .card-unidade-status--alerta,[data-tema=escuro] .card-unidade--alerta .card-unidade-acao{color:#f87171}[data-tema=escuro] .card-unidade--alerta:hover .card-unidade-rodape svg{color:#f87171}@keyframes pulsar-alerta{0%,to{box-shadow:0 0 #ef444440}50%{box-shadow:0 0 0 6px #ef444400}}.card-unidade-topo{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.card-unidade-nome{font-size:1rem;font-weight:600;color:var(--cor-texto-principal);line-height:1.3}.card-unidade-indicador{display:flex;align-items:center;flex-shrink:0}.card-unidade-ponto{display:inline-block;width:10px;height:10px;border-radius:50%;background-color:#ef4444;animation:piscar 1.4s ease-in-out infinite}@keyframes piscar{0%,to{opacity:1}50%{opacity:.25}}.card-unidade-status{font-size:.8125rem;font-weight:500;color:var(--cor-texto-secundario);margin:0}.card-unidade-status--alerta{color:#dc2626;font-weight:600}.card-unidade-rodape{display:flex;align-items:center;justify-content:space-between;margin-top:.25rem;padding-top:.75rem;border-top:1px solid var(--cor-borda)}.card-unidade--alerta .card-unidade-rodape{border-top-color:#fecaca}.card-unidade-acao{font-size:.8125rem;font-weight:500;color:var(--cor-primaria)}.card-unidade--alerta .card-unidade-acao{color:#dc2626}.card-unidade-rodape svg{width:14px;height:14px;color:var(--cor-texto-claro);transition:transform .15s ease}.card-unidade:hover .card-unidade-rodape svg{transform:translate(3px);color:var(--cor-primaria)}.card-unidade--alerta:hover .card-unidade-rodape svg{color:#dc2626}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:999;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-caixa{background:#fff;border-radius:var(--raio-lg);box-shadow:0 20px 60px #0003;width:100%;max-width:480px;animation:subirModal .2s ease;overflow:hidden}@keyframes subirModal{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-cabecalho{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--cor-borda)}.modal-titulo{font-size:1.0625rem;font-weight:700;color:var(--cor-texto-principal)}.modal-fechar{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--raio-sm);color:var(--cor-texto-secundario);cursor:pointer;transition:background var(--transicao),color var(--transicao)}.modal-fechar:hover{background:var(--cor-fundo);color:var(--cor-texto-principal)}.modal-fechar svg{width:18px;height:18px}.modal-corpo{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.modal-corpo--centro{align-items:center;padding:2.5rem 1.5rem}.modal-descricao{font-size:.9375rem;color:var(--cor-texto-secundario);line-height:1.6;margin:0}.campo-dica{font-size:.8125rem;color:var(--cor-texto-claro);margin:.25rem 0 0}.modal-spinner{width:44px;height:44px;border:3px solid var(--cor-borda);border-top-color:var(--cor-primaria);border-radius:50%;animation:girar .8s linear infinite;margin-bottom:.5rem}.sucesso-icone{display:flex;justify-content:center}.sucesso-icone svg{width:52px;height:52px;color:#22c55e}.sucesso-titulo{font-size:1.0625rem;font-weight:700;color:var(--cor-texto-principal);text-align:center;margin:0}.erro-icone{display:flex;justify-content:center}.erro-icone svg{width:52px;height:52px;color:var(--cor-erro)}.erro-titulo{font-size:1.0625rem;font-weight:700;color:var(--cor-texto-principal);text-align:center;margin:0}.convite-campo-grupo{display:flex;flex-direction:column;gap:.375rem}.convite-campo{display:flex;align-items:center;gap:.625rem;padding:.625rem .875rem;background:var(--cor-fundo);border:1.5px solid var(--cor-borda);border-radius:var(--raio-md)}.convite-campo--link{align-items:flex-start;flex-wrap:wrap;gap:.5rem}.convite-codigo{font-family:Courier New,monospace;font-size:.9375rem;font-weight:700;color:var(--cor-primaria);letter-spacing:.05em;flex:1}.convite-link{font-size:.8rem;color:var(--cor-texto-secundario);word-break:break-all;flex:1;line-height:1.5}.btn-copiar{flex-shrink:0;padding:.375rem .75rem;background:var(--cor-card);border:1.5px solid var(--cor-borda);border-radius:var(--raio-sm);font-size:.8125rem;font-weight:600;color:var(--cor-texto-principal);cursor:pointer;transition:all var(--transicao);white-space:nowrap}.btn-copiar:hover{border-color:var(--cor-primaria);color:var(--cor-primaria)}.btn-copiar--copiado{border-color:#22c55e;color:#16a34a;background:#f0fdf4}.modal-rodape{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.25rem}.btn-primario{padding:.625rem 1.25rem;background:var(--cor-primaria);color:#fff;font-size:.9375rem;font-weight:600;border:none;border-radius:var(--raio-md);cursor:pointer;transition:background var(--transicao),box-shadow var(--transicao)}.btn-primario:hover{background:var(--cor-primaria-hover);box-shadow:0 4px 12px #4f46e54d}.btn-secundario{padding:.625rem 1.25rem;background:transparent;color:var(--cor-texto-secundario);font-size:.9375rem;font-weight:500;border:1.5px solid var(--cor-borda);border-radius:var(--raio-md);cursor:pointer;transition:all var(--transicao)}.btn-secundario:hover{border-color:#94a3b8;color:var(--cor-texto-principal)}@media (max-width: 480px){.modal-caixa{max-width:100%}}[data-tema=escuro] .modal-caixa{background:var(--cor-card);box-shadow:0 20px 60px #00000080}[data-tema=escuro] .btn-copiar{background:var(--cor-fundo);border-color:var(--cor-borda);color:var(--cor-texto-principal)}[data-tema=escuro] .btn-copiar--copiado{background:#052e16;border-color:#16a34a;color:#4ade80}[data-tema=escuro] .btn-secundario:hover{border-color:var(--cor-borda);color:var(--cor-texto-principal)}.menu-usuario-container{position:relative;display:flex;align-items:center;gap:.625rem}.usuario-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:.875rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border:2px solid transparent;cursor:pointer;padding:0;transition:border-color var(--transicao),box-shadow var(--transicao)}.usuario-avatar:hover,.usuario-avatar--ativo{border-color:var(--cor-primaria);box-shadow:0 0 0 3px #4f46e526}.menu-dropdown{position:absolute;top:calc(100% + 10px);right:0;min-width:220px;background:var(--cor-card);border:1px solid var(--cor-borda);border-radius:var(--raio-lg);box-shadow:0 8px 24px #0000001f;z-index:200;animation:aparecer-dropdown .15s ease;overflow:hidden}@keyframes aparecer-dropdown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.menu-dropdown-info{padding:.875rem 1rem}.menu-dropdown-nome{font-size:.875rem;font-weight:600;color:var(--cor-texto-principal);margin:0 0 .125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-dropdown-email{font-size:.8125rem;color:var(--cor-texto-secundario);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-dropdown-divisor{height:1px;background:var(--cor-borda)}.menu-dropdown-opcao{width:100%;display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;background:transparent;border:none;font-size:.875rem;font-weight:500;color:var(--cor-texto-principal);cursor:pointer;transition:background var(--transicao);text-align:left}.menu-dropdown-opcao:hover{background:var(--cor-fundo)}.menu-dropdown-opcao svg{width:16px;height:16px;color:var(--cor-texto-secundario);flex-shrink:0}.menu-dropdown-opcao--sair{color:#dc2626}.menu-dropdown-opcao--sair svg{color:#dc2626}.menu-dropdown-opcao--sair:hover{background:#fef2f2}@media (max-width: 640px){.usuario-nome{display:none}.menu-dropdown{right:-8px}}.dashboard-pagina{min-height:100vh;display:flex;flex-direction:column;background-color:var(--cor-fundo)}.dashboard-header{background-color:var(--cor-card);border-bottom:1px solid var(--cor-borda);padding:0 1.5rem;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 4px #0000000f}.header-marca{display:flex;align-items:center}.header-nome-sistema{font-size:1.125rem;font-weight:700;color:var(--cor-texto-principal);letter-spacing:-.01em}.header-usuario{display:flex;align-items:center;gap:.75rem}.usuario-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:.875rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.usuario-avatar-foto{width:100%;height:100%;object-fit:cover}.usuario-nome{font-size:.875rem;font-weight:500;color:var(--cor-texto-principal)}.dashboard-conteudo{flex:1;padding:2rem 1.5rem;max-width:1200px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:1.75rem}.dashboard-saudacao{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.saudacao-titulo{font-size:1.5rem;font-weight:700;color:var(--cor-texto-principal);letter-spacing:-.02em;margin-bottom:.25rem}.saudacao-subtitulo{font-size:.9375rem;color:var(--cor-texto-secundario)}.saudacao-badge-alerta{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fef2f2;border:1.5px solid #FECACA;border-radius:999px;color:#dc2626;font-size:.875rem;font-weight:600;animation:aparecer .3s ease}.saudacao-badge-ponto{display:inline-block;width:8px;height:8px;border-radius:50%;background:#ef4444;animation:piscar-rapido 1s ease-in-out infinite}@keyframes piscar-rapido{0%,to{opacity:1}50%{opacity:.3}}@keyframes aparecer{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.unidades-secao{display:flex;flex-direction:column;gap:1.25rem}.unidades-cabecalho{display:flex;flex-direction:column;gap:.25rem}.unidades-titulo-grupo{display:flex;align-items:center;gap:.625rem}.unidades-titulo{font-size:1.125rem;font-weight:700;color:var(--cor-texto-principal)}.unidades-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 .5rem;background:var(--cor-primaria-clara);color:var(--cor-primaria);font-size:.75rem;font-weight:700;border-radius:999px}.polling-indicador{display:inline-block;width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulsar-verde 2s ease-in-out infinite}@keyframes pulsar-verde{0%,to{opacity:1;box-shadow:0 0 #22c55e4d}50%{opacity:.7;box-shadow:0 0 0 4px #22c55e00}}.unidades-subtitulo{font-size:.8125rem;color:var(--cor-texto-claro)}.unidades-carregando{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem;color:var(--cor-texto-secundario);font-size:.875rem}.spinner-unidades{width:40px;height:40px;border:3px solid var(--cor-borda);border-top-color:var(--cor-primaria);border-radius:50%;animation:girar .8s linear infinite}.unidades-erro{display:flex;align-items:flex-start;gap:.875rem;padding:1.25rem;background:var(--cor-erro-fundo);border:1.5px solid #FECACA;border-radius:var(--raio-lg);color:#991b1b}.unidades-erro svg{width:20px;height:20px;flex-shrink:0;margin-top:1px}.unidades-erro strong{display:block;font-size:.9375rem;margin-bottom:.25rem}.unidades-erro p{font-size:.875rem;margin:0;opacity:.9}.unidades-erro-retry{font-size:.8125rem!important;opacity:.7!important;margin-top:.25rem!important;font-style:italic}.unidades-vazio{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem;background:var(--cor-card);border:2px dashed var(--cor-borda);border-radius:var(--raio-lg);color:var(--cor-texto-claro)}.unidades-vazio svg{width:48px;height:48px}.unidades-vazio-texto{font-size:.9375rem;font-weight:500;margin:0}.unidades-grade{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.grafico-secao{background:var(--cor-card);border:1px solid var(--cor-borda);border-radius:var(--raio-lg);box-shadow:var(--sombra-card);padding:1.25rem 1.5rem}.grafico-cabecalho{margin-bottom:1.25rem}.grafico-titulo{font-size:1.125rem;font-weight:700;color:var(--cor-texto-principal);margin:0}.grafico-corpo{display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap}.grafico-svg{width:140px;height:140px;flex-shrink:0}.grafico-num{font-size:26px;font-weight:700;fill:var(--cor-texto-principal);font-family:inherit}.grafico-sub{font-size:11px;fill:var(--cor-texto-claro);font-family:inherit}.grafico-legenda{display:flex;flex-direction:column;gap:1.125rem}.legenda-item{display:flex;align-items:center;gap:.75rem}.legenda-bolinha{width:13px;height:13px;border-radius:50%;flex-shrink:0}.legenda-bolinha--ok{background:#22c55e}.legenda-bolinha--alerta{background:#ef4444}.legenda-textos{display:flex;flex-direction:column;gap:.125rem}.legenda-valor{font-size:1.375rem;font-weight:700;color:var(--cor-texto-principal);line-height:1}.legenda-rotulo{font-size:.8125rem;color:var(--cor-texto-secundario)}[data-tema=escuro] .saudacao-badge-alerta{background:#450a0a;border-color:#7f1d1d;color:#fca5a5}[data-tema=escuro] .unidades-erro{border-color:#7f1d1d;color:#fca5a5}@media (max-width: 640px){.dashboard-header{padding:0 1rem}.usuario-nome{display:none}.dashboard-conteudo{padding:1.25rem 1rem}.saudacao-titulo{font-size:1.25rem}.unidades-grade{grid-template-columns:1fr}.dashboard-saudacao{flex-direction:column;align-items:flex-start}}.card-acesso{background:var(--cor-card);border-radius:var(--raio-lg);border:1.5px solid var(--cor-borda);box-shadow:var(--sombra-card);overflow:hidden;transition:transform var(--transicao),box-shadow var(--transicao)}.card-acesso--clicavel{cursor:pointer}.card-acesso--clicavel:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.card-acesso:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001a}.card-acesso--alerta{border-color:#ef4444;box-shadow:0 2px 12px #ef44442e;animation:pulsar-card 2.5s ease-in-out infinite}@keyframes pulsar-card{0%,to{box-shadow:0 2px 12px #ef44442e}50%{box-shadow:0 2px 22px #ef44446b,0 0 0 3px #ef444414}}.card-acesso-cabecalho{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.125rem;background:var(--cor-fundo);border-bottom:1px solid var(--cor-borda)}.card-acesso-icone-tipo{width:16px;height:16px;color:var(--cor-primaria);flex-shrink:0}.card-acesso-nome{font-size:.9375rem;font-weight:700;letter-spacing:.04em;color:var(--cor-texto-principal);flex:1}.card-acesso-tipo-badge{font-size:.6875rem;font-weight:700;letter-spacing:.07em;padding:.2rem .5rem;border-radius:var(--raio-sm);flex-shrink:0}.tipo-badge--entrada{background:#eef2ff;color:#4338ca}.tipo-badge--saida{background:#f0fdf4;color:#15803d}.card-acesso-totem{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.125rem;border-bottom:1px solid var(--cor-borda)}.card-acesso-status{display:flex;align-items:center;gap:.5rem}.card-acesso-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dot--online{background:#22c55e;box-shadow:0 0 0 3px #22c55e38;animation:piscar-verde 2s ease-in-out infinite}@keyframes piscar-verde{0%,to{box-shadow:0 0 0 3px #22c55e38}50%{box-shadow:0 0 0 5px #22c55e0f}}.dot--offline{background:#ef4444}.card-acesso-status-texto{font-size:.8rem;font-weight:700;letter-spacing:.07em}.status--online .card-acesso-status-texto{color:#16a34a}.status--offline .card-acesso-status-texto{color:#dc2626}.card-acesso-contato{display:flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--cor-texto-claro);font-variant-numeric:tabular-nums}.card-acesso-contato svg{width:13px;height:13px;flex-shrink:0}.card-acesso-cancela{display:flex;align-items:flex-start;gap:.625rem;padding:.75rem 1.125rem}.card-acesso-cancela-icone{width:16px;height:16px;flex-shrink:0;margin-top:1px}.card-acesso-cancela-textos{display:flex;flex-direction:column;gap:.125rem}.card-acesso-cancela-rotulo{font-size:.8rem;font-weight:700;letter-spacing:.04em}.card-acesso-cancela-msg{font-size:.75rem;line-height:1.3}.cancela--ok{background:#22c55e0f;color:#15803d}.cancela--ok .card-acesso-cancela-msg{color:#16a34a;opacity:.75}.cancela--alerta{background:#ef444414;color:#b91c1c}.cancela--alerta .card-acesso-cancela-msg{color:#dc2626;opacity:.8}[data-tema=escuro] .tipo-badge--entrada{background:#1e1b4b;color:#a5b4fc}[data-tema=escuro] .tipo-badge--saida{background:#052e16;color:#4ade80}[data-tema=escuro] .status--online .card-acesso-status-texto{color:#4ade80}[data-tema=escuro] .status--offline .card-acesso-status-texto{color:#f87171}[data-tema=escuro] .cancela--ok{background:#22c55e1a;color:#4ade80}[data-tema=escuro] .cancela--ok .card-acesso-cancela-msg{color:#4ade80;opacity:1}[data-tema=escuro] .cancela--alerta{background:#ef44441f;color:#f87171}[data-tema=escuro] .cancela--alerta .card-acesso-cancela-msg{color:#f87171;opacity:1}.unidade-pagina{min-height:100vh;display:flex;flex-direction:column;background:var(--cor-fundo)}.unidade-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:1rem;padding:0 1.5rem;height:60px;background:var(--cor-card);border-bottom:1px solid var(--cor-borda);box-shadow:0 1px 6px #0000000f}.btn-header-voltar{display:flex;align-items:center;gap:.4rem;padding:.5rem .875rem;background:transparent;border:1.5px solid var(--cor-borda);border-radius:var(--raio-md);font-size:.875rem;font-weight:500;color:var(--cor-texto-secundario);cursor:pointer;transition:border-color var(--transicao),color var(--transicao),background var(--transicao);flex-shrink:0;white-space:nowrap}.btn-header-voltar:hover{border-color:var(--cor-primaria);color:var(--cor-primaria);background:var(--cor-primaria-clara)}.btn-header-voltar svg{width:16px;height:16px}.unidade-header-info{display:flex;flex-direction:column;flex:1;min-width:0}.unidade-header-codigo{font-size:.6875rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--cor-primaria);line-height:1.1}.unidade-header-nome{font-size:1rem;font-weight:600;color:var(--cor-texto-principal);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unidade-header-alerta{display:flex;align-items:center;gap:.4rem;padding:.375rem .75rem;background:var(--cor-erro-fundo);border:1px solid #FECACA;border-radius:var(--raio-md);font-size:.8125rem;font-weight:600;color:#dc2626;flex-shrink:0;white-space:nowrap}.header-alerta-ponto{width:8px;height:8px;border-radius:50%;background:var(--cor-erro);animation:piscar-ponto 1.4s ease-in-out infinite}@keyframes piscar-ponto{0%,to{opacity:1}50%{opacity:.25}}.unidade-conteudo{flex:1;padding:1.75rem 1.5rem 3rem;max-width:1200px;width:100%;margin:0 auto}.unidade-carregando{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:5rem 2rem;color:var(--cor-texto-secundario);font-size:.9375rem}.unidade-spinner{width:40px;height:40px;border:3px solid var(--cor-borda);border-top-color:var(--cor-primaria);border-radius:50%;animation:girar-spinner .8s linear infinite}@keyframes girar-spinner{to{transform:rotate(360deg)}}.unidade-erro{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;background:var(--cor-erro-fundo);border:1px solid #FECACA;border-radius:var(--raio-md);color:var(--cor-erro);font-size:.9rem}.unidade-erro svg{width:20px;height:20px;flex-shrink:0;margin-top:1px}.unidade-erro strong{display:block;font-weight:600;margin-bottom:.25rem}.unidade-erro p{color:#991b1b;font-size:.875rem}.acessos-cabecalho{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.acessos-titulo{font-size:1.125rem;font-weight:700;color:var(--cor-texto-principal)}.acessos-badge{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:26px;padding:0 .5rem;background:var(--cor-primaria);color:#fff;font-size:.75rem;font-weight:700;border-radius:13px}.acessos-grade{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.acessos-vazio{display:flex;flex-direction:column;align-items:center;gap:.875rem;padding:4rem 2rem;color:var(--cor-texto-claro);text-align:center}.acessos-vazio svg{width:52px;height:52px;opacity:.35}.acessos-vazio p{font-size:.9375rem}.unidade-rodape-status{display:flex;align-items:center;gap:.5rem;margin-top:2rem;padding-top:1.25rem;border-top:1px solid var(--cor-borda);font-size:.8125rem;color:var(--cor-texto-claro)}.unidade-rodape-status svg{width:15px;height:15px;flex-shrink:0}@media (max-width: 640px){.unidade-header{padding:0 1rem;gap:.75rem}.btn-header-voltar span{display:none}.btn-header-voltar{padding:.5rem .625rem}.unidade-conteudo{padding:1.25rem 1rem 2.5rem}.acessos-grade{grid-template-columns:1fr}.unidade-header-nome{font-size:.9rem}}[data-tema=escuro] .unidade-header-alerta{background:#450a0a;border-color:#7f1d1d;color:#f87171}@media (max-width: 400px){.unidade-header-alerta span{display:none}.unidade-header-alerta{padding:.5rem}}.historico-pagina{min-height:100vh;background-color:#f4f6f9;display:flex;flex-direction:column}.historico-header{background-color:#1e293b;color:#fff;padding:12px 20px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:10;box-shadow:0 2px 8px #0003}.btn-header-voltar{display:flex;align-items:center;gap:6px;background:none;border:none;color:#94a3b8;cursor:pointer;font-size:.875rem;padding:6px 10px;border-radius:6px;transition:color .15s,background .15s;flex-shrink:0}.btn-header-voltar:hover{color:#fff;background:#ffffff14}.btn-header-voltar svg{width:18px;height:18px}.historico-header-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.historico-header-unidade{font-size:.75rem;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.historico-header-acesso{font-size:1rem;font-weight:600;color:#f1f5f9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.historico-conteudo{flex:1;padding:20px 16px;max-width:760px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:20px}.historico-filtro{background:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 1px 4px #00000014}.filtro-campos{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.filtro-label{display:flex;flex-direction:column;gap:4px;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.filtro-input{border:1px solid #cbd5e1;border-radius:8px;padding:8px 12px;font-size:.875rem;color:#1e293b;background:#f8fafc;outline:none;transition:border-color .15s;min-width:0}.filtro-input:focus{border-color:#3b82f6;background:#fff}.filtro-input[type=date]::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer}.filtro-input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.filtro-separador{font-size:.875rem;color:#94a3b8;padding-bottom:10px}.filtro-btn{padding:9px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap}.filtro-btn:hover:not(:disabled){background:#1d4ed8}.filtro-btn:disabled{opacity:.6;cursor:not-allowed}.filtro-erro{margin-top:8px;font-size:.8125rem;color:#dc2626}.historico-carregando{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 0;color:#64748b}.historico-spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.historico-erro{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;padding:16px 20px;display:flex;align-items:flex-start;gap:12px;color:#991b1b}.historico-erro svg{width:20px;height:20px;flex-shrink:0;margin-top:2px}.historico-erro strong{display:block;margin-bottom:4px}.historico-lista-secao{display:flex;flex-direction:column;gap:12px}.historico-lista-cabecalho{display:flex;align-items:center;gap:10px}.historico-lista-titulo{font-size:1rem;font-weight:700;color:#1e293b;margin:0}.historico-lista-badge{background:#e2e8f0;color:#475569;font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:999px}.historico-lista{display:flex;flex-direction:column;gap:10px}.historico-ocorrencia{background:#fff;border-radius:10px;padding:14px 16px;border-left:4px solid #cbd5e1;box-shadow:0 1px 3px #00000012;display:flex;flex-direction:column;gap:8px}.ocorrencia--aberta{border-left-color:#dc2626;background:#fff5f5}.ocorrencia--offline{border-left-color:#475569}.ocorrencia--barreira-aberta{border-left-color:#f97316}.ocorrencia--barreira-desligada{border-left-color:#f59e0b}.ocorrencia-topo{display:flex;align-items:center;justify-content:space-between;gap:8px}.ocorrencia-tipo{font-size:.9375rem;font-weight:700;color:#1e293b}.ocorrencia-badge-aberta{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#dc2626;background:#fee2e2;padding:2px 8px;border-radius:999px}.ocorrencia-periodo{display:flex;align-items:flex-start;gap:8px;color:#475569;font-size:.8125rem}.ocorrencia-periodo svg{width:16px;height:16px;flex-shrink:0;margin-top:1px;color:#94a3b8}.ocorrencia-datas{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.ocorrencia-seta{color:#94a3b8;font-size:.75rem}.ocorrencia-veiculos{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:#475569}.ocorrencia-veiculos svg{width:16px;height:16px;color:#94a3b8}.historico-grafico{background:#fff;border-radius:12px;padding:16px 12px 8px;box-shadow:0 1px 4px #00000014}.historico-tipo-filtro{display:flex;flex-wrap:wrap;gap:8px}.tipo-chip{padding:5px 14px;border-radius:999px;border:1.5px solid #cbd5e1;background:#fff;color:#475569;font-size:.8125rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s,color .15s;white-space:nowrap}.tipo-chip:hover{border-color:#3b82f6;color:#1e293b}.tipo-chip--ativo{background:#2563eb;border-color:#2563eb;color:#fff}.tipo-chip--ativo:hover{background:#1d4ed8;border-color:#1d4ed8;color:#fff}.historico-lista-badge-total{font-weight:400;color:#94a3b8}.historico-vazio{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 0;color:#94a3b8;text-align:center}.historico-vazio svg{width:48px;height:48px;opacity:.4}[data-tema=escuro] .historico-pagina{background-color:var(--cor-fundo)}[data-tema=escuro] .historico-filtro{background:var(--cor-card);box-shadow:var(--sombra-card)}[data-tema=escuro] .filtro-label{color:var(--cor-texto-secundario)}[data-tema=escuro] .filtro-input{color:var(--cor-texto-principal);background:var(--cor-fundo);border-color:var(--cor-borda)}[data-tema=escuro] .filtro-input:focus{background:var(--cor-card);border-color:var(--cor-primaria)}[data-tema=escuro] .filtro-separador{color:var(--cor-texto-claro)}[data-tema=escuro] .historico-carregando{color:var(--cor-texto-secundario)}[data-tema=escuro] .historico-spinner{border-color:var(--cor-borda);border-top-color:var(--cor-primaria)}[data-tema=escuro] .historico-erro{background:#450a0a;border-color:#7f1d1d;color:#f87171}[data-tema=escuro] .historico-grafico{background:var(--cor-card);box-shadow:var(--sombra-card)}[data-tema=escuro] .historico-lista-titulo{color:var(--cor-texto-principal)}[data-tema=escuro] .historico-lista-badge{background:var(--cor-borda);color:var(--cor-texto-secundario)}[data-tema=escuro] .historico-lista-badge-total{color:var(--cor-texto-claro)}[data-tema=escuro] .tipo-chip{border-color:var(--cor-borda);background:var(--cor-card);color:var(--cor-texto-secundario)}[data-tema=escuro] .tipo-chip:hover{border-color:var(--cor-primaria);color:var(--cor-texto-principal)}[data-tema=escuro] .tipo-chip--ativo{background:var(--cor-primaria);border-color:var(--cor-primaria);color:#fff}[data-tema=escuro] .tipo-chip--ativo:hover{background:var(--cor-primaria-hover);border-color:var(--cor-primaria-hover)}[data-tema=escuro] .historico-ocorrencia{background:var(--cor-card);border-left-color:var(--cor-borda);box-shadow:var(--sombra-card)}[data-tema=escuro] .ocorrencia--aberta{background:#2d0a0a;border-left-color:#ef4444}[data-tema=escuro] .ocorrencia--offline{border-left-color:#64748b}[data-tema=escuro] .ocorrencia--barreira-aberta{border-left-color:#f97316}[data-tema=escuro] .ocorrencia--barreira-desligada{border-left-color:#f59e0b}[data-tema=escuro] .ocorrencia-tipo{color:var(--cor-texto-principal)}[data-tema=escuro] .ocorrencia-badge-aberta{background:#450a0a;color:#f87171}[data-tema=escuro] .ocorrencia-periodo,[data-tema=escuro] .ocorrencia-veiculos{color:var(--cor-texto-secundario)}[data-tema=escuro] .historico-vazio{color:var(--cor-texto-claro)}.cadastro-pagina{position:relative;min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1.5rem 3rem;background:linear-gradient(135deg,#eef2ff,#f8fafc,#e0e7ff)}[data-tema=escuro] .cadastro-pagina{background:linear-gradient(135deg,#1e1b4b,#0f172a,#1e1b4b)}.cadastro-card{width:100%;max-width:560px;background:#fff;border-radius:var(--raio-lg);border:1px solid var(--cor-borda);box-shadow:0 8px 24px #4f46e51a,var(--sombra-elevada);overflow:hidden}.cadastro-cabecalho{padding:2rem 2rem 0;text-align:center}.cadastro-titulo{font-size:1.5rem;font-weight:700;color:var(--cor-texto-principal);letter-spacing:-.02em;margin-bottom:.25rem}.cadastro-subtitulo{font-size:.875rem;color:var(--cor-texto-secundario)}.cadastro-formulario{padding:1.5rem 2rem 0;display:flex;flex-direction:column;gap:1.5rem}.cadastro-secao{border:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.875rem}.cadastro-secao-titulo{font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--cor-texto-secundario);margin-bottom:.25rem}.opcional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--cor-texto-claro)}.campos-linha{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.campo-grupo{display:flex;flex-direction:column;gap:.375rem}.campo-label{font-size:.875rem;font-weight:500;color:var(--cor-texto-principal)}.campo-input{width:100%;padding:.625rem .875rem;border:1.5px solid var(--cor-borda);border-radius:var(--raio-md);font-size:.9375rem;color:var(--cor-texto-principal);background:#fff;outline:none;transition:border-color var(--transicao),box-shadow var(--transicao)}.campo-input:focus{border-color:var(--cor-primaria);box-shadow:0 0 0 3px #4f46e51f}.campo-input:disabled{background:var(--cor-fundo);opacity:.7;cursor:not-allowed}.campo-input--mono{font-family:Courier New,monospace;letter-spacing:.04em;font-size:.9rem}.campo-dica{font-size:.8125rem;color:var(--cor-texto-claro);margin:0}.campo-dica--ok{color:#16a34a;font-weight:500}.campo-senha-wrapper{position:relative}.campo-senha-wrapper .campo-input{padding-right:2.75rem}.campo-senha-toggle{position:absolute;right:.625rem;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;color:var(--cor-texto-claro);padding:.25rem;display:flex;align-items:center;transition:color var(--transicao)}.campo-senha-toggle:hover{color:var(--cor-texto-secundario)}.campo-senha-toggle svg{width:18px;height:18px}.campo-foto-input{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}.campo-foto-label{display:flex;align-items:center;gap:.625rem;padding:.625rem .875rem;border:1.5px dashed var(--cor-borda);border-radius:var(--raio-md);font-size:.875rem;color:var(--cor-texto-secundario);cursor:pointer;transition:border-color var(--transicao),background var(--transicao)}.campo-foto-label:hover{border-color:var(--cor-primaria);background:var(--cor-primaria-clara);color:var(--cor-primaria)}.campo-foto-label svg{width:18px;height:18px;flex-shrink:0}.cadastro-erro{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--cor-erro-fundo);border:1px solid #FECACA;border-radius:var(--raio-md);color:var(--cor-erro);font-size:.875rem;font-weight:500;animation:aparecer .2s ease}.cadastro-erro svg{width:18px;height:18px;flex-shrink:0}@keyframes aparecer{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.btn-cadastrar{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem;background:var(--cor-primaria);color:#fff;font-size:.9375rem;font-weight:600;border:none;border-radius:var(--raio-md);cursor:pointer;transition:background var(--transicao),transform var(--transicao),box-shadow var(--transicao)}.btn-cadastrar:hover:not(:disabled){background:var(--cor-primaria-hover);box-shadow:0 4px 12px #4f46e559;transform:translateY(-1px)}.btn-cadastrar:disabled{opacity:.7;cursor:not-allowed}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:girar .7s linear infinite}@keyframes girar{to{transform:rotate(360deg)}}.cadastro-rodape{padding:1.25rem 2rem 1.5rem;text-align:center;border-top:1px solid var(--cor-borda);margin-top:1.5rem}.cadastro-rodape p{font-size:.875rem;color:var(--cor-texto-secundario)}.cadastro-rodape a{color:var(--cor-primaria);font-weight:500}.cadastro-sucesso{padding:3rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.sucesso-check svg{width:64px;height:64px;color:#22c55e}.cadastro-sucesso h1{font-size:1.375rem;font-weight:700;color:var(--cor-texto-principal)}.cadastro-sucesso p{font-size:.9375rem;color:var(--cor-texto-secundario)}[data-tema=escuro] .cadastro-card{background:var(--cor-card);box-shadow:0 8px 24px #0006}[data-tema=escuro] .campo-input{background:var(--cor-fundo);color:var(--cor-texto-principal);border-color:var(--cor-borda)}[data-tema=escuro] .campo-input:focus{border-color:var(--cor-primaria)}[data-tema=escuro] .campo-input:disabled{background:var(--cor-card)}[data-tema=escuro] .cadastro-erro{background:#2d0a0a;border-color:#7f1d1d}[data-tema=escuro] .campo-dica--ok{color:#4ade80}@media (max-width: 480px){.cadastro-pagina{padding:1rem .75rem 2rem}.cadastro-formulario{padding:1.25rem 1.25rem 0}.cadastro-cabecalho{padding:1.5rem 1.25rem 0}.cadastro-rodape{padding:1rem 1.25rem 1.25rem}.campos-linha{grid-template-columns:1fr}}.nao-encontrada-pagina{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#eef2ff,#f8fafc,#e0e7ff)}.nao-encontrada-conteudo{text-align:center;max-width:480px}.nao-encontrada-codigo{font-size:clamp(6rem,20vw,9rem);font-weight:800;line-height:1;background:linear-gradient(135deg,#4f46e5,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem;letter-spacing:-.04em}.nao-encontrada-titulo{font-size:1.5rem;font-weight:700;color:var(--cor-texto-principal);margin-bottom:.75rem}.nao-encontrada-texto{font-size:1rem;color:var(--cor-texto-secundario);line-height:1.6;margin-bottom:2rem}.btn-voltar{display:inline-flex;align-items:center;padding:.75rem 1.5rem;background-color:var(--cor-primaria);color:#fff;font-size:.9375rem;font-weight:600;border:none;border-radius:var(--raio-md);cursor:pointer;transition:background-color var(--transicao),transform var(--transicao),box-shadow var(--transicao)}.btn-voltar:hover{background-color:var(--cor-primaria-hover);box-shadow:0 4px 12px #4f46e559;transform:translateY(-1px)}.btn-voltar:active{transform:translateY(0)}
