#app{position:absolute;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh}#loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#1e1e1e;color:#fff;display:flex;justify-content:center;align-items:center;font-size:1.8em;z-index:1000;text-align:center;font-family:Arial,sans-serif;transition:opacity .5s ease-out}#loading-screen.hidden{opacity:0;visibility:hidden;transition:opacity .5s ease-out,visibility 0s linear .5s}#loading-screen span:after{content:".";animation:dots 1s steps(5,end) infinite}@keyframes dots{0%,20%{color:#fff0;text-shadow:.25em 0 0 rgba(255,255,255,0),.5em 0 0 rgba(255,255,255,0)}40%{color:#fff;text-shadow:.25em 0 0 rgba(255,255,255,0),.5em 0 0 rgba(255,255,255,0)}60%{text-shadow:.25em 0 0 white,.5em 0 0 rgba(255,255,255,0)}80%,to{text-shadow:.25em 0 0 white,.5em 0 0 white}}#create-alarm-temp-button{position:fixed;bottom:600px;right:50px;background:#af4c4c;color:#fff;border:none;padding:10px 15px;border-radius:5px;cursor:pointer;font-size:1em;z-index:1000;box-shadow:0 2px 10px #0000004d;transition:background .2s ease,transform .2s ease}#create-alarm-temp-button:hover{background:#45a049;transform:translateY(-2px)}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#1e3c72,#2a5298);height:100vh;width:100vw;color:#fff;overflow:hidden}.status-bar{position:fixed;top:0;left:0;right:0;background:#00000069;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 20px;z-index:1000;border-bottom:1px solid rgba(255,255,255,.1)}.status-container{display:flex;align-items:center;justify-content:space-between;max-width:1600px;margin:0 auto;flex-wrap:wrap;gap:10px}.status-left{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center;flex-grow:1}.status-item{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:500;position:relative;white-space:nowrap}.status-indicator{width:10px;height:10px;border-radius:50%;box-shadow:0 0 8px #0000004d;animation:pulse 2s infinite}.status-connected{background:#0f8;box-shadow:0 0 15px #0f89}.status-disconnected{background:#f44;box-shadow:0 0 15px #f449;animation:blink 1s infinite}.status-warning{background:#fa0;box-shadow:0 0 15px #fa09}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.status-right{display:flex;align-items:center;gap:20px;font-size:13px;color:#fffc;flex-wrap:wrap;justify-content:center;flex-grow:1}.timestamp{font-family:Courier New,monospace;font-size:18px}.app-branding{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.app-logo{font-size:1.6rem;font-weight:700}.logo-3d{color:#f44}.logo-scada{color:#fff}.app-version{font-size:.8em;color:#fff9;line-height:1;white-space:nowrap}.weather-widget{cursor:pointer;position:relative;padding-right:20px}.weather-icon img{width:34px;height:34px;vertical-align:middle}.weather-tooltip{position:absolute;top:100%;left:0;background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;padding:12px 15px;box-shadow:0 4px 15px #0006;min-width:220px;opacity:0;visibility:hidden;transform:translateY(10px);z-index:1001;border:1px solid rgba(255,255,255,.1);transition:opacity .3s ease,transform .3s ease,visibility .3s ease}.weather-tooltip.visible{opacity:1;visibility:visible;transform:translateY(0)}.weather-tooltip h4{margin-top:0;margin-bottom:10px;color:#0f8;font-size:1em;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:5px;font-weight:500}#forecast-details{display:flex;flex-direction:column;gap:8px}.forecast-item{display:flex;align-items:center;justify-content:space-between;font-size:.9em;color:#fffc}.forecast-item img{width:28px;height:28px;vertical-align:middle}.outage-widget{cursor:pointer;position:relative;padding-right:20px}.outage-widget .outage-icon{font-size:1.2em;margin-right:5px;color:#ffffffb3}.outage-widget.active .outage-icon{animation:blink-outage 1s infinite alternate;color:#fa0}.outage-widget.active .outage-icon.water{color:#0af}.outage-widget.active .outage-icon.power{color:#f44}@keyframes blink-outage{0%{opacity:1}to{opacity:.5}}.outage-tooltip{position:absolute;top:100%;left:0;background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;padding:12px 15px;box-shadow:0 4px 15px #0006;min-width:220px;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .3s ease,transform .3s ease,visibility .3s ease;z-index:1001;border:1px solid rgba(255,255,255,.1);white-space:normal}.outage-tooltip.visible{opacity:1;visibility:visible;transform:translateY(0)}.outage-tooltip h5{margin:0;font-size:.9em;color:#ffffffe6}.logged-in-user-wrapper{position:relative;cursor:pointer}.logged-in-user{display:flex;align-items:center;gap:8px;color:#aff;font-weight:600;font-size:14px}.logged-in-user i{color:#ffffffb3}.user-tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(10px);background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;padding:10px 15px;box-shadow:0 4px 15px #0006;opacity:0;visibility:hidden;transition:opacity .3s ease,transform .3s ease,visibility .3s ease;z-index:1001;border:1px solid rgba(255,255,255,.1);white-space:nowrap}.user-tooltip.visible{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.user-tooltip button{background:#f44;color:#fff;border:none;padding:8px 15px;border-radius:5px;font-size:.9em;cursor:pointer;transition:background .2s ease,transform .2s ease}.user-tooltip button:hover{background:#e63946;transform:translateY(-1px)}@media (max-width: 768px){.status-bar{padding:8px 10px}.status-container{flex-direction:row;justify-content:center;gap:15px}.status-right,.timestamp,.app-branding,.weather-widget,.outage-widget{display:none!important}.status-left{width:100%;justify-content:center;gap:15px;flex-wrap:wrap}.status-item{font-size:14px}.status-indicator{width:8px;height:8px}}@media (max-width: 480px){.status-container{gap:10px}.status-item{font-size:12px;gap:5px}}.settings-button{position:fixed;bottom:20px;left:20px;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:50%;width:50px;height:50px;display:flex;justify-content:center;align-items:center;font-size:1.5rem;color:#fff;cursor:pointer;box-shadow:0 4px 15px #0000004d;transition:background .3s ease,transform .3s ease;z-index:1000}.settings-button:hover{background:#0009;transform:scale(1.05)}.settings-panel{position:fixed;top:0;left:-350px;width:350px;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-right:1px solid rgba(255,255,255,.15);box-shadow:2px 0 20px #00000080;transition:left .4s ease-out;z-index:1100;display:flex;flex-direction:column;padding:20px;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.settings-panel::-webkit-scrollbar{display:none}.settings-panel.open{left:0}.panel-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:15px;margin-bottom:15px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.panel-header h3{margin:0;color:#fff;font-size:1.6rem}.close-button{background:none;border:none;color:#ffffffb3;font-size:1.4rem;cursor:pointer;transition:color .2s ease}.close-button:hover{color:#fff}.panel-content{flex-grow:1;overflow-y:auto;padding-right:10px;margin-bottom:20px;scrollbar-width:thin;scrollbar-color:rgba(0,255,136,.5) rgba(0,0,0,.2)}.panel-content::-webkit-scrollbar{width:8px;background-color:transparent}.panel-content::-webkit-scrollbar-track{background:#0003;border-radius:10px}.panel-content::-webkit-scrollbar-thumb{background-color:#0f89;border-radius:10px;border:2px solid transparent;background-clip:padding-box;transition:background-color .2s ease}.panel-content::-webkit-scrollbar-thumb:hover{background-color:#00ff88e6}.setting-group{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:15px;margin-bottom:20px;box-shadow:inset 0 0 5px #0003}.setting-group h4{margin-top:0;margin-bottom:15px;color:#0f8;font-size:1.2em;border-bottom:1px dashed rgba(255,255,255,.1);padding-bottom:10px}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px dashed rgba(255,255,255,.08)}.setting-item:last-child{border-bottom:none}.setting-item label{flex-grow:1;font-size:1em;color:#ffffffe6}.setting-item select,.setting-item input[type=checkbox]{background:#ffffff26;border:1px solid rgba(255,255,255,.25);color:#fff;padding:6px 8px;border-radius:5px;font-size:.9em;cursor:pointer}.setting-item select option{background:#2a5298;color:#fff}.setting-item input[type=checkbox]{width:20px;height:20px;appearance:none;-webkit-appearance:none;-moz-appearance:none;border-radius:4px;background:#fff3;border:1px solid rgba(255,255,255,.3);position:relative}.setting-item input[type=checkbox]:checked{background-color:#0f8;border-color:#0f8}.setting-item input[type=checkbox]:checked:after{content:"";font-family:"Font Awesome 5 Free";font-weight:900;color:#1e3c72;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px}.setting-item .display-value{font-size:1em;color:#0f8;font-weight:700;background:#00aaff1a;padding:4px 8px;border-radius:5px;min-width:80px;text-align:center;border:1px solid rgba(0,170,255,.3)}.panel-footer{padding-top:20px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;gap:15px;flex-shrink:0}.user-profile-section{display:flex;align-items:center;gap:10px;color:#ffffffe6;font-size:1.1em;font-weight:500}.user-profile-icon{font-size:1.8em;color:#0f8}.logout-button-panel{background:#f44;color:#fff;border:none;padding:8px 15px;border-radius:5px;cursor:pointer;font-size:.9em;font-weight:700;transition:background .2s ease,transform .2s ease;display:none}.logout-button-panel:hover{background:#e63946;transform:translateY(-1px)}.social-links{display:flex;gap:20px;margin-top:10px}.social-link{color:#ffffffb3;font-size:1.8em;transition:color .2s ease,transform .2s ease}.social-link:hover{color:#fff;transform:translateY(-2px)}.social-link .fa-linkedin{color:#0077b5}.social-link .fa-envelope{color:#ea4335}@media (max-width: 768px){.settings-panel{width:100%;left:-100%;border-right:none;border-left:none;padding:15px;box-shadow:none;transition:left .4s ease-out}.settings-panel.open{left:0;right:0;border-left:none}.panel-header{padding-bottom:10px;margin-bottom:10px}.panel-header h3{font-size:1.4rem}.close-button{font-size:1.2rem}.panel-content{padding-right:5px;margin-bottom:15px}.setting-group{padding:10px;margin-bottom:15px}.setting-group h4{font-size:1.1em;margin-bottom:10px;padding-bottom:8px}.setting-item{padding:8px 0}.setting-item label,.setting-item select,.setting-item input[type=checkbox],.setting-item .display-value{font-size:.9em}.user-profile-section{font-size:1em;gap:8px}.user-profile-icon{font-size:1.6em}.logout-button-panel{padding:6px 12px;font-size:.8em}.social-links{gap:15px;margin-top:5px}.social-link{font-size:1.6em}}@media (max-width: 480px){.settings-button{width:45px;height:45px;font-size:1.3rem;bottom:15px;left:15px}.settings-panel{padding:10px}.panel-header h3{font-size:1.2rem}.setting-group{padding:8px}.setting-group h4{font-size:1em}.setting-item label,.setting-item select,.setting-item input[type=checkbox],.setting-item .display-value{font-size:.85em}}.auth-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;justify-content:center;align-items:center;z-index:2000;color:#fff}.auth-card{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:30px 40px;box-shadow:0 8px 30px #00000080;text-align:center;width:100%;max-width:400px}.separator{display:flex;align-items:center;text-align:center;margin:25px 0;color:#fff9}.separator:before,.separator:after{content:"";flex:1;border-bottom:1px solid rgba(255,255,255,.2)}.separator:not(:empty):before{margin-right:.5em}.separator:not(:empty):after{margin-left:.5em}.social-login-button{display:flex;align-items:center;justify-content:center;width:100%;padding:12px 20px;border:none;border-radius:5px;font-size:1.1em;cursor:pointer;transition:background .3s ease,box-shadow .3s ease;margin-bottom:15px;gap:10px}.social-login-button i{font-size:1.2em}.social-login-button.google-button{background-color:#4285f4;color:#fff}.social-login-button.google-button:hover{background-color:#357ae8;box-shadow:0 4px 12px #0003}.auth-card h2{margin-top:0;margin-bottom:25px;color:#0f8;font-size:2em}.input-group{margin-bottom:20px;text-align:left}.input-group label{display:block;margin-bottom:8px;font-size:.95em;color:#fffc}.input-group input[type=text],.input-group input[type=password],.input-group input[type=email],.input-group select{width:100%;padding:12px 15px;border:1px solid rgba(255,255,255,.3);background:#ffffff14;border-radius:5px;color:#fff;font-size:1em;outline:none;box-sizing:border-box}.input-group input::placeholder{color:#ffffff80}.input-group input:focus,.input-group select:focus{border-color:#0f8;box-shadow:0 0 0 2px #00ff884d}.input-group select option{background:#1e3c72;color:#fff}.auth-card button{background:#0f8;color:#1e3c72;border:none;padding:12px 25px;border-radius:5px;font-size:1.1em;font-weight:700;cursor:pointer;transition:background .3s ease,transform .2s ease;width:100%;margin-top:15px}.auth-card button:hover{background:#00e676;transform:translateY(-2px)}.error-message{color:#f44;font-size:.9em;margin-top:15px;height:1.2em}.alarm-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1500;pointer-events:none;display:none;overflow:hidden}.alarm-overlay>.alarm-card{pointer-events:all}.alarm-card{position:absolute;background:#2720206b;border:2px solid;border-radius:12px;padding:20px;box-shadow:0 10px 30px #000000b3;color:#fff;width:100%;max-width:450px;display:flex;flex-direction:column;gap:15px;z-index:1998;overflow:hidden;min-height:120px;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;transition:width .3s ease,max-width .3s ease,height .3s ease,padding .3s ease,border-radius .3s ease,box-shadow .3s ease,background .3s ease}.alarm-card.high{border-color:#f44;animation:blink-high 1s infinite alternate}.alarm-card.medium{border-color:#fa0;animation:blink-medium 1.2s infinite alternate}.alarm-card.low{border-color:#0af;animation:blink-low 1.5s infinite alternate}@keyframes blink-high{0%{border-color:#f44;box-shadow:0 0 15px #ff4444b3}to{border-color:#ff44444d;box-shadow:0 0 5px #f443}}@keyframes blink-medium{0%{border-color:#fa0;box-shadow:0 0 15px #ffaa00b3}to{border-color:#ffaa004d;box-shadow:0 0 5px #fa03}}@keyframes blink-low{0%{border-color:#0af;box-shadow:0 0 15px #00aaffb3}to{border-color:#00aaff4d;box-shadow:0 0 5px #0af3}}.alarm-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.15);cursor:grab;flex-shrink:0;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.alarm-icon{font-size:2em;color:#fa0;margin-right:15px;flex-shrink:0}.alarm-title{margin:0;font-size:1.5em;color:#0f8;flex-grow:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 0 5px rgba(0,255,136,.5);font-weight:700}.alarm-controls{display:flex;gap:8px;flex-shrink:0}.alarm-controls button{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.85em;transition:background .2s ease,border-color .2s ease,transform .2s ease;white-space:nowrap}.alarm-controls button:hover{background:#ffffff40;transform:translateY(-1px)}.ack-button{background:#0f8;color:#1e3c72;font-weight:700;border-color:#0f8}.ack-button:hover{background:#00e676;border-color:#00e676}.details-toggle-button{background:#0af3;border-color:#00aaff80}.details-toggle-button:hover{background:#0af6}.mute-button{background:none!important;border:none!important;padding:0!important;font-size:1.1em!important;color:#ffffffb3!important;margin-right:5px}.mute-button:hover{color:#fff!important;background:none!important;transform:none!important}.mute-button.muted{color:#fa0!important}.alarm-details{text-align:left;line-height:1.5;font-size:1em;color:#ffffffd9;opacity:1;max-height:500px;transition:opacity .4s ease,max-height .4s ease,padding .4s ease,margin .4s ease;overflow-y:auto;padding-right:5px;scrollbar-width:thin;scrollbar-color:rgba(0,170,255,.5) transparent}.alarm-details::-webkit-scrollbar{width:6px}.alarm-details::-webkit-scrollbar-track{background:transparent}.alarm-details::-webkit-scrollbar-thumb{background-color:#00aaff80;border-radius:6px}.alarm-details strong{color:#0af;margin-right:5px}.alarm-card.minimized{padding:8px 12px;max-width:220px;min-height:auto;border-radius:8px;background:#0009;box-shadow:0 4px 10px #00000080;border-width:1px;transform:scale(.8);transform-origin:center center;animation-duration:1.5s!important;box-shadow:0 0 8px #fff3!important}.alarm-card.minimized .alarm-details{opacity:0;max-height:0;padding:0;margin:0;pointer-events:none;overflow-y:hidden}.alarm-card.minimized .alarm-header{flex-wrap:wrap;justify-content:center;padding-bottom:0;border-bottom:none;gap:0}.alarm-card.minimized .alarm-icon{font-size:1.1em;margin-right:3px;order:1}.alarm-card.minimized .alarm-title{font-size:.9em;font-weight:700;color:#fff;text-shadow:0 0 5px rgba(255,255,255,.8);flex-basis:auto;max-width:calc(100% - 30px);text-align:left;order:2;margin-bottom:0}.alarm-card.minimized .alarm-controls{width:100%;justify-content:center;margin-top:5px;border-top:1px solid rgba(255,255,255,.08);padding-top:5px;order:3}.alarm-card.minimized .alarm-controls button{padding:3px 6px;font-size:.65em;border-width:.5px}@media (max-width: 768px){.alarm-card{width:95vw;max-width:95vw;height:auto;max-height:90vh;padding:15px;border-radius:10px;box-sizing:border-box;position:fixed;left:50%!important;top:50%!important;transform:translate(-50%,-50%)!important}.alarm-card[style*=transform]{transform:translate(-50%,-50%)!important}.alarm-card.minimized{width:200px;padding:10px;top:20px!important;left:50%!important;transform:translate(-50%)!important;background:#272020b3;box-shadow:0 4px 10px #0009;border-radius:8px;font-size:.9em}.alarm-header{flex-wrap:wrap;justify-content:center;text-align:center;gap:8px}.alarm-icon{font-size:1.8em;margin-right:0;width:100%}.alarm-title{font-size:1.3em;white-space:normal;overflow:visible;text-overflow:clip;width:100%;text-align:center}.alarm-controls{width:100%;justify-content:center;gap:8px;margin-top:10px}.alarm-controls button{padding:10px 15px;font-size:.9em}.alarm-details{font-size:.9em;line-height:1.4;padding-right:0}}@media (max-width: 480px){.alarm-card{width:98vw;max-width:98vw;padding:10px;border-radius:8px}.alarm-card.minimized{width:180px;padding:8px;top:10px!important}.alarm-icon{font-size:1.5em}.alarm-title{font-size:1.1em}.alarm-controls{gap:5px}.alarm-controls button{padding:8px 12px;font-size:.8em}.alarm-details{font-size:.85em}}:root{--widget-bg: rgba(10, 25, 41, .75);--widget-border: rgba(56, 189, 248, .2);--accent-color: #00ff88;--accent-glow: #00ff88;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--online-indicator: #22c55e;--scrollbar-thumb: rgba(14, 165, 233, .5);--scrollbar-thumb-hover: rgba(14, 165, 233, .8);--item-hover-bg: rgba(14, 165, 233, .1)}.online-users-widget{position:fixed;bottom:20px;right:20px;background:var(--widget-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--widget-border);border-radius:16px;padding:20px;box-shadow:0 8px 32px #0000004d,0 0 20px var(--accent-glow);color:var(--text-primary);width:260px;max-height:350px;display:flex;flex-direction:column;z-index:900;opacity:0;transform:translateY(20px);animation:fadeIn .5s ease-out forwards;transition:width .3s ease,height .3s ease,padding .3s ease,bottom .3s ease,left .3s ease,right .3s ease}@keyframes fadeIn{to{opacity:1;transform:translateY(0)}}.widget-header{display:flex;align-items:center;gap:4px;margin-bottom:5px;padding-bottom:5px;border-bottom:1px solid;border-image-slice:1;border-image-source:linear-gradient(to right,var(--accent-color),transparent);cursor:pointer}.widget-header i{font-size:1em;color:var(--accent-color);text-shadow:0 0 8px var(--accent-glow)}.widget-header h4{margin:0;font-size:.95em;font-weight:600;color:var(--text-primary)}.online-count-display{font-size:.95em;color:var(--accent-color);font-weight:600;margin-left:auto;display:inline-block;transition:opacity .3s ease}.online-users-list{list-style:none;padding:0;margin:0;flex-grow:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent;transition:opacity .3s ease}.online-users-list::-webkit-scrollbar{width:6px}.online-users-list::-webkit-scrollbar-track{background:transparent}.online-users-list::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb);border-radius:6px;transition:background-color .2s ease}.online-users-list::-webkit-scrollbar-thumb:hover{background-color:var(--scrollbar-thumb-hover)}.online-user-item{display:flex;align-items:center;gap:10px;padding:10px 5px;font-size:.8em;color:var(--text-secondary);border-radius:8px;transition:background-color .2s ease,color .2s ease}.online-user-item:before{content:"";display:block;width:8px;height:8px;border-radius:50%;background-color:var(--online-indicator);box-shadow:0 0 5px #22c55eb3;flex-shrink:0}.online-user-item:hover{background-color:var(--item-hover-bg);color:var(--text-primary)}.no-users-message{text-align:center;color:var(--text-secondary);margin-top:20px;font-style:italic}.online-users-widget.collapsed{width:auto;height:auto;padding:10px 15px;max-height:unset}.online-users-widget.collapsed .widget-header{border-bottom:none;margin-bottom:0;padding-bottom:0}.online-users-widget.collapsed .online-users-list{display:none;opacity:0;height:0;pointer-events:none}@media (max-width: 768px){.online-users-widget{bottom:15px;right:15px;left:unset;width:auto;max-height:auto;padding:10px 15px;border-radius:12px;box-shadow:0 4px 15px #0000004d,0 0 10px var(--accent-glow)}.online-users-widget:not(.collapsed){width:220px;max-height:300px;padding:15px}.online-users-widget:not(.collapsed) .widget-header{border-bottom:1px solid;border-image-slice:1;border-image-source:linear-gradient(to right,var(--accent-color),transparent);margin-bottom:5px;padding-bottom:5px}.online-users-widget .widget-header h4{font-size:1em}.online-users-widget .widget-header i{font-size:.9em}.online-count-display{font-size:1em}}@media (max-width: 480px){.online-users-widget{bottom:15px;right:10px;padding:8px 12px;border-radius:10px}.online-users-widget:not(.collapsed){width:200px;max-height:250px;padding:12px}.online-users-widget .widget-header h4{font-size:.9em}.online-users-widget .widget-header i{font-size:.8em}.online-count-display{font-size:.9em}}:root{--panel-bg-color: rgba(0, 0, 0, .7);--panel-header-bg: rgba(0, 0, 0, .8);--border-color: rgba(255, 255, 255, .15);--text-color-primary: rgba(255, 255, 255, .9);--text-color-secondary: rgba(255, 255, 255, .7);--text-color-tertiary: rgba(255, 255, 255, .5);--primary-color: #00ff88;--primary-color-dark: #8cb300;--secondary-color: #6c757d;--secondary-color-dark: #5a6268;--button-text-color: #1e3c72;--button-hover-bg-color: #00d97b;--scrollbar-thumb-color: rgba(0, 255, 136, .6);--scrollbar-thumb-hover-color: rgba(0, 255, 136, .9);--scrollbar-track-color: rgba(0, 0, 0, .2);--severity-low-color: #88EE88;--severity-medium-color: #FFD700;--severity-high-color: #FF6347}.alarm-history-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:750px;height:85%;max-height:90vh;background-color:var(--panel-bg-color);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 25px #00000080;z-index:2000;display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transform:translate(-50%,-50%) scale(.95);transition:opacity .3s ease-out,visibility .3s ease-out,transform .3s ease-out}.alarm-history-panel.active{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}.history-header{display:flex;justify-content:space-between;align-items:center;padding:15px 25px;background-color:var(--panel-header-bg);border-bottom:1px solid var(--border-color);color:var(--text-color-primary);font-weight:600;font-size:1.1em;-webkit-user-select:none;user-select:none}.history-header h3{margin:0;font-size:1.4em}.history-header .close-button{background:none;border:none;font-size:2em;color:var(--text-color-secondary);cursor:pointer;padding:0 10px;line-height:1;transition:color .2s ease,transform .2s ease}.history-header .close-button:hover{color:var(--text-color-primary);transform:rotate(90deg)}.history-tabs{display:flex;justify-content:center;border-bottom:1px solid var(--border-color);background-color:var(--panel-header-bg);padding:0 15px}.history-tabs .tab-button{background:none;border:none;padding:12px 20px;cursor:pointer;font-size:1.1em;color:var(--text-color-secondary);transition:color .3s ease,background-color .3s ease,border-bottom .3s ease;border-bottom:3px solid transparent;margin:0 5px;outline:none}.history-tabs .tab-button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.history-tabs .tab-button:hover{color:var(--text-color-primary);background-color:#ffffff0d}.history-tabs .tab-button.active{color:var(--primary-color);border-bottom:3px solid var(--primary-color);font-weight:700}.date-range-filter-container{display:flex;flex-wrap:wrap;gap:15px;padding:15px 25px;background-color:var(--panel-bg-color);border-bottom:1px solid var(--border-color);align-items:center}.date-range-filter-container label{color:var(--text-color-primary);font-size:.95em;min-width:80px}.date-range-filter-container input[type=datetime-local]{flex-grow:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--card-bg-color);color:var(--text-color-primary);font-size:.95em;max-width:200px}.date-range-filter-container input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(1)}.date-range-filter-container button{padding:8px 15px;background-color:var(--primary-color);color:var(--button-text-color);border:none;border-radius:6px;cursor:pointer;font-size:.95em;font-weight:600;transition:background-color .3s ease}.date-range-filter-container button:hover{background-color:var(--button-hover-bg-color)}.history-content{flex-grow:1;overflow-y:auto;padding:20px;list-style:none;color:var(--text-color-secondary)}#history-list{padding:0;margin:0;list-style:none}.history-item{background-color:var(--card-bg-color);border:1px solid var(--border-color);border-radius:8px;padding:15px;margin-bottom:15px;box-shadow:inset 0 0 5px #0003;color:var(--text-color-primary);position:relative;overflow:hidden;display:flex;align-items:flex-start;gap:15px}.alarm-content-wrapper{flex-grow:1;border-left:8px solid transparent;padding-left:15px}.alarm-content-wrapper.low{border-left-color:var(--severity-low-color)}.alarm-content-wrapper.medium{border-left-color:var(--severity-medium-color)}.alarm-content-wrapper.high{border-left-color:var(--severity-high-color)}.alarm-date-badge{min-width:65px;height:75px;background-color:var(--primary-color-dark);border-radius:8px;display:flex;flex-direction:column;justify-content:center;align-items:center;color:var(--button-text-color);font-weight:700;text-align:center;box-shadow:0 2px 5px #0003;flex-shrink:0;overflow:hidden}.alarm-date-badge .day{font-size:1.8em;line-height:1;margin-bottom:2px;padding-top:5px}.alarm-date-badge .month{font-size:.8em;text-transform:uppercase;background-color:#0003;width:100%;padding:2px 0;box-sizing:border-box;display:block}.alarm-date-badge .year{font-size:.7em;opacity:.8;margin-top:auto;padding-bottom:5px}.header-line{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px;width:100%}.alarm-severity-stars{font-size:1.2em;display:flex;gap:3px;flex-shrink:0}.alarm-severity-stars i{color:var(--text-color-secondary);font-family:"Font Awesome 5 Free";font-weight:900}.alarm-severity-stars.stars-low i{color:var(--severity-low-color)}.alarm-severity-stars.stars-medium i{color:var(--severity-medium-color)}.alarm-severity-stars.stars-high i{color:var(--severity-high-color)}.history-item strong{font-size:1.1em;color:var(--text-color-primary);margin-bottom:0}.history-item span{font-size:.9em;color:var(--text-color-secondary);display:block;margin-bottom:5px}.history-item small{display:block;margin-top:3px;color:var(--text-color-tertiary);font-size:.75em}.no-history-message,.loading-message,.error-message,.no-more-alarms-message,.enter-dates-message{text-align:center;padding:30px;color:var(--text-color-secondary);font-style:italic;font-size:1.1em}.load-more-button{display:block;width:fit-content;margin:20px auto;padding:12px 25px;background-color:var(--secondary-color);color:var(--button-text-color);border:none;border-radius:8px;cursor:pointer;font-size:1em;font-weight:700;transition:background-color .3s ease,transform .2s ease}.load-more-button:hover{background-color:var(--secondary-color-dark);transform:translateY(-2px)}.history-content::-webkit-scrollbar{width:8px}.history-content::-webkit-scrollbar-track{background:var(--scrollbar-track-color);border-radius:10px}.history-content::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb-color);border-radius:10px;border:2px solid transparent;background-clip:padding-box;transition:background-color .2s ease}.history-content::-webkit-scrollbar-thumb:hover{background-color:var(--scrollbar-thumb-hover-color)}.history-content{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb-color) var(--scrollbar-track-color)}.fixed-bottom-left-button{position:fixed;bottom:80px;left:20px;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:50%;width:50px;height:50px;display:flex;justify-content:center;align-items:center;font-size:1.5rem;color:#fff;cursor:pointer;box-shadow:0 4px 15px #0000004d;transition:background .3s ease,transform .3s ease;z-index:1000}.fixed-bottom-left-button:hover{background:#0009;transform:scale(1.05)}.fixed-bottom-left-button:active{transform:translateY(0)}@media (max-width: 768px){.alarm-history-panel{width:95%;height:90%;max-width:none;max-height:none}.history-header{padding:12px 20px}.history-tabs .tab-button{padding:10px 18px;font-size:1em}.date-range-filter-container{flex-direction:column;align-items:stretch;padding:12px 20px;gap:12px}.date-range-filter-container label,.date-range-filter-container input,.date-range-filter-container button{max-width:none;width:100%}.history-item{flex-direction:row;align-items:flex-start;padding-left:15px}.alarm-date-badge{margin-bottom:0;min-width:60px;height:70px}.alarm-date-badge .day{font-size:1.6em}.alarm-date-badge .month{font-size:.75em}.alarm-date-badge .year{font-size:.65em}.alarm-content-wrapper{border-left:8px solid transparent;border-top:none;padding-left:15px;padding-top:0;text-align:left;width:auto}.alarm-content-wrapper.low{border-left-color:var(--severity-low-color);border-top-color:initial}.alarm-content-wrapper.medium{border-left-color:var(--severity-medium-color);border-top-color:initial}.alarm-content-wrapper.high{border-left-color:var(--severity-high-color);border-top-color:initial}.header-line{flex-direction:row;align-items:center;gap:5px}.history-item strong,.alarm-severity-stars{font-size:1em}.history-item span{font-size:.85em}.history-item small{font-size:.7em}}@media (max-width: 480px){.alarm-history-panel{width:100%;height:100%;border-radius:0;box-shadow:none;top:0;left:0;transform:translate(0)}.fixed-bottom-left-button{width:45px;height:45px;font-size:1.3rem;bottom:65px;left:15px}.alarm-history-panel.active{transform:translate(0)}.history-header{padding:10px 15px}.history-header h3{font-size:1.2em}.history-tabs .tab-button{font-size:.9em;padding:8px 12px}.date-range-filter-container{padding:8px 10px;gap:8px}.alarm-date-badge{min-width:50px;height:60px}.alarm-date-badge .day{font-size:1.4em}.alarm-date-badge .month{font-size:.7em}.alarm-date-badge .year{font-size:.6em}.history-item strong,.alarm-severity-stars{font-size:.9em}.history-item span{font-size:.8em}.history-item small{font-size:.65em}}hover :root{--panel-bg-color: rgba(0, 0, 0, .7);--panel-header-bg: rgba(0, 0, 0, .8);--border-color: rgba(255, 255, 255, .15);--text-color-primary: rgba(255, 255, 255, .9);--text-color-secondary: rgba(255, 255, 255, .7);--text-color-tertiary: rgba(255, 255, 255, .5);--primary-color: #00ff88;--primary-color-dark: #8cb300;--secondary-color: #6c757d;--secondary-color-dark: #5a6268;--button-text-color: #1e3c72;--button-hover-bg-color: #00d97b;--card-bg-color: rgba(255, 255, 255, .05);--danger-color: #ff4444;--scrollbar-thumb-color: rgba(0, 255, 136, .6);--scrollbar-thumb-hover-color: rgba(0, 255, 136, .9);--scrollbar-track-color: rgba(0, 0, 0, .2)}.announcement-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:750px;height:85%;max-height:90vh;background-color:var(--panel-bg-color);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 25px #00000080;z-index:2100;display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transform:translate(-50%,-50%) scale(.95);transition:opacity .3s ease-out,visibility .3s ease-out,transform .3s ease-out}.announcement-panel.active{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:15px 25px;background-color:var(--panel-header-bg);border-bottom:1px solid var(--border-color);color:var(--text-color-primary);font-weight:600;font-size:1.1em;-webkit-user-select:none;user-select:none}.panel-header h3{margin:0;font-size:1.4em}.close-button{background:none;border:none;font-size:2em;color:var(--text-color-secondary);cursor:pointer;padding:0 10px;line-height:1;transition:color .2s ease,transform .2s ease}.close-button:hover{color:var(--text-color-primary);transform:rotate(90deg)}.announcement-tabs{display:flex;justify-content:center;border-bottom:1px solid var(--border-color);background-color:var(--panel-header-bg);padding:0 15px}.announcement-tabs .tab-button{background:none;border:none;padding:12px 20px;cursor:pointer;font-size:1.1em;color:var(--text-color-secondary);transition:color .3s ease,background-color .3s ease,border-bottom .3s ease;border-bottom:3px solid transparent;margin:0 5px;outline:none}.announcement-tabs .tab-button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.announcement-tabs .tab-button:hover{color:var(--text-color-primary);background-color:#ffffff0d}.announcement-tabs .tab-button.active{color:var(--primary-color);border-bottom:3px solid var(--primary-color);font-weight:700}.announcement-content{flex-grow:1;padding:20px;display:flex;flex-direction:column;overflow-y:hidden}.announcement-content .tab-section{flex-grow:1;display:none;overflow-y:auto;padding-right:5px}.announcement-content .tab-section.active{display:flex;flex-direction:column}.announcement-content .tab-section::-webkit-scrollbar{width:8px}.announcement-content .tab-section::-webkit-scrollbar-track{background:var(--scrollbar-track-color);border-radius:10px}.announcement-content .tab-section::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb-color);border-radius:10px;border:2px solid transparent;background-clip:padding-box;transition:background-color .2s ease}.announcement-content .tab-section::-webkit-scrollbar-thumb:hover{background-color:var(--scrollbar-thumb-hover-color)}.announcement-content .tab-section{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb-color) var(--scrollbar-track-color)}#announcement-list{list-style:none;padding:0;margin:0}.announcement-item{background-color:var(--card-bg-color);border:1px solid var(--border-color);border-radius:8px;padding:15px;margin-bottom:15px;box-shadow:inset 0 0 5px #0003;color:var(--text-color-primary);position:relative;overflow:hidden}.announcement-item h4{margin-top:0;margin-bottom:5px;color:var(--primary-color);font-size:1.1em}.announcement-item p{margin-bottom:10px;font-size:.95em;color:var(--text-color-secondary);line-height:1.5;white-space:pre-wrap}.announcement-item small{display:block;text-align:right;color:var(--text-color-tertiary);font-size:.75em}.announcement-form{display:flex;flex-direction:column;gap:15px;padding:10px}.announcement-form label{color:var(--text-color-primary);font-size:.95em;margin-bottom:-10px}.announcement-form input[type=text],.announcement-form textarea{padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--card-bg-color);color:var(--text-color-primary);font-size:1em;resize:vertical}.announcement-form input[type=text]:focus,.announcement-form textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #00ff884d}.form-actions{display:flex;align-items:center;gap:15px;margin-top:10px}#publish-announcement-button{padding:10px 20px;background-color:var(--primary-color);color:var(--button-text-color);border:none;border-radius:6px;cursor:pointer;font-size:1em;font-weight:700;transition:background-color .3s ease,transform .2s ease}#publish-announcement-button:hover{background-color:var(--button-hover-bg-color);transform:translateY(-2px)}.status-message{color:var(--text-color-primary);font-size:.9em;min-height:20px}.status-message.success{color:var(--primary-color)}.status-message.error{color:var(--danger-color)}.no-announcement-message,.loading-message,.error-message{text-align:center;padding:30px;color:var(--text-color-secondary);font-style:italic;font-size:1.1em}.notification-area-wrapper{position:fixed;bottom:140px;left:20px;display:flex;align-items:center;z-index:1000;padding:8px;width:auto;min-width:50px;height:50px;max-width:50px;overflow:visible;border-radius:25px;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 15px #0000004d;transform:scale(1);transition:max-width .4s ease-out,background-color .3s ease,box-shadow .3s ease,transform .2s ease}.notification-area-wrapper.active-notification-wrapper{max-width:320px;background-color:var(--primary-color);box-shadow:0 4px 20px #0f86;transform:scale(1.02)}.notification-area-wrapper:hover{transform:scale(1.05)}.notification-area-wrapper:active{transform:translateY(0)}#open-announcement-button{background:none;border:none;box-shadow:none;padding:0;border-radius:50%;width:34px;height:34px;display:flex;justify-content:center;align-items:center;font-size:1.4rem;color:#fff;cursor:pointer;transition:transform .2s ease;position:relative;flex-shrink:0;z-index:1}#open-announcement-button:hover{transform:scale(1.1)}#open-announcement-button:active{transform:translateY(0)}.new-announcement-badge{position:absolute;top:-8px;right:-8px;width:16px;height:16px;background-color:#f44;border-radius:50%;border:2px solid rgba(0,0,0,.8);animation:pulse-badge 1.5s infinite;z-index:13;box-shadow:0 2px 8px #ff44444d}.announcement-preview-container{display:flex;align-items:center;gap:8px;flex-grow:1;overflow:hidden;white-space:nowrap;opacity:0;width:0;transition:opacity .3s ease-out .1s,width .4s ease-out;justify-content:space-between}.notification-area-wrapper.active-notification-wrapper .announcement-preview-container{opacity:1;width:250px}.announcement-preview-text{color:var(--button-text-color);font-size:.9em;font-weight:500;flex-shrink:1;min-width:0;text-overflow:ellipsis;overflow:hidden}.hide-announcement-preview-button{background:none;border:none;color:var(--button-text-color);font-size:1.2em;cursor:pointer;opacity:.7;transition:opacity .2s ease;flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.hide-announcement-preview-button:hover{opacity:1}.announcement-item .mark-as-read-button{background-color:var(--secondary-color);color:var(--button-text-color);border:none;border-radius:5px;padding:5px 10px;font-size:.85em;cursor:pointer;transition:background-color .2s ease;margin-top:10px;display:block;margin-left:auto}.announcement-item .mark-as-read-button:hover{background-color:var(--secondary-color-dark)}.announcement-item.read{opacity:.6}.announcement-item.read .mark-as-read-button{display:none}@keyframes pulse-badge{0%{transform:scale(1);opacity:1}70%{transform:scale(1.2);opacity:.7}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.announcement-panel{width:95%;height:90%;max-width:none;max-height:none}.panel-header{padding:12px 20px}.announcement-tabs .tab-button{padding:10px 18px;font-size:1em}.announcement-content{padding:15px}.announcement-item{padding:12px;margin-bottom:12px}.announcement-item h4{font-size:1em}.announcement-item p{font-size:.9em}.announcement-item small{font-size:.7em}#open-announcement-button{width:32px;height:32px;font-size:1.2rem}.new-announcement-badge{width:14px;height:14px;top:-6px;right:-6px}.notification-area-wrapper.active-notification-wrapper{max-width:280px}.notification-area-wrapper.active-notification-wrapper .announcement-preview-container{width:200px}.announcement-preview-text{font-size:.8em}.hide-announcement-preview-button{font-size:1em;width:18px;height:18px}}@media (max-width: 480px){.announcement-panel{width:100%;height:100%;border-radius:0;box-shadow:none;top:0;left:0;transform:translate(0)}.announcement-panel.active{transform:translate(0)}.panel-header{padding:10px 15px}.panel-header h3{font-size:1.2em}.announcement-tabs .tab-button{font-size:.9em;padding:8px 12px}.announcement-content{padding:10px}.announcement-item{padding:10px;margin-bottom:10px}.announcement-form{padding:5px;gap:10px}.announcement-form label,.announcement-form input[type=text],.announcement-form textarea,#publish-announcement-button{font-size:.9em}.notification-area-wrapper{bottom:120px;left:15px;width:10px!important}#open-announcement-button{font-size:1rem}.notification-area-wrapper.active-notification-wrapper{max-width:200px}.notification-area-wrapper.active-notification-wrapper .announcement-preview-container{width:130px}.announcement-preview-text{font-size:.7em}.hide-announcement-preview-button{font-size:.9em;width:16px;height:16px}}
