: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}}body{justify-content:center;background-color:#0f172a}.app-container{padding:30px;font-family:system-ui,-apple-system,sans-serif;max-width:100vw;width:90vw;margin:0 auto;background-color:#0f172a;color:#e5e7eb;min-height:100vh}.app-header{padding-bottom:15px;margin-bottom:30px;display:flex;justify-content:space-between;align-items:center;gap:20px}.header-text-container{display:flex;flex-direction:column}.app-header h1{margin:0;color:#38bdf8;font-size:1.8rem}.app-header p{margin:5px 0 0;color:#94a3b8}.header-actions{display:flex;gap:15px;justify-content:center}.header-logo{height:50px;width:auto;object-fit:contain;transition:filter .3s ease-in-out}.header-logo:hover{filter:drop-shadow(0 0 12px rgba(56,189,248,.9));cursor:pointer}.nav{height:10vh}#menu-ctrl-tiempo{width:100%;position:sticky;top:0;z-index:1000;gap:25px;margin:-30px -30px 30px;box-shadow:0 4px 12px #0003;display:flex;align-items:center;padding:10px 20px;background-color:#0f172a;border-bottom:1px solid #1e293b}#menu-ctrl-tiempo h4{margin:0;color:#38bdf8;font-size:1.1rem;font-weight:600}.ctrl-tiempo-controles{display:flex;gap:20px;align-items:center}.ctrl-grupo{display:flex;align-items:center;gap:8px}.ctrl-grupo label{color:#e2e8f0;font-size:.95rem;font-weight:500;display:flex;align-items:center;cursor:pointer}.ctrl-grupo select,.ctrl-grupo input{padding:6px 12px;background-color:#0f172a;color:#f8fafc;border:1px solid #334155;border-radius:6px;font-size:.9rem;font-family:inherit;outline:none;transition:all .2s ease-in-out}.ctrl-grupo input{width:90px}.ctrl-grupo select:hover,.ctrl-grupo input:hover,.ctrl-grupo select:focus,.ctrl-grupo input:focus{border-color:#38bdf8;box-shadow:0 0 0 2px #38bdf833}.ctrl-grupo svg{transition:transform .3s ease}.ctrl-grupo svg:hover{transform:rotate(45deg)}.btn-navbar{background:transparent;border:none;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.btn-navbar:hover{background-color:#1e293b}.btn-navbar svg{stroke:#94a3b8;transition:stroke .2s}.btn-navbar:hover svg{stroke:#f8fafc}.dashboard-grid{display:flex;gap:25px;flex-wrap:wrap}.grafana-column h2,.ia-column h2{font-size:1.2rem;color:#f1f5f9}.grafana-column{display:inline;align-items:center;justify-content:center;flex:2;min-width:350px}.graph-section{margin-bottom:30px}.grafana-placeholder{border:1px solid #334155;border-radius:10px;height:fit-content;width:fit-content;display:flex;flex-direction:row;align-items:center;justify-content:center;color:#64748b;transition:all .3s ease}.grafana-placeholder iframe{width:100%}.grafana-placeholder:hover{border-color:#38bdf8;box-shadow:0 4px 20px #38bdf81a}.grafana-placeholder p{margin:0 0 10px}.grafana-placeholder code{background-color:#0f172a;padding:8px 12px;border-radius:6px;font-size:.9rem}.grafana-placeholder iframe{border:none;border-radius:10px;width:auto}.panel-chat{display:flex;flex-direction:column;height:65vh}.chat-mensajes{flex:1;overflow-y:auto;padding:15px 10px;display:flex;flex-direction:column;gap:12px;margin-bottom:15px;background-color:#020617;border-radius:6px;border:1px solid #1e293b}.chat-mensajes::-webkit-scrollbar{width:6px}.chat-mensajes::-webkit-scrollbar-track{background:#0f172a;border-radius:4px}.chat-mensajes::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}.chat-mensajes::-webkit-scrollbar-thumb:hover{background:#475569}.mensaje-wrapper{display:flex;width:100%}.mensaje-wrapper.usuario{justify-content:flex-end}.mensaje-wrapper.ia{justify-content:flex-start}.mensaje-burbuja{max-width:85%;padding:10px 14px;border-radius:8px;font-size:.95rem;line-height:1.4;word-wrap:break-word}.mensaje-burbuja.usuario{background-color:#2563eb;color:#fff;border-bottom-right-radius:0}.mensaje-burbuja.ia{background-color:#1e293b;color:#e2e8f0;border:1px solid #334155;border-bottom-left-radius:0}.chat-input-form{display:flex;gap:10px}.chat-input{flex:1;background-color:#0f172a;border:1px solid #334155;border-left:4px solid #1a8863;color:#f8fafc;padding:10px 15px;border-radius:6px;outline:none;font-family:inherit;transition:border-color .2s}.chat-input:focus{border-color:#38bdf8}.chat-input:disabled{opacity:.6;cursor:not-allowed}.chat-enviar-btn{background-color:#2563eb;color:#fff;border:none;border-radius:6px;width:45px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s}.chat-enviar-btn:hover:not(:disabled){background-color:#1d4ed8}.chat-enviar-btn:disabled{background-color:#475569;cursor:not-allowed}.escribiendo .punto{animation:parpadeo 1.4s infinite both;font-size:1.2rem;line-height:1}.escribiendo .punto:nth-child(1){animation-delay:0s}.escribiendo .punto:nth-child(2){animation-delay:.2s}.escribiendo .punto:nth-child(3){animation-delay:.4s}@keyframes parpadeo{0%{opacity:.2}20%{opacity:1}to{opacity:.2}}.mensaje-burbuja p{margin:0 0 8px}.mensaje-burbuja p:last-child{margin:0}.mensaje-burbuja strong{font-weight:700;color:#38bdf8}.mensaje-burbuja ul,.mensaje-burbuja ol{margin-top:5px;margin-bottom:5px;padding-left:20px}.mensaje-burbuja li{margin-bottom:3px}.mensaje-burbuja code{background-color:#0000004d;padding:2px 5px;border-radius:4px;font-family:monospace;font-size:.9em}.legend-box{margin-top:20px;padding:15px;background-color:#1e293b;border-radius:8px;border-left:4px solid #38bdf8;width:fit-content}.legend-box p{margin:0;font-size:.95em;color:#cbd5e1}.ia-column{flex:1;min-width:300px}.ia-card{border-radius:10px;padding:25px;background-color:#1e293b;transition:all .3s ease}.ia-card h3{margin-top:0;display:flex;align-items:center;gap:10px;font-size:1.1rem}.status-indicator{display:inline-block;width:12px;height:12px;border-radius:50%;transition:all .3s ease}.diagnosis-text{line-height:1.6;font-size:1.05rem;color:#f8fafc}.divIA{background-color:#0f172a;border:1px solid #334155;border-radius:10px;padding:20px;margin-top:20px;transition:all .3s ease}.divIA:hover{border-color:#38bdf8;box-shadow:0 4px 20px #38bdf81a}.ia-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.ia-title{margin:0;color:#e2e8f0;display:flex;align-items:center;gap:8px}.ia-button{background-color:#2563eb;color:#fff;border:none;padding:8px 16px;border-radius:5px;cursor:pointer;font-weight:700;transition:background-color .2s}.ia-button:disabled{background-color:#475569;cursor:not-allowed}.ia-diagnosis-box{background-color:#020617;padding:15px;border-radius:5px;font-family:monospace;min-height:80px}.diagnosis-alert{color:#ef4444;border-left:4px solid #ef4444}.diagnosis-safe{color:#10b981;border-left:4px solid #10b981}.alert-safe{border:2px solid #10b981;box-shadow:0 4px 20px #10b9810d}.alert-safe h3{color:#10b981}.alert-safe .status-indicator{background-color:#10b981;box-shadow:0 0 10px #10b981}.alert-danger{border:2px solid #ef4444;box-shadow:0 4px 20px #ef444426}.alert-danger h3{color:#ef4444}.alert-danger .status-indicator{background-color:#ef4444;box-shadow:0 0 12px #ef4444}.btn-logout{margin-right:20px}.button-group{display:flex;gap:10px;margin-top:30px}.btn-alert,.btn-restore{flex:1;padding:10px;border-radius:6px;cursor:pointer;font-weight:700;transition:background-color .2s}.btn-alert{background-color:#ef4444;color:#fff;border:none}.btn-alert:hover{background-color:#dc2626}.btn-restore{background-color:transparent;color:#cbd5e1;border:1px solid #475569}.btn-restore:hover{background-color:#334155}.btn-navbar{background-color:transparent;color:#cbd5e1;border:none;padding:2px 4px;border-radius:3px;font-size:.9rem;font-family:inherit;outline:none;transition:all .2s ease-in-out}.btn-navbar:hover{background-color:#0d1725;color:#38bdf8}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#0f172a;background-image:radial-gradient(circle at center,#1e293b,#0f172a)}.login-box{background-color:#1e293b;padding:40px;border-radius:12px;box-shadow:0 10px 25px #00000080;width:100%;max-width:400px;text-align:center;border:1px solid #334155}.login-logo{height:60px;margin-bottom:20px;filter:drop-shadow(0 0 10px rgba(56,189,248,.5))}.login-box h2{color:#f1f5f9;margin:0 0 5px;font-size:1.5rem}.login-subtitle{color:#94a3b8;margin-bottom:30px;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:20px;text-align:left}.input-group label{display:block;color:#cbd5e1;margin-bottom:8px;font-size:.9rem;font-weight:500}.input-group input{width:100%;padding:12px;border-radius:6px;border:1px solid #475569;background-color:#0f172a;color:#f1f5f9;font-size:1rem;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.input-group input:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 2px #38bdf833}.btn-login{background-color:#0284c7;color:#fff;padding:12px;border:none;border-radius:6px;font-size:1rem;font-weight:700;cursor:pointer;margin-top:10px;transition:background-color .2s}.btn-login:hover{background-color:#0369a1}.error-message{color:#ef4444;background-color:#ef44441a;padding:10px;border-radius:6px;font-size:.85rem;border:1px solid rgba(239,68,68,.2);text-align:center}.sidebar-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1001;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.sidebar-overlay.visible{opacity:1;visibility:visible}.app-sidebar{position:fixed;top:0;left:-300px;width:280px;height:100vh;background-color:#0f172a;border-right:1px solid #1e293b;z-index:1002;transition:left .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:4px 0 15px #0000004d}.app-sidebar.abierta{left:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #1e293b}.sidebar-header h2{margin:0;font-size:1.2rem;color:#f8fafc}.btn-close-sidebar{background:transparent;border:none;cursor:pointer;padding:5px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.btn-close-sidebar:hover{background-color:#1e293b}.sidebar-nav{padding:20px 10px;display:flex;flex-direction:column;gap:10px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 15px;background:transparent;border:none;border-radius:8px;color:#cbd5e1;font-size:1rem;font-weight:500;text-align:left;cursor:pointer;transition:all .2s ease}.sidebar-link:hover{background-color:#1e293b;color:#f8fafc}.sidebar-link.activo{background-color:#38bdf81a;color:#38bdf8;border-left:3px solid #38bdf8}.sidebar-link svg{flex-shrink:0}#graph-potencia,#graph-factor-potencia,#graph-eapm{width:100%;height:45vh}#graph-t-ll,#graph-t-ln{width:100%;height:50vh}#grafana-corrientes{width:40vw}#graph-corrientes{height:30vh;width:100%}#grafana-frecuencia{width:20vw}#graph-frecuencia{height:30vh;width:100%}#graph-corrientes-timerange{width:100%;height:40vh}#graph-tensiones-timerange{width:100%;height:49vh}#graph-frecuencia-timerange{width:100%;height:30vh}#graph-potencia-apf{width:100%;height:45vh}#grafana-factores-potencia{width:60%}#graph-factor-pf{width:60%;height:40vh}#graph-factor-pt{width:40%;height:40vh}.grafana-placeholder{width:100%;margin-bottom:1vh}.grafana-placeholder iframe{border:none;border-radius:0;width:100%}#grafana-clima-1{display:flex;align-content:flex-start;align-items:flex-start;height:55vh;flex-wrap:wrap}#grafana-clima-1 .subdashboard-1{width:33.33%;height:40%}#grafana-clima-1 .subdashboard-1.lr{width:33.33%;height:20%}#organizador-2x2{display:flex;flex-direction:row;flex-wrap:wrap;height:fit-content;align-items:stretch}#organizador-2x2 div{width:100%}#porcentajes-eventos{display:flex;height:50vh;width:100%}#porcentajes-eventos iframe{height:100%;width:100%}#grafana-probabilidades-promedios{display:flex;height:50vh;width:100%}#grafana-probabilidades-promedios iframe{height:100%}#graph-probabilidades-semanal{height:100%;width:25%}#graph-promedio-dias-entre-eventos,#graph-tiempo-anticipado-evento{height:100%;width:37.5%}#tiempo-entre-eventos{display:flex;height:40vh;width:100%}#tiempo-entre-eventos iframe{height:100%;width:50%}#distribucion-tiempo-entre-eventos{height:40vh;width:100%}#distribucion-tiempo-entre-eventos iframe{height:100%;width:100%}#itic-por-linea{display:flex;align-items:stretch;height:60vh;width:100%;flex-direction:column}#itic-por-linea iframe{height:33.33%;width:100%}#grafana-conducta-predictiva{height:30vh}#grafana-conducta-predictiva iframe{height:100%}#graph-edo-actual-pa{width:30%}#graph-potencia-activa-estandarizada,#graph-desviacion-estandar-pa{height:30vh}#graph-curva-itic{width:100%;height:80vh;border:none}#graph-leyenda-curva-itic{width:100%;height:68vh;border:none}#graph-ceraunicos-vzla{width:100%;height:80vh;border:none}
