:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body{margin:0;padding:0;min-width:320px;width:100%;min-height:100vh;height:100%}#root{width:100%;min-height:100vh;height:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-page{width:100%;min-height:100vh;min-height:100dvh;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#0f0f14,#1a1a24,#0d0d12);padding:1rem;box-sizing:border-box}.login-card{width:100%;max-width:400px;background:#1a1a24d9;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:2.5rem;box-shadow:0 24px 48px #0006}.login-header{text-align:center;margin-bottom:2rem}.login-logo{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem}.logo-icon{font-size:2rem;filter:drop-shadow(0 0 8px rgba(255,200,50,.5))}.login-header h1{margin:0;font-size:1.75rem;font-weight:700;color:#fff;letter-spacing:-.02em}.login-subtitle{margin:0;font-size:.9rem;color:#ffffff80}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;font-weight:500;color:#fffc}.login-form input{padding:.75rem 1rem;border:1px solid rgba(255,255,255,.1);border-radius:10px;background:#ffffff0a;color:#fff;font-size:1rem;transition:border-color .2s,box-shadow .2s}.login-form input::placeholder{color:#ffffff4d}.login-form input:focus{outline:none;border-color:#ffc83280;box-shadow:0 0 0 3px #ffc8321a}.login-form input:disabled{opacity:.6;cursor:not-allowed}.login-error{padding:.75rem 1rem;background:#dc354526;border:1px solid rgba(220,53,69,.3);border-radius:10px;color:#f87171;font-size:.9rem}.login-btn{margin-top:.5rem;padding:.9rem 1.5rem;background:linear-gradient(135deg,#e6b800,#c99a00);border:none;border-radius:10px;color:#0f0f14;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .2s}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #e6b80059}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.8;cursor:not-allowed}.login-hint{margin:1.5rem 0 0;text-align:center;font-size:.8rem;color:#ffffff59}.alarm-popup-backdrop{position:fixed;inset:0;background:#0f172ad9;display:flex;align-items:center;justify-content:center;z-index:100}.alarm-popup-modal{width:min(420px,calc(100% - 2rem));max-height:min(400px,calc(100vh - 4rem));background:#0f172a;border:1px solid rgba(248,113,113,.4);border-radius:16px;box-shadow:0 24px 48px #00000080,0 0 0 1px #f8717126;overflow:hidden;display:flex;flex-direction:column}.alarm-popup-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.08);background:#f8717114}.alarm-popup-title{font-size:1.1rem;font-weight:700;color:#fca5a5}.alarm-popup-close{width:2rem;height:2rem;border:none;border-radius:8px;background:transparent;color:#ffffffb3;font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.alarm-popup-close:hover{background:#ffffff14;color:#fff}.alarm-popup-list{margin:0;padding:1rem 1.25rem;list-style:none;overflow:auto;flex:1}.alarm-popup-item{display:flex;flex-wrap:wrap;gap:.5rem;align-items:baseline;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:.9rem}.alarm-popup-item:last-child{border-bottom:none}.alarm-popup-sala{font-weight:600;color:#e6b800;min-width:3.5rem}.alarm-popup-message{color:#fefcf5}.alarm-popup-footer{padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.08)}.alarm-popup-btn{width:100%;padding:.65rem 1rem;border:none;border-radius:10px;background:linear-gradient(135deg,#e6b800,#c99a00);color:#0f0f14;font-size:.95rem;font-weight:600;cursor:pointer}.alarm-popup-btn:hover{filter:brightness(1.08)}.side-bar{width:240px;min-width:240px;height:100%;display:flex;flex-direction:column;background:#121218f2;border-right:1px solid rgba(255,255,255,.06)}.side-bar-brand{display:flex;align-items:center;gap:.5rem;padding:1.25rem 1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.06)}.side-bar-logo{font-size:1.5rem;filter:drop-shadow(0 0 6px rgba(255,200,50,.4))}.side-bar-title{font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:-.02em}.side-bar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.side-bar-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:10px;color:#ffffffa6;text-decoration:none;font-size:.95rem;font-weight:500;transition:color .2s,background .2s}.side-bar-link:hover{color:#ffffffe6;background:#ffffff0d}.side-bar-link--active{color:#e6b800;background:#e6b8001a}.side-bar-link--active:hover{color:#f0c414;background:#e6b80024}.side-bar-link-icon{font-size:1.15rem;line-height:1}.side-bar-link-icon-img{width:1.25rem;height:1.25rem;object-fit:contain;flex-shrink:0}.side-bar-link-icon-svg{width:1.25rem;height:1.25rem;flex-shrink:0}.side-bar-link-label{flex:1}.side-bar-footer{padding:1rem .75rem;border-top:1px solid rgba(255,255,255,.06)}.side-bar-logout{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:none;border-radius:10px;background:transparent;color:#fff9;font-size:.95rem;font-weight:500;cursor:pointer;transition:color .2s,background .2s}.side-bar-logout:hover{color:#f87171;background:#f871711a}.dashboard-page{width:100%;min-height:100vh;min-height:100dvh;height:100%;display:flex;background:linear-gradient(145deg,#0f0f14,#1a1a24);color:#fff;box-sizing:border-box}.dashboard-main{flex:1;overflow:auto;padding:2rem 1.5rem}.dashboard-content{display:flex;flex-direction:column;gap:1.5rem}.dashboard-content-title{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:#fff}.dashboard-content-desc{margin:0;font-size:.95rem;color:#fffc}.dashboard-cards-grid{display:grid;grid-template-columns:repeat(3,minmax(260px,1fr));gap:1.5rem;margin-top:1.5rem}.dashboard-tabs{display:inline-flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem;margin-bottom:1.25rem}.dashboard-tab{padding:.5rem 1rem;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:#0f172a99;color:#fffc;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.dashboard-tab:hover{background:#1e40afcc;border-color:#818cf8e6}.dashboard-tab--active{background:linear-gradient(135deg,#e6b800,#c99a00);border-color:transparent;color:#111827}@media(max-width:1200px){.dashboard-cards-grid{grid-template-columns:repeat(2,minmax(260px,1fr))}}@media(max-width:768px){.dashboard-cards-grid{grid-template-columns:1fr}}.monit-card{background:#121218f2;border-radius:16px;border:1px solid rgba(255,255,255,.06);padding:1.25rem 1.25rem 1rem;color:#fff;display:flex;flex-direction:column;gap:1rem;box-shadow:0 16px 32px #0006}.monit-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.monit-card-title-area{display:flex;flex-direction:column;gap:.15rem}.monit-card-title{margin:0;font-size:1.1rem;font-weight:700;letter-spacing:-.01em}.monit-card-subtitle{margin:0;font-size:.8rem;color:#ffffffbf}.monit-card-status{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;padding:.3rem .6rem;border-radius:999px;background:#ffffff0a}.monit-card-status-dot{width:.6rem;height:.6rem;border-radius:999px;background:#9ca3af}.monit-card-status--connected .monit-card-status-dot{background:#22c55e;box-shadow:0 0 8px #22c55ecc}.monit-card-status--connecting .monit-card-status-dot{background:#eab308;box-shadow:0 0 8px #eab30899}.monit-card-status--error .monit-card-status-dot{background:#ef4444;box-shadow:0 0 8px #ef4444cc}.monit-card-status-text{white-space:nowrap}.monit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem 1rem}.monit-item{display:flex;flex-direction:column;gap:.15rem}.monit-label{font-size:.75rem;color:#fffc}.monit-value{font-size:1.05rem;font-weight:600;color:#fefcf5}.monit-value--warn{color:#facc15}.monit-value--crit{color:#f97373}.monit-footer{margin-top:.5rem;font-size:.75rem;color:#ffffffbf}@media(max-width:640px){.monit-grid{grid-template-columns:1fr}}.dados-cpd-card{background:#121218fa;border-radius:16px;border:1px solid rgba(255,255,255,.08);padding:1.5rem 1.5rem 1.25rem;color:#fff;box-shadow:0 18px 40px #00000073;display:flex;flex-direction:column;gap:1.25rem}.dados-cpd-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.dados-cpd-title{margin:0;font-size:1.2rem;font-weight:700}.dados-cpd-subtitle{margin:.15rem 0 0;font-size:.8rem;color:#ffffffbf}.dados-cpd-status{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;padding:.3rem .7rem;border-radius:999px;background:#ffffff0d}.dados-cpd-status-dot{width:.55rem;height:.55rem;border-radius:999px;background:#9ca3af}.dados-cpd-status--connected .dados-cpd-status-dot{background:#22c55e;box-shadow:0 0 8px #22c55ecc}.dados-cpd-status--connecting .dados-cpd-status-dot{background:#eab308;box-shadow:0 0 8px #eab30899}.dados-cpd-status--error .dados-cpd-status-dot{background:#ef4444;box-shadow:0 0 8px #ef4444cc}.dados-cpd-status-text{white-space:nowrap}.dados-cpd-section{border-top:1px solid rgba(255,255,255,.06);padding-top:.9rem}.dados-cpd-section:first-of-type{border-top:none;padding-top:0}.dados-cpd-section-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.4rem}.dados-cpd-section h4{margin:0;font-size:.9rem;font-weight:600;color:#ffffffe6}.dados-cpd-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem 1.25rem}.dados-cpd-item{display:flex;flex-direction:column;gap:.1rem}.dados-cpd-item-wide{grid-column:1 / -1}.dados-cpd-label{font-size:.75rem;color:#ffffffb3}.dados-cpd-value{font-size:.9rem;font-weight:500;color:#fefcf5}.dados-cpd-chart-btn{padding:.35rem .8rem;border-radius:999px;border:1px solid rgba(250,204,21,.6);background:#172554e6;color:#fefce8;font-size:.75rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,transform .1s}.dados-cpd-chart-btn:hover{background:#facc1526;transform:translateY(-.5px)}.dados-cpd-chart-btn--secondary{border-color:#94a3b8b3;background:#0f172ae6}.dados-cpd-chart-wrapper{margin-top:.75rem}.dados-cpd-chart-status{margin-top:.5rem;font-size:.8rem;color:#e2e8f0e6}.dados-cpd-chart-status--error{color:#fecaca}.dados-cpd-modal-backdrop{position:fixed;inset:0;background:#0f172ad9;display:flex;align-items:center;justify-content:center;z-index:50}.dados-cpd-modal{width:min(720px,100% - 2rem);max-height:min(480px,100% - 4rem);background:#020617;border-radius:16px;border:1px solid rgba(148,163,184,.6);padding:1.25rem 1.25rem 1rem;box-shadow:0 24px 80px #000c;overflow:hidden;display:flex;flex-direction:column;gap:.5rem}.dados-cpd-chart-section{margin-top:0}.dados-cpd-chart-metric-tabs{display:inline-flex;flex-wrap:wrap;gap:.4rem;margin-top:.25rem;margin-bottom:.4rem}.dados-cpd-chart-metric{padding:.25rem .7rem;border-radius:999px;border:1px solid rgba(148,163,184,.7);background:#0f172ae6;color:#e2e8f0e6;font-size:.75rem;cursor:pointer}.dados-cpd-chart-metric--active{background:linear-gradient(135deg,#e6b800,#c99a00);border-color:transparent;color:#111827}@media(max-width:768px){.dados-cpd-grid{grid-template-columns:1fr}}.alarmes-page{display:flex;flex-direction:column;gap:1rem}.alarmes-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem}.alarmes-actions{display:flex;align-items:center;gap:.75rem}.alarmes-filter{padding:.5rem .75rem;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#0f172acc;color:#fefcf5;font-size:.9rem;cursor:pointer}.alarmes-btn-clear{padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(248,113,113,.5);background:#f871711a;color:#fca5a5;font-size:.9rem;font-weight:500;cursor:pointer}.alarmes-btn-clear:hover{background:#f8717133}.alarmes-error{padding:1rem;border-radius:10px;background:#f8717126;border:1px solid rgba(248,113,113,.3);color:#fca5a5}.alarmes-status{color:#fff9;font-size:.95rem;margin:0}.alarmes-summary{font-size:.85rem;color:#fff9}.alarmes-table-wrap{overflow:auto;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#12121899}.alarmes-table{width:100%;border-collapse:collapse;font-size:.9rem}.alarmes-table th{text-align:left;padding:.75rem 1rem;background:#ffffff0d;color:#ffffffe6;font-weight:600;white-space:nowrap}.alarmes-table td{padding:.65rem 1rem;border-top:1px solid rgba(255,255,255,.06);color:#fefcf5}.alarmes-table tbody tr:hover{background:#ffffff08}.alarmes-cell-time{white-space:nowrap;color:#ffffffb3;font-size:.85rem}.alarmes-cell-sala{font-weight:600;color:#e6b800}.alarmes-cell-msg{max-width:320px}.alarmes-cell-tipo{color:#fff9;font-size:.85rem}#root{margin:0;padding:0}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
