*{margin:0;padding:0;box-sizing:border-box}.login-container{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;font-family:Plus Jakarta Sans,-apple-system,sans-serif}.login-left{background:#fff;display:flex;flex-direction:column;justify-content:space-between;padding:60px 80px;overflow-y:auto}.login-content{width:100%;max-width:480px}.login-logo{display:flex;align-items:center;gap:16px;margin-bottom:48px}.logo-image{width:60px;height:60px;object-fit:contain;flex-shrink:0}.logo-text h1{font-size:28px;font-weight:700;color:#103f73;margin:0;line-height:1}.logo-text span{font-size:12px;font-weight:600;color:#0b853f;letter-spacing:1px}.login-header{margin-bottom:32px}.login-header h2{font-size:32px;font-weight:700;color:#1a202c;margin:0 0 12px}.login-header p{font-size:14px;color:#3a424d;line-height:1.6;margin:0}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{position:relative;display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:600;color:#2d3748}.form-group input{padding:14px 16px;border:1px solid #cbd5e0;border-radius:8px;font-size:14px;transition:all .2s;outline:none;background:#fff}.form-group input::placeholder{color:#a0aec0}.form-group input:focus{border-color:#0f4c75;box-shadow:0 0 0 3px #0f4c751a}.form-group input:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.6}.password-toggle{position:absolute;right:16px;top:50%;transform:translateY(-50%);cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity .2s;display:flex;align-items:center;justify-content:center;margin-top:12px}.password-toggle:hover{opacity:.8}.eye-icon{font-size:20px;opacity:.6;display:flex;align-items:center;line-height:1}.form-options{display:flex;justify-content:space-between;align-items:center;margin-top:-8px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:13px;color:#4a5568;cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.forgot-link{font-size:13px;color:#103f73;text-decoration:none;font-weight:500;background:none;border:none;cursor:pointer;padding:0;transition:all .2s ease}.forgot-link:hover{text-decoration:underline;color:#0f4c75}.error-message{padding:12px 16px;background-color:#fed7d7;color:#c53030;border-radius:8px;font-size:13px;text-align:center;border-left:4px solid #c53030}.button-wrapper{position:relative;margin-top:8px}.login-button{width:100%;padding:16px;background:#103f73;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s;position:relative}.border-animation{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:8px;pointer-events:none;border:2px solid transparent;transition:all .6s ease}.button-wrapper:hover .border-animation{border-top-color:#0b853f;border-right-color:#0b853f;border-bottom-color:#0b853f;border-left-color:#0b853f;transition:border-top-color .15s ease 0s,border-right-color .15s ease .15s,border-bottom-color .15s ease .3s,border-left-color .15s ease .45s}.button-wrapper:hover .login-button:not(:disabled){transform:translateY(-1px);box-shadow:0 0 20px #0b853f99,0 0 40px #0b853f66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.toggle-mode{margin-top:32px;text-align:center;font-size:13px;color:#4a5568}.toggle-mode span{margin-right:4px}.toggle-button{background:none;border:none;color:#103f73;font-weight:600;cursor:pointer;padding:0;font-size:13px;text-decoration:none}.toggle-button:hover:not(:disabled){text-decoration:underline}.toggle-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{display:flex;justify-content:space-between;align-items:center;margin-top:40px;padding-top:24px;border-top:1px solid #e2e8f0;font-size:12px;color:#a0aec0}.footer-links{display:flex;gap:20px}.footer-links a{color:#1a3056;text-decoration:none;font-weight:500}.footer-links a:hover{text-decoration:underline}.login-right{position:relative;background-size:cover;background-position:center;overflow:hidden;transition:background-image .3s ease}.image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;padding:60px}.gradient-overlay{position:absolute;top:0;right:0;bottom:0;left:0;transition:background .3s ease}.login-right.light-mode .gradient-overlay{background:linear-gradient(180deg,#1a365d33,#0f4c7566,#1a365d80)}.login-right.dark-mode .gradient-overlay{background:linear-gradient(180deg,#0003,#103f7366,#0009)}@media(max-width:1024px){.login-container{grid-template-columns:1fr}.login-right{display:none}.login-left{padding:40px;justify-content:center}.login-content{max-width:100%}}@media(max-width:640px){.login-left{padding:24px}.login-logo{margin-bottom:32px}.login-header h2{font-size:24px}.login-footer{flex-direction:column;gap:16px;text-align:center}.footer-links{flex-direction:column;gap:12px}}.sunrise-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:radial-gradient(circle at 50% 100%,gold,#ffb347,#ff8c69,#ff6b9d 30%,#c471ed,#12cad6,#87ceeb,#b0e0e6 90%,#e0f7ff);animation:sunriseReveal 2s ease-in-out forwards;display:flex;align-items:center;justify-content:center;pointer-events:none;clip-path:circle(0% at 50% 100%)}.sunrise-overlay .sun{position:fixed;bottom:-60px;left:50%;transform:translate(-50%);font-size:120px;animation:sunRise 2s ease-in-out forwards;filter:drop-shadow(0 0 80px rgba(255,165,0,1)) drop-shadow(0 0 150px rgba(255,215,0,.8))}@keyframes sunriseReveal{0%{clip-path:circle(0% at 50% 100%);background:radial-gradient(circle at 50% 100%,gold,#ffb347,#ff8c69,#ff6b9d 30%,#c471ed,#12cad6,#87ceeb,#b0e0e6 90%,#e0f7ff)}80%{clip-path:circle(150% at 50% 100%);background:radial-gradient(circle at 50% 0%,#e0f7ff,#b0e0e6,#87ceeb 40%,#87ceeb);opacity:1}to{clip-path:circle(150% at 50% 100%);background:radial-gradient(circle at 50% 0%,#e0f7ff,#b0e0e6,#87ceeb 40%,#87ceeb);opacity:0}}@keyframes sunRise{0%{bottom:-60px;filter:drop-shadow(0 0 60px rgba(255,165,0,.8)) drop-shadow(0 0 100px rgba(255,215,0,.6))}50%{filter:drop-shadow(0 0 100px rgba(255,179,71,1)) drop-shadow(0 0 180px rgba(255,140,105,.9))}to{bottom:calc(100vh + 60px);filter:drop-shadow(0 0 120px rgba(255,215,0,1)) drop-shadow(0 0 200px rgba(255,165,0,.8))}}.login-button.submitting{background:linear-gradient(135deg,orange,gold);color:#fff;font-size:32px;animation:buttonPulse 1s ease-in-out infinite}@keyframes buttonPulse{0%,to{transform:scale(1);box-shadow:0 0 20px #ffa50099}50%{transform:scale(1.05);box-shadow:0 0 40px #ffa500e6,0 0 60px #ffd70099}}.dashboard-skeleton{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:linear-gradient(135deg,#0f4c75,#1a365d);display:flex;flex-direction:column;animation:skeletonFadeIn .5s ease-in}@keyframes skeletonFadeIn{0%{opacity:0}to{opacity:1}}.skeleton-header{height:80px;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;padding:0 40px;gap:24px}.skeleton-logo{width:56px;height:56px;background:#ffffff1a;border-radius:12px;animation:skeletonPulse 1.5s ease-in-out infinite}.skeleton-title{width:200px;height:32px;background:#ffffff1a;border-radius:8px;animation:skeletonPulse 1.5s ease-in-out infinite .2s}.skeleton-actions{margin-left:auto;width:150px;height:40px;background:#ffffff1a;border-radius:8px;animation:skeletonPulse 1.5s ease-in-out infinite .4s}.skeleton-carousel{flex:1;display:flex;flex-direction:column;padding:40px;gap:24px}.skeleton-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;height:150px}.skeleton-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;animation:skeletonPulse 1.5s ease-in-out infinite}.skeleton-card:nth-child(1){animation-delay:.1s}.skeleton-card:nth-child(2){animation-delay:.2s}.skeleton-card:nth-child(3){animation-delay:.3s}.skeleton-card:nth-child(4){animation-delay:.4s}.skeleton-main{flex:1;display:flex;gap:24px}.skeleton-chart{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;animation:skeletonPulse 1.5s ease-in-out infinite .5s;position:relative;overflow:hidden}.skeleton-chart:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;height:60%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);animation:skeletonShimmer 2s infinite}.skeleton-footer{height:60px;background:#ffffff0d;border-top:1px solid rgba(255,255,255,.1);animation:skeletonPulse 1.5s ease-in-out infinite .6s}@keyframes skeletonPulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes skeletonShimmer{0%{transform:translate(-150%,-50%)}to{transform:translate(150%,-50%)}}.forgot-success-icon{font-size:4rem;margin-bottom:1rem;display:block}.forgot-info-box{display:flex;align-items:center;gap:12px;background:#f0fdf4;border:1px solid #86efac;border-radius:12px;padding:16px 20px;margin-bottom:24px}.forgot-info-box .info-icon{font-size:1.5rem;flex-shrink:0}.forgot-info-box p{margin:0;font-size:14px;color:#166534;line-height:1.5}@media(prefers-color-scheme:dark){.forgot-info-box{background:#22c55e1a;border-color:#22c55e4d}.forgot-info-box p{color:#86efac}}:root{--primary: #0f4c75;--primary-light: #3282b8;--accent: #0b853f;--accent-light: #0b853f;--solar: #f7b731;--solar-glow: #ffd166;--consumption: #ef476f;--grid: #7209b7;--bg-main: #f0f4f8;--bg-card: rgba(255, 255, 255, .9);--text-primary: #1a202c;--text-secondary: #4a5568;--text-muted: #3a424d;--shadow-md: 0 4px 20px rgba(0, 0, 0, .08);--radius-md: 16px;--radius-lg: 24px}@media(prefers-color-scheme:dark){:root{--text-secondary: #8b949e}}.tv-dashboard.dark{--bg-main: #0d1117;--bg-card: rgba(22, 27, 34, .95);--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #6e7681}.tv-dashboard{height:100vh;background:var(--bg-main);color:var(--text-primary);font-family:Plus Jakarta Sans,-apple-system,sans-serif;overflow:hidden;position:relative;display:flex;flex-direction:column}.tv-dashboard:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 20%,rgba(0,168,150,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(15,76,117,.08) 0%,transparent 50%);pointer-events:none;z-index:0}.tv-header{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:14px 32px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(0,0,0,.06);position:relative;z-index:10;flex-shrink:0}.header-left{display:flex;align-items:center}.logo-container{display:flex;align-items:center;gap:16px}.logo-icon{width:56px;height:56px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);padding:8px}.logo-icon img{width:100%;height:100%;object-fit:contain}.header-title h1{font-size:1.5rem;font-weight:700;margin:0;line-height:1}.header-title h1 .brand-primary,.header-title h1 .brand-accent{font-size:inherit;font-weight:inherit;line-height:inherit}.header-title h1 .brand-primary{color:#103f73}.header-title h1 .brand-accent{color:#0b853f}.tv-dashboard.dark .header-title h1 .brand-primary{color:#103f73}.tv-dashboard.dark .header-title h1 .brand-accent{color:#0b853f}.header-title>span{font-size:.9rem;color:var(--text-muted);font-weight:500}.header-right{display:flex;align-items:center;gap:16px}.status-badge{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#00a8961a,#02c39a1a);border:1px solid rgba(0,168,150,.2);border-radius:999px;font-size:.9rem;font-weight:600;color:var(--accent);transition:all .3s ease}.status-badge.disconnected{background:linear-gradient(135deg,#ef476f1a,#ff63841a);border:1px solid rgba(239,71,111,.3);color:#ef476f}.status-dot{width:10px;height:10px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite}.status-dot.disconnected{background:#ef476f;animation:none;opacity:.8}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.current-time{font-family:JetBrains Mono,monospace;font-size:.95rem;color:var(--text-muted)}.btn-icon{width:44px;height:44px;border-radius:12px;border:1px solid rgba(0,0,0,.08);background:var(--bg-card);cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .3s}.btn-icon:hover{transform:translateY(-2px)}.btn-logout{padding:10px 20px;border-radius:12px;border:none;background:linear-gradient(135deg,#fc8181,#f56565);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-logout:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5656566}.btn-admin-back{padding:10px 20px;border-radius:12px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:6px}.btn-admin-back:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.page-indicators{display:flex;justify-content:center;gap:12px;padding:20px 16px;margin-top:auto;position:relative;z-index:10;flex-shrink:0}.indicator{width:12px;height:12px;border-radius:50%;border:2px solid var(--accent);background:transparent;cursor:pointer;transition:all .3s}.indicator.active{background:var(--accent);width:40px;border-radius:6px}.carousel-container{position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column;min-height:0}.carousel-wrapper{display:flex;transition:transform .8s cubic-bezier(.4,0,.2,1);height:100%;width:100%;align-items:flex-start}.carousel-page{min-width:100%;width:100%;height:100%;flex-shrink:0;display:flex;flex-direction:column;padding:1.25vh 2vw;box-sizing:border-box;overflow:auto}.carousel-page>div{height:100%;display:flex;flex-direction:column;gap:1.5vh}.carousel-page>div>.stats-cards{flex:0 0 auto}.carousel-page>div>.live-panel{flex:1;display:flex;flex-direction:column;min-height:0;max-height:68vh}.stats-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-md);border:1px solid rgba(0,0,0,.08);transition:all .3s;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#0b853f,#103f73);opacity:1;transition:opacity .3s}.tv-dashboard.dark .stat-card{border:1px solid rgba(255,255,255,.1)}.stat-card-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-icon.solar{background:linear-gradient(135deg,#f7b73133,#ffd16633)}.stat-icon.co2{background:linear-gradient(135deg,#00a89633,#02c39a33)}.stat-icon.trees{background:linear-gradient(135deg,#10b98133,#34d39933)}.stat-icon.footprint{background:linear-gradient(135deg,#0f4c7533,#3282b833)}.stat-card .stat-label{font-size:1.75rem;color:var(--text-secondary);font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1)}.stat-card .stat-value{font-family:JetBrains Mono,monospace;font-size:2.2rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:6px;text-shadow:0 1px 3px rgba(0,0,0,.15)}.stat-card .stat-unit{font-size:1.25rem;color:var(--text-secondary);font-weight:500;opacity:.9}.reduction{color:var(--accent);font-weight:700}.live-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:1.2vh 1.2vw;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.live-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#0b853f,#103f73);opacity:0;transition:opacity .3s}.live-panel:hover:before{opacity:1}.live-panel .chart-container{flex:1;min-height:0;position:relative}.live-panel .chart-container canvas{width:100%!important;height:100%!important}.panel-title{font-size:1rem;font-weight:700;display:flex;align-items:center;gap:.5vw;margin-bottom:1vh}.panel-icon{width:2.5vh;height:2.5vh;border-radius:.5vh;background:linear-gradient(135deg,var(--solar) 0%,var(--solar-glow) 100%);display:flex;align-items:center;justify-content:center;font-size:.8rem}.live-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1vh;margin-bottom:1vh}.live-stat{text-align:center;padding:1vh .5vw;background:#00000005;border-radius:var(--radius-md);transition:all .3s}.tv-dashboard.dark .live-stat{background:#ffffff05}.live-stat:hover{transform:scale(1.02)}.live-stat-icon{font-size:1.4rem;display:block;margin-bottom:.5vh}.live-stat-value{font-family:JetBrains Mono,monospace;font-size:1.3rem;font-weight:700;line-height:1.1}.live-stat-value.solar{color:var(--solar)}.live-stat-value.consumption{color:var(--consumption)}.live-stat-value.coverage{color:var(--accent)}.live-stat-label{font-size:1.4rem;color:var(--text-muted);font-weight:500;margin-top:8px}.live-stat-unit{font-size:1rem;color:var(--text-muted)}.production-badge{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#00a8961a,#10b9811a);border:1px solid rgba(0,168,150,.2);padding:12px 20px;border-radius:999px}.production-dot{width:10px;height:10px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite;box-shadow:0 0 10px var(--accent)}.production-dot.inactive{background:#666;animation:none;box-shadow:none;opacity:.5}.production-text{font-size:.85rem;font-weight:600;color:var(--accent)}.production-text strong{color:var(--text-primary)}.flow-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:1.2vh 1.2vw;box-shadow:var(--shadow-md);flex:1;display:flex;flex-direction:column;min-height:0;max-height:85vh;position:relative;overflow:hidden}.flow-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#0b853f,#103f73);opacity:0;transition:opacity .3s}.flow-panel:hover:before{opacity:1}.flow-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:auto auto;gap:1vh;align-items:center;padding:1vh 0}.flow-node{display:flex;flex-direction:column;align-items:center;gap:.5vh;padding:1vh .5vw;background:#00000005;border-radius:var(--radius-md);transition:all .3s}.tv-dashboard.dark .flow-node{background:#ffffff05}.flow-node:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.flow-node-icon{width:4vh;height:4vh;border-radius:.8vh;display:flex;align-items:center;justify-content:center;font-size:1.4rem}.flow-node-icon.solar-icon{background:linear-gradient(135deg,var(--solar) 0%,var(--solar-glow) 100%);box-shadow:0 4px 20px #f7b73166}.flow-node-icon.inverter-icon{background:linear-gradient(135deg,#64748b,#94a3b8);box-shadow:0 4px 20px #64748b66}.flow-node-icon.building-icon{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);box-shadow:0 4px 20px #0f4c7566}.flow-node-icon.consumption-icon{background:linear-gradient(135deg,var(--consumption) 0%,#f472b6 100%);box-shadow:0 4px 20px #ef476f66}.flow-node-label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.flow-node-value{font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:700;color:var(--text-primary)}.flow-node-unit{font-size:.75rem;color:var(--text-muted)}.neutrality-node{grid-column:3;grid-row:1 / 3;align-self:center}.grid-node{grid-column:4;grid-row:2;background:linear-gradient(135deg,#7209b71a,#a855f71a);border:1px solid rgba(114,9,183,.2);min-height:140px;display:flex;flex-direction:column;justify-content:center}.tv-dashboard.dark .grid-node{border-color:#a855f74d}.price-node{grid-column:2;grid-row:2;background:linear-gradient(135deg,#0f4c751a,#3282b81a);border:1px solid rgba(15,76,117,.2);min-height:140px;display:flex;flex-direction:column;justify-content:center}.tv-dashboard.dark .price-node{border-color:#3282b84d}.flow-node-icon-small{font-size:1.5rem;margin-bottom:8px}.flow-node-value-price{font-family:JetBrains Mono,monospace;font-size:2rem;font-weight:700;color:var(--primary)}.tv-dashboard.dark .flow-node-value-price{color:var(--primary-light)}.grid-node .flow-node-value,.price-node .flow-node-value-price{font-size:2rem}.grid-node .flow-node-icon,.price-node .flow-node-icon-small{width:56px;height:56px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.flow-node-icon.grid-icon{background:linear-gradient(135deg,var(--grid) 0%,#a855f7 100%);box-shadow:0 4px 20px #7209b766}.neutrality-circle{width:10vh;height:10vh;border-radius:50%;background:linear-gradient(135deg,#00a8961a,#02c39a33);border:.3vh solid var(--accent);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 0 2vh #00a8964d}.neutrality-label{font-size:.65rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.neutrality-value{font-family:JetBrains Mono,monospace;font-size:2.2rem;font-weight:800;color:var(--accent);line-height:1}.neutrality-unit{font-size:1rem;font-weight:700;color:var(--accent)}.price-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:1.2vh 1.2vw;box-shadow:var(--shadow-md);flex:1;display:flex;flex-direction:column;min-height:0;max-height:85vh;position:relative;overflow:hidden}.price-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#0b853f,#103f73);opacity:0;transition:opacity .3s}.price-panel:hover:before{opacity:1}.price-stat{text-align:center;margin-bottom:1vh}.price-value{font-family:JetBrains Mono,monospace;font-size:2rem;font-weight:700;color:var(--primary)}.tv-dashboard.dark .price-value{color:var(--primary-light)}.price-label{font-size:.8rem;color:var(--text-muted);margin-top:.5vh}.mini-chart{height:15vh;margin-bottom:1vh}.savings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1vh}.savings-card{text-align:center;padding:1vh .5vw;background:#00a8961a;border-radius:var(--radius-md);border:2px solid rgba(0,168,150,.2)}.savings-icon{font-size:1.3rem;margin-bottom:.4vh}.savings-value{font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:700;color:var(--accent);margin-bottom:.3vh}.savings-label{font-size:.7rem;color:var(--text-muted)}.chart-panel-wrapper{display:contents}.charts-row{display:grid;gap:1rem;width:100%;max-width:100%;flex:1;min-height:0}.charts-row:first-child{grid-template-columns:1fr}.charts-row:last-child{grid-template-columns:1fr 1fr}.bottom-charts{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1.25rem;width:100%}.chart-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-md);display:flex;flex-direction:column;height:100%;min-height:0;position:relative;overflow:hidden}.chart-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#0b853f,#103f73);opacity:0;transition:opacity .3s}.chart-panel:hover:before{opacity:1}.chart-title{font-size:1rem;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:16px;color:var(--text-primary)}.chart-title span{font-size:1.1rem}.chart-container-bottom{flex:1;min-height:0;position:relative}.chart-container-bottom canvas{width:100%!important;height:100%!important}.neutrality-stat{text-align:center;margin-bottom:12px}.neutrality-value-large{font-family:JetBrains Mono,monospace;font-size:2.5rem;font-weight:700;color:var(--accent);line-height:1;margin-bottom:6px}.neutrality-label-large{font-size:1rem;color:var(--text-muted)}.mini-chart-small{height:8.75rem;margin-top:auto;padding-top:1rem}.trend-stat{text-align:center;margin-bottom:1rem}.trend-value{font-family:JetBrains Mono,monospace;font-size:2.5rem;font-weight:700;color:var(--accent);line-height:1;margin-bottom:.375rem}.trend-label{font-size:1rem;color:var(--text-muted)}.trend-icons{display:flex;justify-content:center;gap:1.25rem;margin-top:1.25rem}.trend-item{text-align:center}.trend-icon{font-size:1.5rem;margin-bottom:.5rem}.trend-text{font-size:.8rem;color:var(--text-muted)}.chart-container{height:13.75rem;margin-top:1rem}.tv-footer{text-align:center;padding:20px;background:var(--bg-card);border-top:1px solid rgba(0,0,0,.06);position:relative;z-index:10;flex-shrink:0}.footer-logo{width:48px;height:48px;margin:0 auto 12px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:8px}.footer-logo img{width:100%;height:100%;object-fit:contain}.footer-text{font-size:.85rem;color:var(--text-muted)}.footer-text strong{color:var(--primary)}.tv-dashboard.dark .footer-text strong{color:var(--accent-light)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeInUp .5s ease forwards}@media(max-width:1400px){.stats-cards{grid-template-columns:repeat(2,1fr)}.flow-grid{grid-template-columns:repeat(3,1fr)}.neutrality-node{grid-column:2}}@media(max-width:1024px){.carousel-container{overflow:visible}.carousel-wrapper{display:block;transform:none!important}.carousel-page{min-width:100%;margin-bottom:24px}.page-indicators{display:none}.stats-cards{grid-template-columns:repeat(2,1fr);gap:16px}.live-stats{grid-template-columns:repeat(3,1fr);gap:16px}.flow-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto;gap:16px}.neutrality-node{grid-column:span 2;grid-row:auto;justify-self:center}.price-node,.grid-node{grid-column:1;grid-row:auto}.bottom-charts{grid-template-columns:1fr 1fr}.chart-panel:first-child{grid-column:span 2}.stat-value{font-size:2.5rem}.live-stat-value{font-size:2rem}.flow-node-value{font-size:1.4rem}.neutrality-circle{width:140px;height:140px}.neutrality-value{font-size:3rem}}@media(max-width:768px){.tv-dashboard{height:auto;min-height:100vh;overflow-y:auto;overflow-x:hidden}.tv-header{padding:12px 16px;flex-wrap:wrap;gap:12px}.header-left{width:100%}.header-right{width:100%;justify-content:space-between}.logo-icon{width:48px;height:48px}.logo-icon svg{width:28px;height:28px}.header-title h1{font-size:1.2rem}.header-title span{font-size:.8rem}.status-badge{padding:8px 12px;font-size:.75rem}.current-time{font-size:.8rem}.btn-logout{padding:8px 16px;font-size:.85rem}.carousel-container{padding:0 16px 16px}.stats-cards{grid-template-columns:1fr;gap:12px}.stat-card{padding:20px}.stat-icon{width:48px;height:48px;font-size:1.5rem}.stat-value{font-size:2rem}.stat-unit{font-size:.8rem}.live-panel,.flow-panel,.market-panel{padding:20px}.panel-title{font-size:1.1rem}.panel-icon{width:36px;height:36px;font-size:1rem}.live-stats{grid-template-columns:1fr;gap:12px}.live-stat{padding:16px}.live-stat-icon{font-size:2rem}.live-stat-value{font-size:1.8rem}.live-stat-label{font-size:.85rem}.production-badge{padding:12px 16px;flex-wrap:wrap}.production-text{font-size:.85rem}.flow-grid{grid-template-columns:1fr;grid-template-rows:auto;gap:12px;display:flex;flex-direction:column}.neutrality-node{grid-column:1;grid-row:auto;order:3}.price-node{grid-column:1;grid-row:auto;order:4}.grid-node{grid-column:1;grid-row:auto;order:2}.flow-node{padding:16px}.flow-node-icon{width:60px;height:60px;font-size:1.8rem}.flow-node-label{font-size:.85rem}.flow-node-value{font-size:1.3rem}.neutrality-circle{width:120px;height:120px}.neutrality-label{font-size:.7rem}.neutrality-value{font-size:2.5rem}.neutrality-unit{font-size:1rem}.savings-grid{grid-template-columns:1fr;gap:12px}.savings-card{padding:20px}.savings-icon{font-size:2rem}.savings-label{font-size:.85rem}.savings-value{font-size:1.8rem}.bottom-charts{grid-template-columns:1fr}.chart-panel:first-child{grid-column:span 1}.chart-container-bottom{height:220px}.tv-footer{padding:16px}.footer-logo{width:40px;height:40px}.footer-text{font-size:.75rem}}@media(max-width:480px){.header-right{flex-wrap:wrap;gap:8px}.btn-icon{width:40px;height:40px;font-size:1rem}.stat-card-header{flex-direction:column;align-items:flex-start}.stat-icon{width:44px;height:44px}.stat-value{font-size:1.8rem}.live-stat-value{font-size:1.5rem}.flow-node-icon{width:52px;height:52px;font-size:1.5rem}.flow-node-value{font-size:1.1rem}.neutrality-circle{width:100px;height:100px}.neutrality-value{font-size:2rem}.savings-value,.savings-icon{font-size:1.5rem}.chart-container-bottom{height:180px}.mini-chart,.mini-chart-small{height:100px}}@media(max-height:820px){.stat-card{padding:12px 16px}.stat-icon{width:36px;height:36px;font-size:1.1rem}.stat-card-header{margin-bottom:6px}.stat-card .stat-label{font-size:1.3rem}.stat-card .stat-value{font-size:1.7rem;margin-bottom:2px}.stat-card .stat-unit{font-size:.95rem}.stats-cards{gap:10px}}@media(min-width:1920px){html{font-size:17px}.tv-header{padding:18px 40px}.logo-icon{width:64px;height:64px}.header-title h1{font-size:1.75rem}.header-title>span{font-size:1rem}.stat-card{padding:22px}.stat-icon{width:52px;height:52px;font-size:1.6rem}.stat-card .stat-label{font-size:2rem}.stat-card .stat-value{font-size:2.5rem}.stat-card .stat-unit{font-size:1.3rem}.live-stat-value,.live-stat-label{font-size:1.5rem}.panel-title{font-size:1.15rem}.flow-node-value{font-size:1.3rem}.neutrality-value{font-size:2.5rem}}@media(min-width:2560px){html{font-size:20px}.tv-header{padding:22px 52px}.logo-icon{width:72px;height:72px}.btn-icon{width:52px;height:52px}.btn-logout,.btn-admin-back{padding:13px 26px;font-size:1rem}.status-badge{padding:12px 24px;font-size:1rem}.current-time{font-size:1.05rem}.stats-cards{gap:20px}.live-stats{gap:1.2vh}.flow-node-icon{width:5vh;height:5vh;font-size:1.7rem}.neutrality-circle{width:12vh;height:12vh}.flow-node-value-price{font-size:2.4rem}.savings-value{font-size:1.4rem}.indicator{width:14px;height:14px}.indicator.active{width:48px}}@media(min-width:3840px){html{font-size:26px}.tv-header{padding:28px 64px}.logo-icon{width:88px;height:88px}.header-title h1{font-size:2.2rem}.header-title>span{font-size:1.15rem}.btn-icon{width:60px;height:60px;font-size:1.5rem;border-radius:16px}.btn-logout,.btn-admin-back{padding:16px 32px;font-size:1.1rem;border-radius:16px}.status-badge{padding:14px 28px;font-size:1.1rem}.status-dot{width:14px;height:14px}.live-panel,.flow-panel,.price-panel{border-radius:28px}.stat-card{border-radius:20px;padding:28px}.stat-card .stat-label{font-size:2.2rem}.stat-card .stat-value{font-size:3.2rem}.stat-card .stat-unit{font-size:1.4rem}.stat-icon{width:60px;height:60px;font-size:2rem}.live-stat-icon,.live-stat-value{font-size:2.2rem}.live-stat-label{font-size:1.8rem}.live-stat-unit{font-size:1.2rem}.panel-title{font-size:1.3rem}.flow-node-value{font-size:1.6rem}.flow-node-value-price{font-size:2.8rem}.flow-node-label{font-size:1rem}.savings-value{font-size:1.6rem}.savings-label{font-size:.9rem}.production-badge{padding:16px 24px}.production-text{font-size:1rem}.neutrality-value{font-size:3rem}.neutrality-circle{width:14vh;height:14vh;border-width:.4vh}.page-indicators{gap:16px;padding:24px 16px}.indicator{width:16px;height:16px}.indicator.active{width:56px;border-radius:8px}}@media(-webkit-min-device-pixel-ratio:1.5)and (min-width:1920px),(min-resolution:144dpi)and (min-width:1920px){html{font-size:22px}.tv-header{padding:22px 52px}.logo-icon{width:72px;height:72px}.header-title h1{font-size:1.9rem}.stat-card{padding:22px;border-radius:18px}.stat-card .stat-value{font-size:2.8rem}.stat-card .stat-label{font-size:1.9rem}.stat-card .stat-unit{font-size:1.2rem}.stat-icon{width:52px;height:52px;font-size:1.7rem}.live-stat-value{font-size:2rem}.live-stat-label{font-size:1.6rem}.live-stat-icon{font-size:2rem}.live-stat-unit{font-size:1.1rem}.panel-title{font-size:1.2rem}.flow-node-value{font-size:1.45rem}.flow-node-value-price{font-size:2.4rem}.neutrality-value{font-size:2.7rem}.neutrality-circle{width:13vh;height:13vh}.savings-value{font-size:1.5rem}}.login-skeleton{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:#fff;animation:skeletonFadeIn .5s ease-in}.skeleton-login-container{width:100%;height:100%;display:grid;grid-template-columns:1fr 1fr}.skeleton-login-left{padding:80px;display:flex;flex-direction:column;gap:32px}.skeleton-login-logo{width:200px;height:60px;background:linear-gradient(90deg,#103f731a,#103f7333,#103f731a);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite;border-radius:12px}.skeleton-login-title{width:300px;height:40px;background:linear-gradient(90deg,#103f731a,#103f7333,#103f731a);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite .1s;border-radius:8px}.skeleton-login-subtitle{width:400px;height:20px;background:linear-gradient(90deg,#103f731a,#103f7333,#103f731a);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite .2s;border-radius:6px}.skeleton-login-form{display:flex;flex-direction:column;gap:24px;margin-top:16px}.skeleton-input{width:100%;max-width:480px;height:50px;background:linear-gradient(90deg,#103f731a,#103f7333,#103f731a);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite;border-radius:8px}.skeleton-input:nth-child(2){animation-delay:.1s}.skeleton-button{width:100%;max-width:480px;height:56px;background:linear-gradient(90deg,#103f7333,#103f734d,#103f7333);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite .2s;border-radius:8px}.skeleton-login-right{background:linear-gradient(135deg,#103f731a,#0b853f1a);position:relative;overflow:hidden}.skeleton-login-right:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 50%,transparent 100%);animation:skeletonSweep 2s infinite}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes skeletonSweep{0%{transform:translate(-100%)}to{transform:translate(100%)}}.sunset-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:radial-gradient(circle at 50% 0%,gold,#ff8c00,tomato,#ff4500 45%,#8b0000,#2d1b4e 85%,#0a0a1a);animation:sunsetReveal 2s ease-in-out forwards;display:flex;align-items:center;justify-content:center;pointer-events:none;clip-path:circle(0% at 50% 0%)}.sunset-overlay .sun-set{position:fixed;top:-60px;left:50%;transform:translate(-50%);font-size:120px;animation:sunSet 2s ease-in-out forwards;filter:drop-shadow(0 0 80px rgba(255,140,0,1)) drop-shadow(0 0 150px rgba(255,69,0,.8))}@keyframes sunsetReveal{0%{clip-path:circle(0% at 50% 0%);background:radial-gradient(circle at 50% 0%,gold,#ff8c00,tomato,#ff4500 45%,#8b0000,#2d1b4e 85%,#0a0a1a)}80%{clip-path:circle(150% at 50% 0%);background:radial-gradient(circle at 50% 100%,#2d1b4e,#1a0f2e,#0a0a1a 60%,#000);opacity:1}to{clip-path:circle(150% at 50% 0%);background:radial-gradient(circle at 50% 100%,#2d1b4e,#1a0f2e,#0a0a1a 60%,#000);opacity:0}}@keyframes sunSet{0%{top:-60px;filter:drop-shadow(0 0 80px rgba(255,215,0,1)) drop-shadow(0 0 150px rgba(255,140,0,.8))}50%{filter:drop-shadow(0 0 100px rgba(255,99,71,1)) drop-shadow(0 0 180px rgba(255,69,0,.9))}to{top:calc(100vh + 60px);filter:drop-shadow(0 0 60px rgba(139,0,0,.8)) drop-shadow(0 0 120px rgba(255,69,0,.5))}}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.smart-maic-section{margin-top:1.5rem}.smart-maic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(17.5rem,1fr));gap:1.25rem;margin-top:1rem}.smart-maic-card{background:var(--bg-card);border-radius:var(--radius-md);padding:1.25rem;box-shadow:var(--shadow-md);transition:all .3s ease}.smart-maic-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #0000001f}.smart-maic-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.smart-maic-icon{font-size:2rem}.smart-maic-type{font-size:.875rem;font-weight:700;color:var(--text-secondary);letter-spacing:1px}.smart-maic-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.smart-maic-data{display:flex;flex-direction:column;gap:.75rem}.smart-maic-stat{display:flex;align-items:baseline;gap:.5rem;padding:.75rem;background:#667eea0d;border-radius:.5rem;border-left:4px solid var(--primary)}.smart-maic-label{font-size:.8125rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;min-width:5rem}.smart-maic-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);flex:1}.smart-maic-unit{font-size:.875rem;color:var(--text-muted);font-weight:600}.smart-maic-error{padding:.75rem;background:#ef476f1a;border-left:4px solid #ef476f;border-radius:.5rem;font-size:.8125rem;color:#ef476f}.smart-maic-chart{margin-top:1rem;padding:1rem;background:#667eea08;border-radius:.5rem}.smart-maic-chart-title{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;font-weight:600}.smart-maic-chart-bars{display:flex;align-items:flex-end;gap:.25rem;height:5rem;padding:0 .25rem}.smart-maic-chart-bar{flex:1;background:linear-gradient(180deg,var(--primary-light),var(--primary));border-radius:4px 4px 0 0;position:relative;min-height:2px;transition:all .3s ease;cursor:pointer}.smart-maic-chart-bar:hover{opacity:.8;transform:scaleY(1.05)}.smart-maic-chart-bar:after{content:attr(data-value);position:absolute;top:-1.25rem;left:50%;transform:translate(-50%);font-size:.625rem;color:var(--text-secondary);white-space:nowrap;opacity:0;transition:opacity .2s;font-weight:600}.smart-maic-chart-bar:hover:after{opacity:1}.smart-maic-chart-labels{display:flex;justify-content:space-between;margin-top:.5rem;padding:0 .25rem}.smart-maic-chart-label{font-size:.625rem;color:var(--text-muted);font-weight:500}.admin-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);font-family:Plus Jakarta Sans,-apple-system,sans-serif}.admin-loading{display:flex;justify-content:center;align-items:center;height:100vh;color:#fff;font-size:1.5rem}.admin-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 20px #0000001a}.admin-header-left{display:flex;align-items:center;gap:20px}.admin-logo{width:50px;height:50px;object-fit:contain}.admin-header h1{margin:0;font-size:1.8rem;color:#2d3748}.admin-header p{margin:4px 0 0;color:#3a424d;font-size:.9rem}.admin-header-right{display:flex;align-items:center;gap:20px}.admin-user{color:#4a5568;font-weight:600}.btn-profile{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s}.btn-profile:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-logout{background:#ef476f;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s}.btn-logout:hover{background:#d63651;transform:translateY(-2px);box-shadow:0 4px 12px #ef476f66}.admin-error{background:#fed7d7;color:#c53030;padding:15px 20px;margin:20px 40px;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.admin-error button{background:transparent;border:none;color:#c53030;font-size:1.2rem;cursor:pointer;padding:0 10px}.admin-content{padding:40px;max-width:1400px;margin:0 auto}.admin-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.admin-toolbar h2{color:#fff;margin:0;font-size:1.8rem}.btn-primary{background:#00a896;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .3s}.btn-primary:hover{background:#008b7a;transform:translateY(-2px);box-shadow:0 4px 12px #00a89666}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;margin-top:30px}.user-card{background:#fffffff2;border-radius:12px;padding:24px;box-shadow:0 4px 20px #0000001a;transition:all .3s}.user-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #00000026}.user-card-header{display:flex;gap:16px;margin-bottom:20px}.user-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;flex-shrink:0}.user-info{flex:1}.user-info h3{margin:0 0 8px;color:#2d3748;font-size:1.2rem}.user-info p{margin:0;color:#3a424d;font-size:.9rem}.user-role-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff}.user-station{display:inline-block;background:#e6fffa;color:#00a896;padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600}.user-card-footer{display:flex;gap:12px;padding-top:20px;border-top:1px solid #e2e8f0;flex-wrap:wrap}.btn-view-dashboard{flex:1 1 100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:none;border-radius:10px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #10b9814d;margin-bottom:8px}.btn-view-dashboard:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166;background:linear-gradient(135deg,#059669,#047857)}.btn-view-dashboard:active{transform:translateY(0);box-shadow:0 2px 8px #10b9814d}.btn-view-dashboard .btn-icon{font-size:1.1rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.btn-edit,.btn-delete{flex:1;padding:10px;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s}.btn-edit{background:#edf2f7;color:#4a5568}.btn-edit:hover{background:#e2e8f0;transform:translateY(-2px)}.btn-delete{background:#fed7d7;color:#c53030}.btn-delete:hover{background:#fc8181;color:#fff;transform:translateY(-2px)}.empty-state{text-align:center;padding:60px 20px;background:#ffffff1a;border-radius:12px;color:#fff}.empty-state p{font-size:1.2rem;margin-bottom:20px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:24px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;color:#2d3748;font-size:1.5rem}.modal-close{background:transparent;border:none;font-size:1.5rem;color:#3a424d;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#edf2f7;color:#2d3748}.modal-form{padding:24px}.form-group label{display:block;margin-bottom:8px;color:#2d3748;font-weight:600;font-size:.9rem}.form-group input{width:100%;padding:12px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .3s;box-sizing:border-box}.modal-actions{display:flex;gap:12px;margin-top:30px}.btn-secondary{flex:1;background:#edf2f7;color:#4a5568;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .3s}.modal-actions .btn-primary{flex:1}@media(max-width:768px){.admin-header{flex-direction:column;gap:20px;padding:20px}.admin-content{padding:20px}.admin-toolbar{flex-direction:column;gap:20px;align-items:flex-start}.users-grid{grid-template-columns:1fr}.modal-content{width:95%}}.admin-tabs{display:flex;gap:0;padding:0 40px;background:#fff;border-bottom:2px solid #e2e8f0}.admin-tab{padding:16px 32px;background:transparent;border:none;border-bottom:3px solid transparent;color:#64748b;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;position:relative;top:2px}.admin-tab:hover{color:#667eea;background:#f7fafc}.admin-tab.active{color:#667eea;border-bottom-color:#667eea;background:#fff}.credentials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;margin-top:24px}.credential-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;transition:all .3s;border:2px solid transparent}.credential-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px);border-color:#667eea}.credential-header{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #f1f5f9}.credential-name-row{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.credential-name-row h3{margin:0;color:#2d3748;font-size:1.2rem;flex:1}.credential-priority{color:#64748b;font-size:.9rem}.credential-priority strong{color:#667eea;font-size:1.1rem}.badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge-warning{background:#fef3c7;color:#92400e}.badge-inactive{background:#e5e7eb;color:#6b7280}.credential-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0;padding:16px;background:#f8fafc;border-radius:8px}.stat{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:.75rem;color:#64748b;font-weight:500}.stat-value{font-size:2rem;font-weight:700;color:#2d3748}@media(prefers-color-scheme:dark){.stat-value{color:#90a0ba}}.stat-value.error{color:#ef4444}.credential-last-used{font-size:.85rem;color:#64748b;margin:12px 0;padding:8px;background:#f1f5f9;border-radius:6px}.credential-rate-limit-info{font-size:.85rem;color:#92400e;background:#fef3c7;padding:8px 12px;border-radius:6px;margin:12px 0;font-weight:500}.credential-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}.btn-edit-small,.btn-delete-small,.btn-reset{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s;flex:1;min-width:100px}.btn-edit-small{background:#667eea;color:#fff}.btn-edit-small:hover{background:#5568d3;transform:translateY(-2px)}.btn-reset{background:#f59e0b;color:#fff}.btn-reset:hover{background:#d97706;transform:translateY(-2px)}.btn-delete-small{background:#ef4444;color:#fff}.btn-delete-small:hover{background:#dc2626;transform:translateY(-2px)}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;margin-top:24px}.device-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;transition:all .3s;border:3px solid transparent}.device-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.device-card.huawei-card{border-left:4px solid #ef4444}.device-card.smartmaic-card{border-left:4px solid #8b5cf6}.device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:2px solid #f1f5f9}.device-header h3{margin:0;color:#2d3748;font-size:1rem}.device-code{font-family:Monaco,Consolas,monospace;background:#f1f5f9;padding:6px 12px;border-radius:6px;font-size:.85rem;color:#334155;font-weight:600}.device-type-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.device-type-badge.agua{background:#dbeafe;color:#1e40af}.device-type-badge.gas{background:#fef3c7;color:#92400e}.device-type-badge.gasoil{background:#fce7f3;color:#9d174d}.device-details{margin:12px 0}.detail-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #f1f5f9}.detail-label{color:#64748b;font-size:.85rem}.detail-value{color:#1e293b;font-weight:500;font-size:.85rem}.device-user-info{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px;background:#f8fafc;border-radius:8px;margin:12px 0}.user-label{font-size:.8rem;color:#64748b}.user-name{font-weight:600;color:#1e293b;font-size:.9rem}.user-email{color:#64748b;font-size:.8rem}.device-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.empty-state-mini{text-align:center;padding:30px;background:#ffffffe6;border-radius:12px;margin:24px 0}.empty-state-mini p{color:#64748b;margin:0}@media(max-width:768px){.credentials-grid,.credential-stats,.devices-grid{grid-template-columns:1fr}.admin-tabs{padding:0 20px}.admin-tab{padding:12px 20px;font-size:.9rem}}.wizard-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.wizard-background{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#667eea,#764ba2);z-index:-1}.wizard-background:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);animation:pulse 15s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.wizard-content{background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:600px;padding:48px;animation:slideIn .5s ease-out}.wizard-header{text-align:center;margin-bottom:40px}.wizard-logo{width:80px;height:80px;margin-bottom:24px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.wizard-header h1{margin:0 0 8px;color:#2d3748;font-size:2rem}.wizard-header p{margin:0;color:#3a424d;font-size:1.1rem}.wizard-steps{display:flex;align-items:center;justify-content:center;margin-bottom:40px;padding:0 20px}.wizard-step{display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .3s}.step-number{width:40px;height:40px;border-radius:50%;background:#e2e8f0;color:#3a424d;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;transition:all .3s}.wizard-step.active .step-number{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:scale(1.1)}.wizard-step.completed .step-number{background:#00a896;color:#fff}.wizard-step.completed .step-number:before{content:"✓"}.wizard-step span{font-size:.85rem;color:#3a424d;font-weight:600;text-align:center}.wizard-step.active span{color:#667eea}.step-line{flex:1;height:2px;background:#e2e8f0;margin:0 16px;max-width:80px}.wizard-error{background:#fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:24px;text-align:center;animation:shake .3s}.wizard-form{margin-bottom:24px}.wizard-panel{animation:fadeIn .3s}.wizard-panel h2{margin:0 0 8px;color:#2d3748;font-size:1.5rem}.wizard-description{color:#3a424d;margin:0 0 32px;font-size:1rem}.form-group{margin-bottom:24px}.form-group input{width:100%;padding:14px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;transition:all .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.wizard-info{background:#e6fffa;border-left:4px solid #00a896;padding:16px;border-radius:8px;margin-bottom:24px}.wizard-info strong{display:block;color:#00a896;margin-bottom:8px}.wizard-info p{margin:0;color:#2d3748;font-size:.95rem;line-height:1.5}.wizard-actions{display:flex;gap:12px;margin-top:32px}.btn-primary,.btn-secondary{flex:1;padding:14px 24px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn-secondary{background:#edf2f7;color:#4a5568}.btn-secondary:hover{background:#e2e8f0}.wizard-footer{text-align:center;padding-top:24px;border-top:1px solid #e2e8f0}.wizard-footer p{margin:0;color:#a0aec0;font-size:.9rem}@media(max-width:768px){.wizard-content{padding:32px 24px}.wizard-steps{padding:0}.wizard-step span{display:none}.step-line{max-width:40px;margin:0 8px}.wizard-header h1{font-size:1.5rem}.wizard-panel h2{font-size:1.3rem}}.configure-station-container{min-height:100vh;display:flex;justify-content:center;align-items:center;position:relative;font-family:Plus Jakarta Sans,-apple-system,sans-serif;overflow:hidden}.configure-station-background{position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 50% 100%,gold,#ffb347,#ff8c69,#ff6b9d 30%,#c471ed,#12cad6,#87ceeb,#b0e0e6 90%,#e0f7ff);z-index:-1}.configure-station-content{width:100%;max-width:600px;padding:20px;animation:slideIn .5s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.configure-station-header{text-align:center;margin-bottom:40px;color:#fff}.configure-station-logo{width:80px;height:80px;object-fit:contain;margin-bottom:20px;animation:floatLogo 3s ease-in-out infinite}@keyframes floatLogo{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.configure-station-header h1{margin:0 0 10px;font-size:2rem;font-weight:700;text-shadow:0 2px 10px rgba(0,0,0,.2)}.configure-station-header p{margin:0;font-size:1.1rem;opacity:.95}.configure-station-card{background:#fff;border-radius:16px;padding:40px;box-shadow:0 20px 60px #0000004d}.configure-info{text-align:center;margin-bottom:30px}.info-icon{font-size:3rem;margin-bottom:15px}.configure-info h2{margin:0 0 15px;font-size:1.5rem;color:#2d3748}.configure-info p{margin:0;color:#3a424d;font-size:1rem;line-height:1.6}.configure-error{background:#fed7d7;color:#c53030;padding:15px 20px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px;animation:shake .5s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.configure-form{margin-bottom:30px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#2d3748;font-weight:600;font-size:.95rem}.form-group input{width:100%;padding:14px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f7fafc;cursor:not-allowed}.form-group small{display:block;margin-top:6px;color:#3a424d;font-size:.85rem}.configure-actions{margin-top:30px}.btn-primary{background:#103f73;color:#fff;border:none;padding:16px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s;position:relative}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 20px #0b853f99,0 0 40px #0b853f66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-wide{width:100%}.configure-help{background:#f7fafc;padding:20px;border-radius:8px;border-left:4px solid #667eea}.configure-help p{margin:0 0 10px;color:#4a5568;font-size:.9rem;line-height:1.5}.configure-help p:last-child{margin-bottom:0}.configure-help strong{color:#2d3748;display:block;margin-bottom:5px}.configure-footer{text-align:center;margin-top:30px}.btn-logout-link{background:transparent;border:none;color:#fff;font-size:.9rem;cursor:pointer;text-decoration:underline;padding:8px 16px;transition:opacity .3s}.btn-logout-link:hover{opacity:.8}@media(max-width:768px){.configure-station-content{padding:15px}.configure-station-card{padding:30px 20px}.configure-station-header h1{font-size:1.5rem}.configure-station-header p{font-size:1rem}.configure-info h2{font-size:1.3rem}.info-icon{font-size:2.5rem}}.profile-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:20px}.profile-header{max-width:600px;margin:0 auto 30px;display:flex;align-items:center;gap:20px}.profile-header h1{color:#fff;font-size:1.8rem;margin:0}.back-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:.9rem;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#fff3}.profile-content{max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.profile-card{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:24px;border:1px solid rgba(255,255,255,.1)}.profile-card h2{color:#fff;font-size:1.2rem;margin:0 0 20px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.user-info{display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;align-items:center}.info-label{color:#fff9;font-size:.9rem}.info-value{color:#fff;font-weight:500}.role-badge{background:linear-gradient(135deg,#667eea,#764ba2);padding:4px 12px;border-radius:20px;font-size:.85rem}.profile-message{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem}.profile-message.success{background:#22c55e33;border:1px solid rgba(34,197,94,.3);color:#22c55e}.profile-message.error{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:#ef4444}.password-form{display:flex;flex-direction:column;gap:16px}.password-form .form-group{display:flex;flex-direction:column;gap:6px}.password-form label{color:#fffc;font-size:.9rem}.password-form input[type=text],.password-form input[type=password]{padding:12px 16px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:1rem;transition:all .2s ease}.password-form input[type=text]:focus,.password-form input[type=password]:focus{outline:none;border-color:#667eea;background:#ffffff26}.password-form input[type=text]::placeholder,.password-form input[type=password]::placeholder{color:#fff6}.password-form input:disabled{opacity:.6;cursor:not-allowed}.show-password-toggle{display:flex;align-items:center;gap:8px}.show-password-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.show-password-toggle label{color:#ffffffb3;font-size:.85rem;cursor:pointer}.submit-button{padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 20px #667eea66}.submit-button:disabled{opacity:.6;cursor:not-allowed}.logout-card{background:#ef44441a;border-color:#ef444433}.logout-button{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 24px;background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#ef44444d}@media(max-width:640px){.profile-container{padding:16px}.profile-header{flex-direction:column;align-items:flex-start}.profile-header h1{font-size:1.5rem}.profile-card{padding:20px}.info-row{flex-direction:column;align-items:flex-start;gap:4px}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}
