: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}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}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}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px}.auth-card{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:40px;width:100%;max-width:420px;box-shadow:0 8px 32px #0000004d;border:1px solid rgba(255,255,255,.1)}.auth-header{text-align:center;margin-bottom:30px}.auth-header h1{color:#ff6b35;font-size:2rem;margin-bottom:8px}.auth-header p{color:#fff9;font-size:.9rem}.auth-card h2{color:#fff;text-align:center;margin-bottom:25px;font-size:1.5rem}.form-group{margin-bottom:20px}.form-group label{display:block;color:#fffc;margin-bottom:8px;font-size:.9rem}.form-group input{width:100%;padding:12px 15px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#fff;font-size:1rem;transition:all .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#ff6b35;background:#ffffff26}.form-group input::placeholder{color:#fff6}.btn-primary{width:100%;padding:14px;background:linear-gradient(135deg,#ff6b35,#f7931e);border:none;border-radius:10px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #ff6b3566}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.error-alert{background:#dc354533;border:1px solid rgba(220,53,69,.5);color:#ff6b6b;padding:12px;border-radius:10px;margin-bottom:15px;text-align:center}.success-alert{background:#28a74533;border:1px solid rgba(40,167,69,.5);color:#51cf66;padding:12px;border-radius:10px;margin-bottom:15px;text-align:center}.auth-footer{text-align:center;margin-top:25px;color:#fff9}.auth-footer a{color:#ff6b35;text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.dashboard.dark{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: rgba(255, 255, 255, .05);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .6);--border-color: rgba(255, 255, 255, .1);--accent-color: #ff6b35}.dashboard.light{--bg-primary: #f5f5f7;--bg-secondary: #ffffff;--bg-tertiary: #f0f0f0;--text-primary: #1a1a1a;--text-secondary: #666666;--border-color: #e0e0e0;--accent-color: #e94560}.dashboard{display:flex;min-height:100vh;background:var(--bg-primary);transition:background .3s}.sidebar{width:220px;background:var(--bg-secondary);display:flex;flex-direction:column;border-right:1px solid var(--border-color)}.sidebar-header{padding:20px;border-bottom:1px solid var(--border-color)}.sidebar-header h1{color:var(--accent-color);font-size:1.3rem;margin:0}.nav-links{list-style:none;padding:0;margin:0;flex:1}.nav-links li{padding:15px 20px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.nav-links li:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-links li.active{background:#ff6b3533;color:var(--accent-color);border-left:3px solid var(--accent-color)}.sidebar-footer{padding:20px;border-top:1px solid var(--border-color)}.user-info{margin-bottom:15px}.user-info span{display:block;color:var(--text-primary);font-weight:500}.user-info small{color:var(--text-secondary)}.btn-logout{width:100%;padding:10px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:background .2s}.btn-logout:hover{background:var(--border-color)}.main-content{flex:1;padding:30px;overflow-y:auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:15px}.dashboard-header h2{color:var(--text-primary);margin:0}.header-right{display:flex;align-items:center;gap:15px}.status-badge{padding:8px 16px;border-radius:20px;font-size:.9rem}.status-badge.connected{background:#28a74533;color:#51cf66}.status-badge.disconnected{background:#ef444433;color:#ef4444}.theme-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:5px}.user-badge{color:var(--text-secondary);font-size:.9rem}.sites-overview{background:var(--bg-tertiary);border-radius:16px;padding:25px;border:1px solid var(--border-color)}.sites-overview h3{color:var(--text-primary);margin:0 0 20px;font-size:1.2rem}.alarm-banner{background:linear-gradient(135deg,#e94560,#ff6b6b);color:#fff;padding:12px 20px;border-radius:8px;margin-bottom:20px;font-weight:600;text-align:center;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.sites-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.site-card{background:var(--bg-secondary);border-radius:16px;padding:20px;border:2px solid var(--border-color);cursor:pointer;transition:all .3s}.site-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0003}.site-card.site-online{border-color:#22c55e}.site-card.site-online:hover{box-shadow:0 10px 30px #22c55e33}.site-card.site-offline{border-color:#666;opacity:.7}.site-card.site-alarm{border-color:#ef4444;background:linear-gradient(135deg,#ef44441a,#ef444433);animation:alarmPulse 1s infinite}@keyframes alarmPulse{0%,to{border-color:#ef4444}50%{border-color:#ff6b6b}}.site-card.site-alarm:hover{box-shadow:0 10px 30px #ef44444d}.site-card.site-fault{border-color:#f59e0b;background:linear-gradient(135deg,#f59e0b1a,#f59e0b26)}.site-card.site-supervisory{border-color:#eab308;background:linear-gradient(135deg,#eab3081a,#eab30826)}.site-card-states{margin:10px 0}.state-badges{display:flex;flex-wrap:wrap;gap:4px}.state-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.state-badge.online{background:#22c55e33;color:#22c55e}.state-badge.offline{background:#73737333;color:#737373}.site-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.status-icon{font-size:1.2rem}.site-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-card-status{font-size:.9rem;font-weight:600;margin-bottom:8px}.site-card.site-online .site-card-status{color:#22c55e}.site-card.site-offline .site-card-status{color:#666}.site-card.site-alarm .site-card-status{color:#ef4444;text-transform:uppercase}.site-card.site-fault .site-card-status{color:#f59e0b}.site-card-city{font-size:.8rem;color:var(--text-secondary);margin-bottom:8px}.site-card-action{font-size:.85rem;color:#ef4444;font-weight:500;margin-top:10px;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.empty-state{text-align:center;padding:60px 20px}.empty-state p{color:var(--text-secondary);margin-bottom:20px}.btn-primary{background:linear-gradient(135deg,#ff6b35,#f7931e);border:none;padding:12px 24px;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ff6b3566}.loading{text-align:center;padding:40px;color:var(--text-secondary)}@media(max-width:1024px){.sites-card-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media(max-width:768px){.dashboard{flex-direction:column}.sidebar{width:100%;flex-direction:row;padding:10px}.nav-links{display:flex}.nav-links li{padding:10px 15px}.sidebar-footer{display:none}.dashboard-header{flex-direction:column;align-items:flex-start}.sites-card-grid{grid-template-columns:repeat(2,1fr);gap:12px}.site-card{padding:15px}}@media(max-width:480px){.sites-card-grid{grid-template-columns:1fr}}.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.site-card{background:#ffffff0d;border-radius:16px;padding:25px;border:1px solid rgba(255,255,255,.1)}.site-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.site-header h3{color:#fff;margin:0}.site-info{margin-bottom:20px}.site-info p{color:#ffffffb3;margin:5px 0}.site-actions{display:flex;gap:10px;margin-bottom:20px}.btn-watch{flex:1;padding:12px 20px;background:linear-gradient(135deg,#e94560,#ff6b6b);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s;font-size:.9rem}.btn-watch:hover{transform:translateY(-2px);box-shadow:0 4px 15px #e9456066}.btn-edit{flex:0 0 auto;padding:12px 20px;background:#4dabf733;border:1px solid rgba(77,171,247,.5);border-radius:8px;color:#4dabf7;font-weight:600;cursor:pointer;transition:all .3s;font-size:.9rem}.btn-edit:hover{background:#4dabf74d;transform:translateY(-2px)}.api-key-display{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#0003;border-radius:6px;margin-bottom:10px}.api-key-display code{color:#4dabf7;font-size:.85rem}.api-key-display .active{color:#51cf66;font-size:.8rem}.api-key-display .inactive{color:#ff6b6b;font-size:.8rem}.btn-regenerate{background:#f59e0b33;border:1px solid rgba(245,158,11,.5);padding:8px 15px;border-radius:6px;color:#f59e0b;cursor:pointer;width:100%;margin-top:10px;transition:all .3s}.btn-regenerate:hover{background:#f59e0b4d}.api-keys-section{border-top:1px solid rgba(255,255,255,.1);padding-top:15px}.api-keys-section h4{color:#fff;margin:0 0 10px;font-size:.9rem}.api-keys-list{list-style:none;padding:0;margin:0 0 15px}.api-keys-list li{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05)}.api-keys-list code{color:#4dabf7;font-size:.85rem}.api-keys-list .active{color:#51cf66;font-size:.8rem}.api-keys-list .inactive{color:#ff6b6b;font-size:.8rem}.no-keys{color:#ffffff80;font-size:.9rem;margin:10px 0}.btn-create{background:linear-gradient(135deg,#ff6b35,#f7931e);border:none;padding:10px 20px;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s}.btn-create:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ff6b3566}.btn-generate{background:#4dabf733;border:1px solid rgba(77,171,247,.5);padding:8px 15px;border-radius:6px;color:#4dabf7;cursor:pointer;width:100%;margin-top:10px;transition:all .3s}.btn-generate:hover{background:#4dabf74d}.empty-state{text-align:center;padding:60px 20px;background:#ffffff0d;border-radius:16px}.empty-state h3{color:#fff;margin-bottom:10px}.empty-state p{color:#fff9;margin-bottom:20px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#1a1a2e;border-radius:16px;padding:30px;width:100%;max-width:450px;border:1px solid rgba(255,255,255,.1)}.modal h3{color:#fff;margin:0 0 20px}.modal .form-group{margin-bottom:15px}.modal .form-group label{display:block;color:#fffc;margin-bottom:8px;font-size:.9rem}.modal .form-group input{width:100%;padding:12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;box-sizing:border-box}.modal .form-group input:focus{outline:none;border-color:#ff6b35}.modal-actions{display:flex;gap:10px;margin-top:20px}.btn-cancel{flex:1;padding:12px;background:#ffffff1a;border:none;border-radius:8px;color:#fff;cursor:pointer}.modal-actions .btn-create{flex:1}.api-key-modal{max-width:550px}.api-key-modal .warning{color:#ffd93d;background:#ffd93d1a;padding:10px;border-radius:8px;margin-bottom:20px}.key-display{display:flex;gap:10px;margin-bottom:20px}.key-display code{flex:1;padding:15px;background:#0000004d;border-radius:8px;color:#51cf66;font-size:.9rem;word-break:break-all}.key-display button{padding:15px 20px;background:#4dabf733;border:1px solid rgba(77,171,247,.5);border-radius:8px;color:#4dabf7;cursor:pointer}.usage-hint{color:#ffffffb3;font-size:.9rem;margin-bottom:10px}.code-example{background:#0000004d;padding:15px;border-radius:8px;color:#4dabf7;font-size:.85rem;overflow-x:auto;margin-bottom:20px}.status-badge.pending{background:#ffd93d33;color:#ffd93d}.status-badge.approved{background:#51cf6633;color:#51cf66}.error-alert{background:#ff6b6b33;border:1px solid rgba(255,107,107,.5);color:#ff6b6b;padding:10px;border-radius:8px;margin-bottom:15px}.site-watch.dark{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-tertiary: #0f0f23;--text-primary: #ffffff;--text-secondary: #a0a0a0;--border-color: #333;--accent-color: #e94560;--success-color: #22c55e;--warning-color: #f59e0b;--danger-color: #ef4444}.site-watch.light{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #e0e0e0;--text-primary: #1a1a1a;--text-secondary: #666666;--border-color: #ddd;--accent-color: #e94560;--success-color: #16a34a;--warning-color: #d97706;--danger-color: #dc2626}.site-watch{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);color:var(--text-primary);font-family:Segoe UI,Tahoma,sans-serif}.watch-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:1rem}.back-btn{background:none;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:.25rem .5rem}.logo{font-size:1.25rem;font-weight:700;color:var(--accent-color)}.header-center{display:flex;align-items:center;gap:1rem}.site-name{font-size:1rem;font-weight:600}.connection-status{padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:500}.connection-status.online{background:#22c55e33;color:var(--success-color)}.connection-status.offline{background:#ef444433;color:var(--danger-color)}.header-right{display:flex;align-items:center;gap:.75rem}.sound-btn,.theme-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem}.user-name{color:var(--text-secondary);font-size:.875rem}.status-bar{display:flex;gap:2rem;padding:.5rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.status-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.status-item .label{color:var(--text-secondary)}.status-item .value{font-weight:500}.status-item .value.online{color:var(--success-color)}.status-item .value.offline{color:var(--danger-color)}.watch-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.event-table-container{flex:1;overflow:auto}.event-table{width:100%;border-collapse:collapse}.event-table thead{position:sticky;top:0;background:var(--bg-secondary);z-index:10}.event-table th{padding:.75rem 1rem;text-align:left;font-weight:600;border-bottom:2px solid var(--border-color);color:var(--text-secondary);font-size:.875rem}.event-table td{padding:.5rem 1rem;border-bottom:1px solid var(--border-color);font-size:.875rem}.event-table tbody tr:hover{background:#ffffff0d}.event-alarm{background:#ef444433!important}.event-alarm .condition{color:#f44;font-weight:700}.event-fault{background:#f59e0b26!important}.event-fault .condition{color:#f59e0b;font-weight:700}.event-supervisory{background:#3b82f626!important}.event-supervisory .condition{color:#3b82f6;font-weight:700}.no-events{text-align:center;padding:3rem!important;color:var(--text-secondary);font-style:italic}.action-bar{display:flex;justify-content:space-between;padding:1rem;background:var(--bg-secondary);border-top:1px solid var(--border-color);gap:1rem}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.75rem .5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;color:var(--text-primary);transition:all .2s;width:80px;height:70px;min-width:80px}.action-btn:hover{background:var(--border-color)}.action-btn.primary{background:var(--accent-color);border-color:var(--accent-color)}.action-btn .icon{font-size:1.25rem}.action-btn .label{font-size:.65rem;text-transform:uppercase;text-align:center;line-height:1.2}.stats-panel{display:flex;gap:2rem;padding:.5rem 1rem;background:var(--bg-tertiary);border-radius:.5rem;align-items:center}.stat-group{display:flex;flex-direction:column;gap:.25rem}.stat-title{font-size:.7rem;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.25rem}.stat-row{font-size:.875rem;font-weight:500}.stat-row.alarm{color:var(--danger-color)}.stat-row.fault{color:var(--warning-color)}.stat-row.supervisory{color:#3b82f6}.stat-row.disabled{color:#6366f1}.event-disabled{background:#6366f126!important}.event-disabled .condition{color:#6366f1;font-weight:700}.watch-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.25rem;color:var(--text-secondary)}@media(max-width:768px){.watch-header{flex-direction:column;gap:.5rem}.header-center,.header-right{width:100%;justify-content:center}.action-bar{flex-direction:column}.action-buttons{justify-content:center}.action-btn{padding:.5rem;min-width:60px}.stats-panel{justify-content:center}.event-table th,.event-table td{padding:.5rem;font-size:.75rem}}@media(max-width:480px){.action-btn .label{display:none}.action-btn .icon{font-size:1.5rem}}.events-page{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary, #0d1117);color:var(--text-primary, #c9d1d9)}.events-page.light{--bg-primary: #ffffff;--bg-secondary: #f6f8fa;--text-primary: #24292f;--text-secondary: #57606a;--border-color: #d0d7de}.events-page.dark{--bg-primary: #0d1117;--bg-secondary: #161b22;--text-primary: #c9d1d9;--text-secondary: #8b949e;--border-color: #30363d}.events-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.events-header .header-left{display:flex;align-items:center;gap:1rem}.events-header .logo{font-size:1.5rem;font-weight:700}.events-header h1{margin:0;font-size:1.25rem;font-weight:500}.events-header .header-right{display:flex;align-items:center;gap:1rem}.events-header .theme-btn{background:transparent;border:none;font-size:1.25rem;cursor:pointer}.events-content{flex:1;overflow:auto;padding:1rem}.events-table-container{background:var(--bg-secondary);border-radius:8px;overflow:hidden}.events-table{width:100%;border-collapse:collapse}.events-table th,.events-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.events-table th{background:#0000001a;font-weight:600;position:sticky;top:0}.events-table tbody tr:hover{background:#ffffff0d}.events-table .event-alarm{background:#dc262633}.events-table .event-alarm .condition{color:#ef4444;font-weight:700}.events-table .event-fault{background:#eab30833}.events-table .event-fault .condition{color:#eab308;font-weight:700}.events-table .event-supervisory{background:#f9731633}.events-table .event-supervisory .condition{color:#f97316;font-weight:700}.events-table .event-normal .condition{color:#22c55e}.no-events{text-align:center;color:var(--text-secondary);padding:2rem!important}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem}.pagination button{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination button:hover:not(:disabled){background:#ffffff1a}.events-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.5rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f0f1a;color:#fff;-webkit-font-smoothing:antialiased}.loading-screen{display:flex;justify-content:center;align-items:center;height:100vh;background:#0f0f1a;color:#fff9;font-size:1.2rem}a{color:#ff6b35;text-decoration:none}a:hover{text-decoration:underline}
