@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;500&display=swap";:root{--bg-dark:#2a363e;--bg-darker:#12191d;--brand-cyan:#00a3da;--brand-cyan-glow:#00a3da40;--brand-cyan-hover:#00bfff;--panel-bg:#1a2228d9;--panel-border:#00a3da33;--text-main:#fff;--text-muted:#8aa0ae;--status-online:#00e676;--status-online-glow:#00e67633;--status-offline:#ff1744;--status-offline-glow:#ff174433;--status-warning:#ff9100}*{box-sizing:border-box}body{background-color:var(--bg-darker);color:var(--text-main);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle at 15%,#00a3da14,#0000 25%),radial-gradient(circle at 85% 30%,#00a3da0d,#0000 25%),linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:100% 100%,100% 100%,30px 30px,30px 30px;background-attachment:fixed;min-height:100vh;margin:0;font-family:Outfit,sans-serif}.dashboard-container{max-width:1500px;margin:0 auto;padding:2rem}.header{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;margin-bottom:2.5rem;padding-bottom:1.5rem;display:flex}.brand-container{align-items:center;gap:2rem;display:flex}.brand-logo{object-fit:contain;filter:drop-shadow(0 0 8px #ffffff1a);height:50px}.client-selector{border:1px solid var(--panel-border);color:var(--brand-cyan);appearance:none;cursor:pointer;background:#0000004d url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2300A3DA' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e") right 1rem center/1em no-repeat;border-radius:12px;outline:none;padding:.75rem 3rem .75rem 1.5rem;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #0003}.client-selector:hover,.client-selector:focus{border-color:var(--brand-cyan);box-shadow:0 0 15px var(--brand-cyan-glow)}.client-selector option{background:var(--bg-darker);color:#fff}.header-status{color:var(--status-online);background:#00e6761a;border:1px solid #00e6764d;border-radius:20px;align-items:center;gap:10px;padding:8px 16px;font-size:.9rem;font-weight:500;display:flex}.live-dot{background:var(--status-online);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse-green}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--panel-border);border-radius:16px;padding:1.5rem;position:relative;box-shadow:0 12px 40px #0006,inset 0 1px #ffffff0d}.panel-title{color:var(--text-main);align-items:center;gap:.75rem;margin-top:0;margin-bottom:1.5rem;font-size:1.25rem;font-weight:600;display:flex}.dashboard-layout{grid-template-columns:2.5fr 1fr;gap:2rem;display:grid}@media (width<=1024px){.dashboard-layout{grid-template-columns:1fr}}.stats-row{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2.5rem;display:grid}.stat-card{background:linear-gradient(135deg,#1a2228e6 0%,#12191de6 100%);align-items:center;gap:1.5rem;padding:1.75rem 1.5rem;display:flex}.stat-icon{background:#ffffff08;border:1px solid #ffffff0d;border-radius:16px;justify-content:center;align-items:center;width:60px;height:60px;display:flex}.stat-info p{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin:0 0 5px;font-size:.95rem;font-weight:500}.stat-info h3{text-shadow:0 2px 10px #00000080;margin:0;font-size:2.5rem;font-weight:700;line-height:1}.locations-container{flex-direction:column;gap:2.5rem;display:flex}.location-group{background:#00000026;border:1px solid #ffffff08;border-radius:16px;padding:1.5rem}.location-title{color:var(--text-main);border-bottom:1px solid #ffffff0d;align-items:center;gap:8px;margin-top:0;margin-bottom:1.5rem;padding-bottom:.75rem;font-size:1.1rem;font-weight:600;display:flex}.location-count{color:var(--text-muted);font-size:.9rem;font-weight:400}.kiosk-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;display:grid}.kiosk-card{background:#00000040;border:1px solid #ffffff0d;border-radius:12px;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem 1rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative}.kiosk-card.online{border-bottom:2px solid #00e6764d}.kiosk-card.online:hover{border-color:var(--status-online);transform:translateY(-5px)scale(1.02);box-shadow:0 10px 20px #00e6761a}.kiosk-card.offline{background:#ff17440d;border-color:#ff174466}.kiosk-card.offline:hover{transform:translateY(-5px)scale(1.02);box-shadow:0 10px 20px #ff174426}.kiosk-card.degraded{background:#ff91000d;border-color:#ff910066}.kiosk-card.degraded:hover{transform:translateY(-5px)scale(1.02);box-shadow:0 10px 20px #ff910026}.status-indicator{border-radius:50%;width:14px;height:14px;position:relative}.kiosk-card.online .status-indicator{background:var(--status-online);box-shadow:0 0 10px var(--status-online)}.kiosk-card.offline .status-indicator{background:var(--status-offline);box-shadow:0 0 15px var(--status-offline);animation:1.5s infinite pulse-red}.kiosk-card.degraded .status-indicator{background:var(--status-warning);box-shadow:0 0 15px var(--status-warning);animation:1.5s infinite pulse-orange}.kiosk-name{text-align:center;color:var(--text-main);font-size:.95rem;font-weight:600}.kiosk-uptime{color:var(--text-muted);text-align:center;background:#ffffff0d;border-radius:4px;padding:2px 6px;font-size:.75rem}.events-list{flex-direction:column;gap:1rem;display:flex}.events-list::-webkit-scrollbar{width:6px}.events-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.event-item{border-left:4px solid var(--status-offline);cursor:pointer;background:#0000004d;border-radius:0 12px 12px 0;padding:1.25rem;transition:all .2s;position:relative}.event-item:hover{background:#ffffff0d;transform:translate(5px)}.event-item:before{content:"Ver Reporte";color:var(--brand-cyan);opacity:0;background:#00a3da1a;border-radius:4px;padding:4px 8px;font-size:.75rem;transition:opacity .2s;position:absolute;top:50%;right:15px;transform:translateY(-50%)}.event-item:hover:before{opacity:1}.event-header{justify-content:space-between;margin-bottom:.75rem;display:flex}.event-kiosk{color:var(--text-main);align-items:center;gap:6px;font-size:1.05rem;font-weight:700;display:flex}.event-location{color:var(--brand-cyan);align-items:center;gap:4px;margin-bottom:8px;font-size:.8rem;display:flex}.event-time{color:var(--text-muted);background:#ffffff14;border-radius:10px;padding:3px 8px;font-size:.8rem}.event-cause{color:#ff8a80;margin:0;font-size:.9rem;font-weight:500;line-height:1.4}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000bf;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-dark);border:1px solid var(--panel-border);border-radius:16px;width:90%;max-width:700px;max-height:90vh;animation:.3s slideUp;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0009}.modal-header{background:#0003;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.modal-header h2{color:var(--status-offline);align-items:center;gap:10px;margin:0;display:flex}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:5px;padding:5px;transition:all .2s}.close-btn:hover{color:#fff;background:#ffffff1a}.modal-body{padding:2rem}.alibi-section{background:#0003;border:1px solid #ffffff08;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.alibi-section h3{color:var(--brand-cyan);align-items:center;gap:8px;margin-top:0;margin-bottom:1rem;font-size:1.1rem;display:flex}.code-block{color:#a6accd;background:#0f141a;border:1px solid #ffffff0d;border-radius:8px;padding:1rem;font-family:Fira Code,monospace;font-size:.85rem;overflow-x:auto}.status-badge{border-radius:4px;padding:2px 8px;font-size:.8rem;font-weight:600;display:inline-block}.status-badge.disconnected{color:#ff8a80;background:#ff174433}.status-badge.up{color:#69f0ae;background:#00e67633}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-cyan{0%{box-shadow:0 0 #00a3da99}70%{box-shadow:0 0 0 8px #00a3da00}to{box-shadow:0 0 #00a3da00}}@keyframes pulse-green{0%{box-shadow:0 0 #00e67666}70%{box-shadow:0 0 0 8px #00e67600}to{box-shadow:0 0 #00e67600}}@keyframes pulse-red{0%{box-shadow:0 0 #ff174499}70%{box-shadow:0 0 0 12px #ff174400}to{box-shadow:0 0 #ff174400}}@keyframes pulse-orange{0%{box-shadow:0 0 #ff910099}70%{box-shadow:0 0 0 12px #ff910000}to{box-shadow:0 0 #ff910000}}.terminal-modal{font-family:Courier New,Courier,monospace}.quick-cmd-btn{border:1px solid var(--brand-cyan);color:var(--brand-cyan);cursor:pointer;background:#00a3da1a;border-radius:4px;padding:8px 12px;font-size:.85rem;transition:all .2s}.quick-cmd-btn:hover{background:var(--brand-cyan);color:#fff}.quick-cmd-btn.danger{border-color:var(--status-offline);color:var(--status-offline);background:#ff17441a}.quick-cmd-btn.danger:hover{background:var(--status-offline);color:#fff}.terminal-logs{background:#000;border:1px solid #ffffff1a;border-radius:6px;height:350px;margin-bottom:20px;padding:15px;overflow-y:auto;box-shadow:inset 0 0 10px #000c}.terminal-entry{border-bottom:1px dashed #ffffff1a;margin-bottom:15px;padding-bottom:15px}.terminal-entry:last-child{border-bottom:none;margin-bottom:0}.cmd-prompt{color:#fff;margin-bottom:5px;font-size:.95rem}.cmd-meta{color:var(--text-muted);margin-bottom:10px;font-size:.75rem}.cmd-output{color:#0f0;white-space:pre-wrap;word-break:break-all;background:#111;border-radius:4px;margin:0;padding:10px;font-size:.85rem;overflow-x:auto}.terminal-input-container{background:#00000080;border:1px solid #ffffff1a;border-radius:6px;align-items:center;gap:10px;padding:10px 15px;display:flex}.terminal-input{color:#fff;background:0 0;border:none;outline:none;flex:1;font-family:Courier New,Courier,monospace;font-size:1rem}.terminal-send-btn{color:var(--brand-cyan);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:5px;display:flex}.terminal-send-btn:hover{transform:scale(1.1)}
