body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}*{box-sizing:border-box}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #ffffff4d;border-radius:1rem;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;padding:1.5rem}.card h2,.card h3{color:#333;margin-top:0}.device-manager .devices-grid{grid-gap:1rem;display:grid;gap:1rem;margin-top:1rem}.device-card{background:#ffffffe6;border:2px solid #0000;border-radius:.75rem;cursor:pointer;padding:1rem;position:relative;transition:all .3s ease}.device-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.device-card.selected{background:#667eea0d;border-color:#667eea}.device-card.online{border-left:4px solid #4ade80}.device-card.offline{border-left:4px solid #ef4444}.device-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.device-header h4{color:#333;font-size:1.1rem;margin:0}.status-dot{border-radius:1rem;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.status-dot.online{background:#dcfce7;color:#166534}.status-dot.offline{background:#fef2f2;color:#991b1b}.device-info,.device-stats{grid-gap:.5rem;display:grid;gap:.5rem}.info-item,.stat{display:flex;font-size:.9rem;justify-content:space-between}.info-item .label,.stat .label{color:#666;font-weight:500}.info-item .value,.stat .value{color:#333;font-weight:600}.wifi-excellent{color:#16a34a}.wifi-good{color:#eab308}.wifi-poor{color:#dc2626}.device-ports-summary{margin-top:1rem}.device-ports-summary h5{color:#666;font-size:.9rem;margin:0 0 .5rem}.ports-summary{display:flex;gap:.5rem}.port-indicator{align-items:center;border-radius:.5rem;display:flex;font-size:.8rem;font-weight:600;height:32px;justify-content:center;position:relative;width:32px}.port-indicator.on{background:#dcfce7;color:#166534}.port-indicator.off{background:#f3f4f6;color:#6b7280}.port-indicator.inactive{opacity:.5}.port-indicator .waiting{font-size:.6rem;position:absolute;right:-5px;top:-5px}.selected-indicator{background:#667eea;border-radius:.5rem;color:#fff;font-weight:600;margin-top:1rem;padding:.5rem;text-align:center}.claim-device{background:#667eea0d;border:1px solid #667eea33;border-radius:.75rem;margin-bottom:2rem;padding:1.5rem}.claim-method h4{color:#4338ca;margin-bottom:.5rem}.claim-method p{color:#666;margin-bottom:1rem}.generate-code-btn,.new-code-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:transform .2s}.generate-code-btn:hover,.new-code-btn:hover{transform:translateY(-1px)}.generate-code-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.claim-code-display{margin-top:1rem}.code-container{background:#fff;border-radius:.75rem;padding:1.5rem;text-align:center}.claim-code{background:#f8fafc;border-radius:.5rem;color:#4338ca;font-family:Courier New,monospace;font-size:2rem;font-weight:700;letter-spacing:.25em;margin:1rem 0;padding:1rem}.code-instructions{color:#666;line-height:1.6;margin:1rem 0;text-align:left}.instructions{background:#fbbf241a;border:1px solid #fbbf244d;border-radius:.75rem;margin-top:2rem;padding:1.5rem}.instructions h4{color:#92400e;margin-top:0}.instructions ol{color:#666;line-height:1.6}.no-devices{color:#666;padding:3rem;text-align:center}.energy-dashboard{min-height:400px}.energy-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:2rem}.energy-stat{background:#ffffffb3;border-radius:.75rem;padding:1rem;text-align:center}.energy-stat .label{color:#666;display:block;font-size:.8rem;margin-bottom:.5rem}.energy-stat .value{color:#333;font-size:1.5rem;font-weight:700}.energy-stat .unit{color:#666;font-size:.9rem}.energy-stat.consumption .value{color:#dc2626}.energy-stat.delivery .value{color:#16a34a}.chart-container{background:#fff;border-radius:.75rem;height:300px;padding:1rem}.no-data{align-items:center;color:#666;display:flex;font-style:italic;height:200px;justify-content:center}.port-control{min-height:400px}.ports-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:1rem}.port-card{background:#ffffffe6;border:2px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;transition:border-color .3s}.port-card.active{background:#4ade800d;border-color:#4ade80}.port-card.inactive{opacity:.6}.port-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.port-header h4{color:#333;margin:0}.port-status{border-radius:1rem;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.port-status.on{background:#dcfce7;color:#166534}.port-status.off{background:#f3f4f6;color:#6b7280}.port-status.waiting{background:#fef3c7;color:#92400e}.port-controls{display:flex;flex-direction:column;gap:1rem}.control-group{align-items:center;display:flex;gap:1rem}.control-group label{color:#666;font-size:.9rem;min-width:80px}.toggle-switch{background-color:#ccc;border-radius:15px;cursor:pointer;height:30px;position:relative;transition:background-color .3s;width:60px}.toggle-switch.active{background-color:#4ade80}.toggle-switch .toggle-knob{background-color:#fff;border-radius:50%;height:24px;left:3px;position:absolute;top:3px;transition:transform .3s;width:24px}.toggle-switch.active .toggle-knob{transform:translateX(30px)}.delay-input,.power-input{border:1px solid #d1d5db;border-radius:.5rem;padding:.5rem;text-align:center;width:80px}.delay-input:focus,.power-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.port-info{border-top:1px solid #e5e7eb;margin-top:1rem;padding-top:1rem}.info-row{display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:.5rem}.info-row .label{color:#666}.info-row .value{color:#333;font-weight:600}.connection-warning{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#991b1b;margin-bottom:1rem;padding:1rem;text-align:center}.landing-page{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.container{margin:0 auto;max-width:1200px;padding:0 2rem}.landing-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #ffffff4d;left:0;position:fixed;right:0;top:0;z-index:1000}.landing-header .container{align-items:center;display:flex;justify-content:space-between;padding:1rem 2rem}.logo h1{font-size:1.5rem}.nav-links{align-items:center;display:flex;gap:2rem}.nav-links a{color:#666;font-weight:500;text-decoration:none;transition:color .3s}.nav-links a:hover{color:#333}.login-btn{background:#0000;border:1px solid #e5e7eb;color:#666;font-weight:500;padding:.5rem 1rem;transition:all .3s}.login-btn:hover{background:#f9fafb;border-color:#d1d5db}.cta-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:600;padding:.5rem 1.5rem;transition:transform .2s}.cta-btn:hover{transform:translateY(-1px)}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;overflow:hidden;padding:8rem 0 4rem;position:relative}.hero .container{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr}.hero-content h1{font-size:3rem;font-weight:700;line-height:1.2;margin:0 0 1rem}.hero-subtitle{font-size:1.2rem;margin-bottom:2rem;opacity:.9}.primary-cta{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:.75rem;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-bottom:1rem;padding:1rem 2rem;transition:all .3s}.primary-cta:hover{background:#ffffff4d;transform:translateY(-2px)}.price-note{margin:0;opacity:.8}.dashboard-preview{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:1rem;overflow:hidden}.preview-header{background:#ffffff1a;display:flex;gap:.5rem;padding:1rem}.dot{border-radius:50%;height:12px;width:12px}.dot.red{background:#ef4444}.dot.yellow{background:#eab308}.dot.green{background:#22c55e}.preview-content{padding:2rem}.preview-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.stat{text-align:center}.stat-value{color:#fff;display:block;font-size:1.5rem;font-weight:700}.stat-label{display:block;font-size:.8rem;opacity:.8}.preview-chart{align-items:end;display:flex;gap:.5rem;height:80px}.chart-bar{background:#ffffff4d;border-radius:.25rem .25rem 0 0;flex:1 1;min-height:20px}.features{background:#f9fafb;padding:4rem 0}.features h2{color:#333;font-size:2.5rem;margin-bottom:3rem;text-align:center}.features-grid{grid-gap:2rem;gap:2rem;grid-template-columns:repeat(3,1fr)}.feature-card{background:#fff;border-radius:1rem;box-shadow:0 4px 20px #00000014;padding:2rem;text-align:center;transition:transform .3s}.feature-card:hover{transform:translateY(-4px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#333;margin:0 0 1rem}.feature-card p{color:#666;margin:0}.how-it-works{background:#fff;padding:4rem 0}.how-it-works h2{color:#333;font-size:2.5rem;margin-bottom:3rem;text-align:center}.steps{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(4,1fr)}.step{position:relative;text-align:center}.step-number{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:60px;justify-content:center;margin:0 auto 1rem;width:60px}.step h3{color:#333;margin:0 0 1rem}.step p{color:#666;margin:0}.pricing{background:#f9fafb;padding:4rem 0}.pricing h2{color:#333;font-size:2.5rem;margin-bottom:3rem;text-align:center}.pricing-cards{display:flex;justify-content:center;margin-bottom:3rem}.pricing-card{background:#fff;border-radius:1rem;box-shadow:0 10px 40px #0000001a;max-width:400px;padding:3rem;text-align:center;width:100%}.pricing-card.featured{border:3px solid #667eea;transform:scale(1.05)}.pricing-header h3{color:#333;font-size:1.5rem;margin:0 0 1rem}.price{align-items:center;display:flex;gap:.25rem;justify-content:center;margin-bottom:1rem}.currency,.period{color:#666;font-size:1.2rem}.amount{color:#333;font-size:3rem;font-weight:700}.pricing-features{margin:2rem 0;text-align:left}.feature{border-bottom:1px solid #f3f4f6;color:#333;padding:.5rem 0}.feature:last-child{border-bottom:none}.one-time-cost{background:#f9fafb;border-radius:.75rem;margin:2rem 0;padding:1.5rem}.one-time-cost h4{color:#333;margin:0 0 .5rem}.one-time-cost p{color:#666;margin:0}.pricing-cta{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.75rem;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:transform .2s;width:100%}.pricing-cta:hover{transform:translateY(-2px)}.pricing-info{margin:0 auto;max-width:800px;text-align:center}.pricing-info h3{color:#333;margin-bottom:2rem}.info-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(2,1fr)}.info-item{background:#fff;border-radius:.75rem;padding:1.5rem;text-align:left}.info-item strong{color:#333;display:block;margin-bottom:.5rem}.info-item p{color:#666;margin:0}.final-cta{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4rem 0;text-align:center}.final-cta h2{font-size:2.5rem;margin-bottom:1rem}.final-cta p{font-size:1.1rem;margin-bottom:2rem;opacity:.9}.final-cta-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:.75rem;color:#fff;cursor:pointer;font-size:1.2rem;font-weight:600;margin-bottom:1rem;padding:1rem 2rem;transition:all .3s}.final-cta-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.guarantee{font-style:italic;margin:0;opacity:.8}.footer{background:#1f2937;color:#fff;padding:3rem 0 1rem}.footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem}.footer-section h4{color:#f9fafb;margin:0 0 1rem}.footer-section a,.footer-section p{color:#d1d5db;margin:.5rem 0;text-decoration:none}.footer-section a:hover{color:#fff}.footer-bottom{border-top:1px solid #374151;color:#9ca3af;padding-top:2rem;text-align:center}.registration-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem}.registration-header{color:#fff;margin-bottom:2rem;text-align:center}.registration-header h1{font-size:2.5rem;margin-bottom:.5rem}.registration-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:1rem;box-shadow:0 20px 40px #0000001a;margin:0 auto;max-width:600px;padding:3rem}.registration-card h2{color:#333;margin:0 0 .5rem;text-align:center}.subtitle{color:#667eea;font-weight:600;text-align:center}.error-messages,.subtitle{margin-bottom:2rem}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#991b1b;margin-bottom:.5rem;padding:.75rem}.registration-form{display:flex;flex-direction:column;gap:2rem}.form-section h3{border-bottom:2px solid #f3f4f6;color:#333;font-size:1.1rem;margin:0 0 1rem;padding-bottom:.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column}.form-group label{color:#333;font-weight:500;margin-bottom:.5rem}.form-group input{border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;padding:.75rem;transition:border-color .3s}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.checkbox-group{display:flex;flex-direction:column;gap:1rem}.checkbox-label{align-items:flex-start;cursor:pointer;display:flex;gap:.75rem;line-height:1.5}.checkbox-label input[type=checkbox]{height:18px;margin:0;width:18px}.checkbox-label a{color:#667eea;text-decoration:underline}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.75rem;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:1rem;padding:1rem 2rem;transition:transform .2s}.submit-button:hover:not(:disabled){transform:translateY(-2px)}.submit-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.login-link{color:#666;margin-top:2rem;text-align:center}.login-link a{color:#667eea;font-weight:600;text-decoration:none}.features-preview{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:1rem;margin:3rem auto 0;max-width:800px;padding:2rem}.features-preview h3{color:#fff;margin:0 0 2rem;text-align:center}.features-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.feature-item{align-items:center;color:#fff;display:flex;gap:1rem}.feature-icon{flex-shrink:0;font-size:1.5rem}.feature-item strong{display:block;margin-bottom:.25rem}.feature-item p{margin:0;opacity:.8}.login-container{flex-direction:column;padding:2rem}.login-header{color:#fff;margin-bottom:2rem;text-align:center}.login-header h1{font-size:2.5rem;margin-bottom:.5rem}.login-card{box-shadow:0 20px 40px #0000001a;max-width:400px;width:100%}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-links{margin-top:2rem;text-align:center}.login-links a{color:#667eea;font-weight:500;text-decoration:none}.register-link{color:#666;margin-top:1rem}.payment-status-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.payment-status-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:1rem;box-shadow:0 20px 40px #0000001a;max-width:600px;padding:3rem;text-align:center;width:100%}.payment-status-card.success{border:3px solid #22c55e}.payment-status-card.error{border:3px solid #ef4444}.error-icon,.loading-spinner,.success-icon{font-size:4rem;margin-bottom:1rem}.payment-status-card h2{color:#333;margin:0 0 1rem}.success-details{background:#f0fdf4;border-radius:.75rem;margin:2rem 0;padding:2rem;text-align:left}.detail-item{margin-bottom:1.5rem}.detail-item:last-child{margin-bottom:0}.detail-item strong{color:#166534;display:block;margin-bottom:.5rem}.detail-item p{color:#16a34a;margin:0}.redirect-notice{color:#666;font-style:italic;margin:2rem 0}.dashboard-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.75rem;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:transform .2s}.dashboard-button:hover{transform:translateY(-2px)}.error-actions{display:flex;gap:1rem;justify-content:center;margin:2rem 0}.retry-button,.support-button{border-radius:.5rem;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:transform .2s}.retry-button{background:#f59e0b;border:none;color:#fff}.support-button{background:#6b7280;border:none;color:#fff}.retry-button:hover,.support-button:hover{transform:translateY(-1px)}.error-details{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;margin-top:1rem;padding:1rem;text-align:left}.payment-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.payment-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:1rem;box-shadow:0 20px 40px #0000001a;max-width:600px;padding:3rem;text-align:center;width:100%}.payment-card h2{color:#333;margin:0 0 1rem}.payment-info{background:#f8fafc;border-radius:.75rem;margin:2rem 0;padding:2rem;text-align:left}.payment-info h3{color:#333;margin:0 0 1rem}.pricing-details{background:#fff;border-radius:.5rem;margin:1rem 0;padding:1.5rem}.price-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:.75rem 0}.price-item:last-child{border-bottom:none}.payment-button{background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:.75rem;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin:2rem 0;padding:1rem 2rem;transition:transform .2s;width:100%}.payment-button:hover:not(:disabled){transform:translateY(-2px)}.payment-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.security-info{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;margin-top:2rem;padding:1rem;text-align:left}.security-info p{color:#16a34a;margin:.5rem 0}.security-info p:first-child{font-weight:600;margin-top:0}.security-info p:last-child{margin-bottom:0}@media (max-width:768px){.container{padding:0 1rem}.landing-header .container{padding:1rem}.nav-links{gap:1rem}.nav-links a{display:none}.hero .container{gap:2rem;grid-template-columns:1fr;text-align:center}.hero-content h1{font-size:2rem}.features-grid,.footer-content,.info-grid,.steps{grid-template-columns:1fr}.footer-content{text-align:center}.features-preview .features-grid,.form-row{grid-template-columns:1fr}.error-actions{flex-direction:column}.card{margin-bottom:1rem;padding:1rem}.energy-stats{grid-template-columns:repeat(2,1fr)}.ports-grid{grid-template-columns:1fr}.control-group{align-items:flex-start;flex-direction:column;gap:.5rem}.control-group label{min-width:auto}}.App{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.app-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #fff3;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px}.logo h1{color:#333;font-size:1.8rem;font-weight:700;margin:0}.user-info{gap:1rem}.connection-status,.user-info{align-items:center;display:flex}.connection-status{color:#666;font-size:.9rem;gap:.5rem}.status-dot{border-radius:50%;height:10px;width:10px}.status-dot.connected{background-color:#4ade80;box-shadow:0 0 10px #4ade8080}.status-dot.disconnected{background-color:#ef4444}.logout-btn{background:#ef4444;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background-color .2s}.logout-btn:hover{background:#dc2626}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #ffffff4d;border-radius:1rem;box-shadow:0 10px 30px #0003;padding:3rem;text-align:center}.login-card .logo h1{color:#333;font-size:2.5rem;margin:0 0 .5rem}.login-card .logo p{color:#666;font-size:1.1rem;margin:0 0 2rem}.login-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:transform .2s,box-shadow .2s}.login-btn:hover{box-shadow:0 10px 20px #667eea66;transform:translateY(-2px)}.loading{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.spinner{animation:spin 1s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app-main{margin:0 auto;max-width:1400px;padding:2rem}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-areas:"devices energy" "devices control";grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.device-section{grid-area:devices}.energy-section{grid-area:energy}.control-section{grid-area:control}@media (max-width:1024px){.dashboard-grid{grid-template-areas:"devices" "energy" "control";grid-template-columns:1fr}}@media (max-width:768px){.app-main{padding:1rem}.header-content{padding:0 1rem}.user-info{flex-direction:column;font-size:.8rem;gap:.5rem}}
/*# sourceMappingURL=main.329a0ca0.css.map*/