@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap);:root{--infinos-orange-50:#fff4ed;--infinos-orange-100:#ffe6d5;--infinos-orange-200:#ffcaa8;--infinos-orange-300:#ffa970;--infinos-orange-400:#ff8c61;--infinos-orange-500:#ff6b35;--infinos-orange-600:#e55a2b;--infinos-orange-700:#cc4f26;--infinos-orange-800:#9d3d1e;--infinos-orange-900:#7d311a;--success-dark:#059669;--warning-light:#fef3c7;--warning-dark:#d97706;--error-dark:#dc2626;--info-light:#dbeafe;--info-dark:#2563eb;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--transition-base:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:300ms cubic-bezier(0.4,0,0.2,1);--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:#f9fafb;background:var(--gray-50);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}body,h1,h2,h3,h4,h5,h6{color:#111827;color:var(--gray-900)}h1,h2,h3,h4,h5,h6{font-family:Space Grotesk,Inter,sans-serif;font-weight:600;line-height:1.2}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f3f4f6;background:var(--gray-100)}::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--gray-300);border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--gray-400)}::selection{background:#ffcaa8;background:var(--infinos-orange-200);color:#111827;color:var(--gray-900)}:focus-visible{outline:2px solid var(--infinos-orange-500)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}.fade-in{animation:fadeIn .2s cubic-bezier(.4,0,.2,1);animation:fadeIn var(--transition-base)}.fade-in-up{animation:fadeInUp .3s cubic-bezier(.4,0,.2,1);animation:fadeInUp var(--transition-slow)}.container{max-width:1400px;padding:0 16px;padding:0 var(--space-4);width:100%}@media (min-width:640px){.container{padding:0 24px;padding:0 var(--space-6)}}@media (min-width:1024px){.container{padding:0 32px;padding:0 var(--space-8)}}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}body,html{max-width:100%;overflow-x:hidden}body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--infinos-orange:#ff6b35;--infinos-dark:#2d2d2d;--infinos-cream:#fff4e6;--infinos-light-orange:#ff8c61;--infinos-border:#e0e0e0;--infinos-shadow:#ff6b351a;--infinos-dark-shadow:#2d2d2d26}body{background-color:#fff4e6;background-color:var(--infinos-cream);color:#2d2d2d;color:var(--infinos-dark);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{background:linear-gradient(135deg,#fff4e6,#ffecd1);background:linear-gradient(135deg,var(--infinos-cream) 0,#ffecd1 100%);display:flex;flex-direction:column;min-height:100vh}.App-logo{filter:drop-shadow(0 4px 6px rgba(255,107,53,.1));filter:drop-shadow(0 4px 6px var(--infinos-shadow));height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background:linear-gradient(135deg,#2d2d2d,#1a1a1a);background:linear-gradient(135deg,var(--infinos-dark) 0,#1a1a1a 100%);color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh;overflow:hidden;position:relative}.App-header:before{background:radial-gradient(circle at 30% 50%,#ff6b35 0,#0000 50%);background:radial-gradient(circle at 30% 50%,var(--infinos-orange) 0,#0000 50%);bottom:0;content:"";left:0;opacity:.1;pointer-events:none;position:absolute;right:0;top:0}.App-link{color:#ff6b35;color:var(--infinos-orange);font-weight:600;position:relative;text-decoration:none;transition:all .3s ease}.App-link:hover{color:#ff8c61;color:var(--infinos-light-orange);transform:translateY(-2px)}.App-link:after{background-color:#ff6b35;background-color:var(--infinos-orange);bottom:-4px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.App-link:hover:after{width:100%}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}button{background:linear-gradient(135deg,#ff6b35,#ff8c61);background:linear-gradient(135deg,var(--infinos-orange) 0,var(--infinos-light-orange) 100%);border:none;border-radius:8px;box-shadow:0 4px 12px #ff6b351a;box-shadow:0 4px 12px var(--infinos-shadow);color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 28px;transition:all .3s ease}button:hover{box-shadow:0 6px 20px #ff6b351a;box-shadow:0 6px 20px var(--infinos-shadow);transform:translateY(-2px)}button:active{transform:translateY(0)}button:disabled{cursor:not-allowed;opacity:.6;transform:none}input,select,textarea{background-color:#fff;border:2px solid #e0e0e0;border:2px solid var(--infinos-border);border-radius:8px;color:#2d2d2d;color:var(--infinos-dark);font-size:16px;padding:12px 16px;transition:all .3s ease}input:focus,select:focus,textarea:focus{border-color:#ff6b35;border-color:var(--infinos-orange);box-shadow:0 0 0 3px #ff6b351a;box-shadow:0 0 0 3px var(--infinos-shadow);outline:none}.card{border:1px solid #e0e0e0;border:1px solid var(--infinos-border);border-radius:12px;box-shadow:0 4px 16px #2d2d2d26;box-shadow:0 4px 16px var(--infinos-dark-shadow);padding:24px;transition:all .3s ease}.card:hover{box-shadow:0 8px 24px #2d2d2d26;box-shadow:0 8px 24px var(--infinos-dark-shadow);transform:translateY(-4px)}.container{margin:0 auto;max-width:1200px;padding:32px 16px}@media (max-width:768px){.container{padding:24px 16px}button{padding:10px 20px}button,input,select,textarea{font-size:14px}}.loading{animation:pulse 1.5s ease-in-out infinite}*{transition:background-color .3s ease,color .3s ease}.devices-layout{background:var(--gray-50);min-height:100vh}.devices-content{margin:0 auto;max-width:1400px;padding:var(--space-8) var(--space-6)}.devices-header{align-items:center;animation:fadeInUp var(--transition-slow);display:flex;justify-content:space-between;margin-bottom:var(--space-8)}.devices-title{color:var(--gray-900);font-size:2rem;font-weight:700;margin:0 0 var(--space-2) 0}.devices-subtitle{color:var(--gray-600);font-size:1rem;margin:0}.devices-filters{align-items:center;animation:fadeInUp var(--transition-slow) .1s;display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-8)}.search-box{flex:1 1;max-width:400px;position:relative}.search-box svg{stroke-width:2;color:var(--gray-400);left:var(--space-4);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius-lg);color:var(--gray-900);font-size:.875rem;height:44px;padding:0 var(--space-4) 0 var(--space-12);transition:all var(--transition-base);width:100%}.search-input:focus{border-color:var(--infinos-orange-500);box-shadow:0 0 0 3px var(--infinos-orange-50);outline:none}.search-input::placeholder{color:var(--gray-400)}.filter-buttons{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);display:flex;gap:var(--space-2);justify-content:space-between;max-width:100%;overflow-x:auto;overflow-y:hidden;padding:var(--space-1)}.filter-btn{background:#0000;border:none;border-radius:var(--radius-md);color:var(--gray-600);cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;min-width:-webkit-fit-content;min-width:fit-content;padding:var(--space-2) var(--space-4);text-align:center;transition:all var(--transition-base);white-space:nowrap}.filter-btn:hover{background:var(--gray-50);color:var(--gray-900)}.filter-btn-active{background:var(--infinos-orange-500)!important;color:#fff!important}.devices-grid{grid-gap:var(--space-6);animation:fadeInUp var(--transition-slow) .2s;display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.device-card{cursor:pointer;display:flex;flex-direction:column;height:100%;transition:all var(--transition-base)}.device-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px)}.device-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-4)}.device-card-icon{align-items:center;background:var(--infinos-orange-50);border-radius:var(--radius-lg);color:var(--infinos-orange-600);display:flex;height:48px;justify-content:center;width:48px}.device-card-icon svg{stroke-width:2}.device-status-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-weight:600;gap:var(--space-2);padding:var(--space-1) var(--space-3)}.device-status-badge.status-online{background:var(--success-light);color:var(--success-dark)}.device-status-badge.status-offline{background:var(--gray-200);color:var(--gray-600)}.device-card-name{color:var(--gray-900);font-size:1.25rem;font-weight:600;margin:0 0 var(--space-4) 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-card-components{background:var(--gray-50);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-6);padding:var(--space-4)}.component-item{align-items:center;color:var(--gray-600);display:flex;font-size:.875rem;gap:var(--space-2)}.component-item svg{stroke-width:2;color:var(--gray-400)}.device-card-actions{align-items:center;border-top:1px solid var(--gray-100);display:flex;justify-content:center;margin-top:auto;padding-top:var(--space-4)}.device-card-actions button{justify-content:center;width:100%}.toggle-switch{cursor:pointer;display:inline-block;height:28px;position:relative;width:52px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background:var(--gray-300);border-radius:var(--radius-full);bottom:0;left:0;right:0;top:0}.toggle-slider,.toggle-slider:before{position:absolute;transition:all var(--transition-base)}.toggle-slider:before{background:#fff;border-radius:50%;bottom:4px;box-shadow:var(--shadow-sm);content:"";height:20px;left:4px;width:20px}.toggle-switch input:checked+.toggle-slider{background:var(--success)}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(24px)}.toggle-switch:hover .toggle-slider{background:var(--gray-400)}.toggle-switch input:checked:hover+.toggle-slider{background:var(--success-dark)}.empty-state{padding:var(--space-20) var(--space-8)}@media (max-width:1024px){.filter-buttons{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.filter-buttons::-webkit-scrollbar{display:none}.filter-btn{font-size:.8125rem;padding:var(--space-2) var(--space-3)}}@media (max-width:768px){.devices-content{padding:var(--space-6) var(--space-4)}.devices-header{align-items:flex-start;flex-direction:column;gap:var(--space-4)}.devices-title{font-size:1.5rem}.devices-filters{align-items:stretch;flex-direction:column;gap:var(--space-3)}.search-box{max-width:100%}.filter-buttons{gap:var(--space-2);padding:var(--space-2);width:100%}.filter-btn{font-size:.75rem;min-width:-webkit-fit-content;min-width:fit-content;padding:var(--space-2) var(--space-3)}.devices-grid{grid-template-columns:1fr}}@media (max-width:480px){.devices-content{padding:var(--space-4) var(--space-3)}.devices-title{font-size:1.25rem}.filter-buttons{gap:6px;padding:6px}.filter-btn{font-size:.65rem;letter-spacing:-.01em;padding:6px 10px}}@media (max-width:375px){.filter-btn{font-size:.6rem;padding:5px 8px}}.device-code-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:12px;padding:12px}.device-code-label{align-items:center;color:#6b7280;display:flex;font-size:11px;font-weight:600;gap:6px;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.device-code-label svg{stroke-width:2;color:#9ca3af}.device-code-display-simple{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;display:flex;justify-content:center;padding:8px 12px}.device-code-text{color:#111827;font-family:JetBrains Mono,Courier New,monospace;font-size:14px;font-weight:600;letter-spacing:1px}@media (max-width:768px){.device-code-section{padding:10px}.device-code-text{font-size:13px}}.navbar{animation:fadeInDown var(--transition-base);background:#fff;border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-sticky)}.navbar-container{align-items:center;display:flex;gap:var(--space-8);height:64px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 var(--space-6)}.navbar-brand{align-items:center;cursor:pointer;display:flex;gap:var(--space-3);transition:opacity var(--transition-base)}.navbar-brand:hover{opacity:.8}.navbar-logo{height:40px;width:auto}.navbar-title{color:var(--gray-900);font-family:Space Grotesk,sans-serif;font-size:1.5rem;font-weight:700}.navbar-menu{flex:1 1;margin-left:var(--space-8)}.navbar-link,.navbar-menu{align-items:center;display:flex;gap:var(--space-2)}.navbar-link{background:#0000;border:none;border-radius:var(--radius-lg);color:var(--gray-600);cursor:pointer;font-weight:500;padding:var(--space-2) var(--space-4);transition:all var(--transition-base)}.navbar-link:hover{background:var(--infinos-orange-50);color:var(--infinos-orange-600)}.navbar-link svg{stroke-width:2}.navbar-actions{align-items:center;display:flex;gap:var(--space-4)}.navbar-notification-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-full);color:var(--gray-600);cursor:pointer;display:flex;height:40px;justify-content:center;position:relative;transition:all var(--transition-base);width:40px}.navbar-notification-btn:hover{background:var(--gray-100);color:var(--gray-900)}.notification-badge{align-items:center;background:var(--error);border:2px solid #fff;border-radius:var(--radius-full);color:#fff;display:flex;font-size:.75rem;font-weight:600;height:18px;justify-content:center;position:absolute;right:6px;top:6px;width:18px}.navbar-user-menu{position:relative}.navbar-user-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-full);cursor:pointer;display:flex;gap:var(--space-3);padding:var(--space-2) var(--space-3) var(--space-2) var(--space-2);transition:all var(--transition-base)}.navbar-user-btn:hover{background:var(--gray-100)}.user-avatar{align-items:center;background:linear-gradient(135deg,var(--infinos-orange-500),var(--infinos-orange-600));border-radius:var(--radius-full);color:#fff;display:flex;font-size:.875rem;font-weight:600;height:36px;justify-content:center;text-transform:uppercase;width:36px}.user-name{color:var(--gray-700);font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-menu{animation:fadeInDown var(--transition-fast);background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:200px;padding:var(--space-2);position:absolute;right:0;top:calc(100% + var(--space-2));z-index:var(--z-dropdown)}.dropdown-item{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--gray-700);cursor:pointer;display:flex;font-weight:500;gap:var(--space-3);padding:var(--space-3) var(--space-4);text-align:left;transition:all var(--transition-base);width:100%}.dropdown-item:hover{background:var(--gray-100)}.dropdown-item-danger{color:var(--error)}.dropdown-item-danger:hover{background:var(--error-light)}.dropdown-divider{background:var(--gray-200);height:1px;margin:var(--space-2) 0}@media (max-width:768px){.navbar-container{padding:0 var(--space-4)}.navbar-menu,.navbar-title{display:none}::selection .user-name{display:none}}.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;position:relative;transition:all var(--transition-base)}.card:before{background:linear-gradient(90deg,var(--infinos-orange-500),var(--infinos-orange-400));content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-base)}.card:hover:before{opacity:1}.card-hoverable:hover{border-color:var(--infinos-orange-200);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-default{background:#fff}.card-bordered{border:2px solid var(--gray-200)}.card-elevated{box-shadow:var(--shadow-md)}.card-padding-none{padding:0}.card-padding-sm .card-body{padding:var(--space-4)}.card-padding-md .card-body{padding:var(--space-6)}.card-padding-lg .card-body{padding:var(--space-8)}.card-header{align-items:flex-start;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;margin-bottom:var(--space-4);padding:var(--space-6) var(--space-6) 0}.card-header-content{flex:1 1}.card-title{color:var(--gray-900);font-size:1.25rem;font-weight:700;margin:0 0 var(--space-1) 0}.card-subtitle{color:var(--gray-500);font-size:.875rem;margin:0}.card-header-action{flex-shrink:0;margin-left:var(--space-4)}.card-body{padding:var(--space-6)}.btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-weight:600;gap:var(--space-2);justify-content:center;overflow:hidden;position:relative;transition:all var(--transition-base);white-space:nowrap}.btn:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.btn:active:before{height:300px;width:300px}.btn-primary{background:linear-gradient(135deg,var(--infinos-orange-500) 0,var(--infinos-orange-600) 100%);box-shadow:var(--shadow-sm);color:#fff}.btn-primary:hover:not(.btn-disabled){background:linear-gradient(135deg,var(--infinos-orange-600) 0,var(--infinos-orange-700) 100%);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--gray-100);border:1px solid var(--gray-200);color:var(--gray-700)}.btn-secondary:hover:not(.btn-disabled){background:var(--gray-200);border-color:var(--gray-300)}.btn-outline{background:#0000;border:2px solid var(--infinos-orange-500);color:var(--infinos-orange-600)}.btn-outline:hover:not(.btn-disabled){background:var(--infinos-orange-50);border-color:var(--infinos-orange-600)}.btn-ghost{background:#0000;color:var(--gray-700)}.btn-ghost:hover:not(.btn-disabled){background:var(--gray-100)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(.btn-disabled){background:var(--error-dark);transform:translateY(-1px)}.btn-xs{font-size:.75rem;height:28px;padding:var(--space-1) var(--space-2)}.btn-sm{font-size:.875rem;height:36px;padding:var(--space-2) var(--space-3)}.btn-md{font-size:1rem;height:44px;padding:var(--space-3) var(--space-4)}.btn-lg{font-size:1.125rem;height:52px;padding:var(--space-4) var(--space-6)}.btn-full{width:100%}.btn-disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.btn-spinner{animation:spin .6s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid #0000;height:16px;width:16px}.btn-icon-left,.btn-icon-right{align-items:center;display:flex;font-size:1.25em}.btn-content{position:relative;z-index:1}.control-layout{background:var(--gray-50);min-height:100vh}.control-content{margin:0 auto;max-width:1400px;padding:var(--space-8) var(--space-6)}.control-header{align-items:center;animation:fadeInUp var(--transition-slow);display:flex;justify-content:space-between;margin-bottom:var(--space-8)}.control-title{color:var(--gray-900);font-size:2rem;font-weight:700;margin:0 0 var(--space-2) 0}.control-subtitle{color:var(--gray-600);font-size:1rem;margin:0}.control-tabs{animation:fadeInUp var(--transition-slow) .1s;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);margin-bottom:var(--space-8);padding:var(--space-1)}.control-tab,.control-tabs{display:flex;gap:var(--space-2)}.control-tab{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--gray-600);cursor:pointer;flex:1 1;font-size:.9375rem;font-weight:600;justify-content:center;padding:var(--space-3) var(--space-6);transition:all var(--transition-base)}.control-tab svg{stroke-width:2}.control-tab:hover{background:var(--gray-50);color:var(--gray-900)}.control-tab-active{background:var(--infinos-orange-500)!important;box-shadow:var(--shadow-sm);color:#fff!important}.control-grid{grid-gap:var(--space-6);animation:fadeInUp var(--transition-slow) .2s;display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.component-card{transition:all var(--transition-base)}.component-card:before{opacity:1}.heater-card:before{background:linear-gradient(90deg,var(--error),var(--error-dark))}.cooler-card:before{background:linear-gradient(90deg,var(--info),var(--info-dark))}.battery-card:before{background:linear-gradient(90deg,var(--warning),var(--warning-dark))}.safety-card:before{background:linear-gradient(90deg,var(--infinos-orange-500),var(--infinos-orange-600))}.add-component-card:before{background:linear-gradient(90deg,var(--gray-400),var(--gray-500))}.control-group{margin-bottom:var(--space-6)}.control-label{color:var(--gray-700);display:block;font-size:.875rem;font-weight:600;margin-bottom:var(--space-2)}.control-input{background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius-md);color:var(--gray-900);font-size:.9375rem;height:44px;padding:0 var(--space-4);transition:all var(--transition-base);width:100%}.control-input:focus{border-color:var(--infinos-orange-500);box-shadow:0 0 0 3px var(--infinos-orange-50);outline:none}.toggle-group{background:var(--gray-50);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-4)}.toggle-item{align-items:center;display:flex;justify-content:space-between}.toggle-label{color:var(--gray-700);font-size:.875rem;font-weight:500}.toggle-switch-small{cursor:pointer;display:inline-block;height:24px;position:relative;width:44px}.toggle-switch-small input{height:0;opacity:0;width:0}.toggle-slider-small{background:var(--gray-300);border-radius:var(--radius-full);bottom:0;left:0;right:0;top:0}.toggle-slider-small,.toggle-slider-small:before{position:absolute;transition:all var(--transition-base)}.toggle-slider-small:before{background:#fff;border-radius:50%;bottom:4px;box-shadow:var(--shadow-xs);content:"";height:16px;left:4px;width:16px}.toggle-switch-small input:checked+.toggle-slider-small{background:var(--success)}.toggle-switch-small input:checked+.toggle-slider-small:before{transform:translateX(20px)}.readings-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,1fr)}.reading-item{background:var(--gray-50);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4)}.reading-label{color:var(--gray-500);font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.reading-value{color:var(--gray-900);font-size:1.5rem;font-weight:700}.safety-zones{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(3,1fr)}.safety-zone{align-items:center;border-radius:var(--radius-lg);display:flex;flex-direction:column;padding:var(--space-5);text-align:center}.safety-zone svg{stroke-width:2;margin-bottom:var(--space-2)}.safety-zone-low{background:var(--info-light);color:var(--info-dark)}.safety-zone-bag{background:var(--gray-100);color:var(--gray-700)}.safety-zone-high{background:var(--error-light);color:var(--error-dark)}.safety-value{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-1)}.safety-label{font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.component-select{background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius-md);color:var(--gray-900);cursor:pointer;font-size:.9375rem;height:44px;margin-bottom:var(--space-4);padding:0 var(--space-4);transition:all var(--transition-base);width:100%}.component-select:focus{border-color:var(--infinos-orange-500);box-shadow:0 0 0 3px var(--infinos-orange-50);outline:none}.analysis-grid{grid-gap:var(--space-6);animation:fadeInUp var(--transition-slow) .2s;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(480px,1fr))}.chart-card{min-height:400px}.chart-wrapper{height:300px}@media (max-width:768px){.control-content{padding:var(--space-6) var(--space-4)}.control-header{align-items:flex-start;flex-direction:column;gap:var(--space-4)}.control-title{font-size:1.5rem}.analysis-grid,.control-grid,.safety-zones{grid-template-columns:1fr}}.analysis-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr;padding:20px;width:100%}.chart-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;width:100%}.chart-wrapper{align-items:center;display:flex;height:auto;justify-content:center;min-height:400px;position:relative;width:100%}.chart-wrapper canvas{height:auto!important;max-width:100%!important}@media (min-width:768px){.analysis-grid{grid-template-columns:repeat(2,1fr)}.chart-wrapper{min-height:350px}}@media (min-width:1024px){.analysis-grid{grid-template-columns:repeat(2,1fr)}.chart-wrapper{min-height:400px}}@media (max-width:768px){.analysis-grid{gap:16px;grid-template-columns:1fr;padding:12px}.chart-card{padding:16px;width:100%}.chart-wrapper{max-height:500px;min-height:450px;width:100%}.chart-wrapper canvas{height:100%!important;max-width:100%!important}}@media (max-width:480px){.analysis-grid{gap:12px;padding:8px}.chart-card{padding:12px}.chart-wrapper{min-height:500px}}.devices-loading{align-items:center;display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;min-height:60vh}.loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--gray-200);height:40px;width:40px}.devices-error{align-items:center;color:var(--error);display:flex;flex-direction:column;font-weight:500;gap:var(--space-4);justify-content:center;min-height:60vh}:root{--primary:#ff6b35;--primary-dark:#e55a2b;--primary-light:#ff8b5c;--secondary:#f7931e;--accent:#ffc947;--white:#fff;--black:#0a0a0a;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--success:#10b981;--success-light:#d1fae5;--error:#ef4444;--error-light:#fee2e2;--warning:#f59e0b;--info:#3b82f6;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a;--shadow-2xl:0 25px 50px -12px #00000040;--shadow-glow:0 0 30px #ff6b354d;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:300ms cubic-bezier(0.4,0,0.2,1);--transition-slow:500ms cubic-bezier(0.4,0,0.2,1);--transition-bounce:500ms cubic-bezier(0.68,-0.55,0.265,1.55)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:hidden}.modern-login-layout{align-items:center;background:linear-gradient(135deg,#0a0a0a,#1f2937);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.animated-background{height:100%;left:0;overflow:hidden;position:absolute;top:0;width:100%;z-index:0}.gradient-orb{animation:float 20s ease-in-out infinite;border-radius:50%;filter:blur(80px);opacity:.4;position:absolute}.orb-1{animation-delay:0s;background:radial-gradient(circle,#ff6b35 0,#0000 70%);background:radial-gradient(circle,var(--primary) 0,#0000 70%);height:600px;left:-10%;top:-10%;width:600px}.orb-2{animation-delay:7s;background:radial-gradient(circle,#f7931e 0,#0000 70%);background:radial-gradient(circle,var(--secondary) 0,#0000 70%);bottom:-15%;height:500px;right:-5%;width:500px}.orb-3{animation-delay:14s;background:radial-gradient(circle,#ffc947 0,#0000 70%);background:radial-gradient(circle,var(--accent) 0,#0000 70%);height:400px;left:50%;top:50%;transform:translate(-50%,-50%);width:400px}.grid-overlay{background-image:linear-gradient(#ff6b3508 1px,#0000 0),linear-gradient(90deg,#ff6b3508 1px,#0000 0);background-size:50px 50px;height:100%;left:0;opacity:.5;position:absolute;top:0;width:100%}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.modern-login-container{animation:slideUp .6s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:1.5rem;border-radius:var(--radius-2xl);box-shadow:0 25px 50px -12px #00000040,inset 0 0 100px #ff6b350d;box-shadow:var(--shadow-2xl),inset 0 0 100px #ff6b350d;display:grid;grid-template-columns:1fr 1fr;max-width:1400px;min-height:90vh;overflow:hidden;position:relative;width:95%;z-index:1}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modern-branding{background:linear-gradient(135deg,#ff6b351a,#f7931e1a);border-right:1px solid #ffffff1a;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;padding:3rem;padding:var(--space-12);position:relative}.modern-branding:before{animation:pulse 8s ease-in-out infinite;background:radial-gradient(circle,#ff6b3533 0,#0000 70%);content:"";height:100%;position:absolute;right:-50%;top:-50%;width:100%}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.branding-header{position:relative;z-index:1}.logo-container{height:80px;margin-bottom:1.5rem;margin-bottom:var(--space-6);position:relative;width:80px}.logo-glow{animation:glow 3s ease-in-out infinite;background:radial-gradient(circle,#ff6b35 0,#0000 70%);background:radial-gradient(circle,var(--primary) 0,#0000 70%);filter:blur(20px);inset:-10px;opacity:.6;position:absolute}@keyframes glow{0%,to{opacity:.4}50%{opacity:.8}}.logo-icon{drop-shadow:0 4px 20px #ff6b3580;animation:rotate 20s linear infinite;position:relative;z-index:1}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.brand-title-modern{-webkit-text-fill-color:#0000;animation:shimmer 3s ease-in-out infinite;background:linear-gradient(135deg,#ff6b35,#f7931e 50%,#ffc947);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 50%,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;background-size:200% 200%;font-size:3.5rem;font-weight:700;letter-spacing:-.05em;margin-bottom:.75rem;margin-bottom:var(--space-3)}@keyframes shimmer{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.brand-subtitle-modern{color:#ffffffb3;font-size:1.125rem;font-weight:400;letter-spacing:.05em}.features-grid{grid-gap:1rem;grid-gap:var(--space-4);display:grid;gap:1rem;gap:var(--space-4);grid-template-columns:repeat(2,1fr);margin:2.5rem 0;margin:var(--space-10) 0;position:relative;z-index:1}.feature-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;border:1px solid #ffffff1a;border-radius:.75rem;border-radius:var(--radius-lg);cursor:default;padding:1.25rem;padding:var(--space-5);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.feature-card:hover{background:#ffffff0d;border-color:#ff6b354d;box-shadow:0 10px 30px #ff6b3533;transform:translateY(-5px)}.feature-icon-modern{align-items:center;background:linear-gradient(135deg,#ff6b35,#f7931e);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border-radius:.5rem;border-radius:var(--radius-md);box-shadow:0 4px 15px #ff6b354d;display:flex;height:48px;justify-content:center;margin-bottom:1rem;margin-bottom:var(--space-4);width:48px}.feature-icon-modern svg{stroke:#fff;stroke-width:2}.feature-card h3{color:#fff;font-size:1.125rem;font-weight:600;margin-bottom:.5rem;margin-bottom:var(--space-2)}.feature-card p{color:#fff;font-size:.875rem;line-height:1.6}.stats-row{display:flex;gap:1.5rem;gap:var(--space-6);padding:1.5rem 0;padding:var(--space-6) 0;position:relative;z-index:1}.stat-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;border:1px solid #ffffff1a;border-radius:.75rem;border-radius:var(--radius-lg);flex:1 1;padding:1rem;padding:var(--space-4);text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.stat-item:hover{background:#ffffff0d;transform:scale(1.05)}.stat-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ff6b35,#ffc947);background:linear-gradient(135deg,var(--primary) 0,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;font-family:JetBrains Mono,monospace;font-size:2.5rem;font-weight:700}.stat-label{color:#fff9;font-size:.875rem;letter-spacing:.1em;margin-top:.5rem;margin-top:var(--space-2)}.trusted-by{position:relative;z-index:1}.trusted-label{color:#ffffff80;font-size:.875rem;letter-spacing:.1em;margin-bottom:1rem;margin-bottom:var(--space-4);text-align:center;text-transform:uppercase}.trust-badges{display:flex;flex-wrap:wrap;gap:.75rem;gap:var(--space-3);justify-content:center}.trust-badge{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:9999px;border-radius:var(--radius-full);color:#ffffffb3;font-size:.75rem;font-weight:500;padding:.5rem 1rem;padding:var(--space-2) var(--space-4)}.modern-form-side{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0a0a0a66;display:flex;justify-content:center;padding:3rem;padding:var(--space-12)}.modern-form-container{animation:fadeIn .8s ease-out .2s both;max-width:480px;width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.mobile-brand{align-items:center;display:none;gap:.75rem;gap:var(--space-3);margin-bottom:2rem;margin-bottom:var(--space-8)}.mobile-logo-icon{height:40px;width:40px}.mobile-brand span{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ff6b35,#ffc947);background:linear-gradient(135deg,var(--primary) 0,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700}.form-header-modern{margin-bottom:2rem;margin-bottom:var(--space-8)}.form-title-modern{color:#fff;font-size:2.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.75rem;margin-bottom:var(--space-3)}.form-subtitle-modern{color:#fff9;font-size:1rem;line-height:1.6}.mode-tabs-modern{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.75rem;border-radius:var(--radius-lg);display:flex;margin-bottom:2rem;margin-bottom:var(--space-8);padding:.25rem;padding:var(--space-1);position:relative}.tab-indicator{background:linear-gradient(135deg,#ff6b35,#f7931e);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border-radius:.5rem;border-radius:var(--radius-md);bottom:.25rem;bottom:var(--space-1);box-shadow:0 4px 15px #ff6b354d;position:absolute;top:.25rem;top:var(--space-1);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:calc(50% - 4px)}.tab-indicator.left{left:.25rem;left:var(--space-1)}.tab-indicator.right{left:calc(50% + 2px)}.mode-tab-modern{background:#0000;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:#fff9;cursor:pointer;flex:1 1;font-size:.9375rem;font-weight:600;padding:.75rem 1.25rem;padding:var(--space-3) var(--space-5);position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);z-index:1}.mode-tab-modern.active{color:#fff}.mode-tab-modern:hover:not(.active){color:#ffffffe6}.message-box{align-items:flex-start;animation:slideDown .3s ease-out;border-radius:.75rem;border-radius:var(--radius-lg);display:flex;font-size:.875rem;gap:.75rem;gap:var(--space-3);line-height:1.6;margin-bottom:1.5rem;margin-bottom:var(--space-6);padding:1rem;padding:var(--space-4)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-box{background:#ef44441a;border:1px solid #ef44444d;color:#fca5a5}.error-box svg{stroke:#fca5a5;stroke-width:2;flex-shrink:0}.success-box{background:#10b9811a;border:1px solid #10b9814d;color:#6ee7b7}.success-box svg{stroke:#6ee7b7;stroke-width:2;flex-shrink:0}.google-btn-modern{align-items:center;background:#fff;border:none;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 15px #0000001a;color:#374151;color:var(--gray-700);cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.75rem;gap:var(--space-3);justify-content:center;margin-bottom:1.5rem;margin-bottom:var(--space-6);padding:1rem;padding:var(--space-4);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.google-btn-modern:hover:not(:disabled){box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.google-btn-modern:disabled{cursor:not-allowed;opacity:.6}.divider-modern{margin:1.5rem 0;margin:var(--space-6) 0;position:relative;text-align:center}.divider-modern:before{background:linear-gradient(90deg,#0000,#ffffff1a 50%,#0000);content:"";height:1px;left:0;position:absolute;top:50%;width:100%}.divider-modern span{background:#0a0a0a66;color:#fff6;font-size:.875rem;font-weight:500;padding:0 1rem;padding:0 var(--space-4);position:relative}.modern-form{gap:1.5rem;gap:var(--space-6)}.input-group-modern,.modern-form{display:flex;flex-direction:column}.input-group-modern{gap:.5rem;gap:var(--space-2)}.input-label-modern{color:#ffffffe6;font-size:.875rem;font-weight:600;letter-spacing:.01em}.input-wrapper-modern{align-items:center;display:flex;position:relative}.input-icon-modern{stroke:#fff6;stroke-width:2;left:1rem;left:var(--space-4);pointer-events:none;position:absolute}.input-field-modern,.input-icon-modern{transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.input-field-modern{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.75rem;border-radius:var(--radius-lg);color:#fff;font-family:inherit;font-size:.9375rem;padding:1rem 1rem 1rem 3rem;padding:var(--space-4) var(--space-4) var(--space-4) var(--space-12);width:100%}.input-field-modern::placeholder{color:#ffffff4d}.input-field-modern:focus{background:#ffffff14;border-color:#ff6b35;border-color:var(--primary);box-shadow:0 0 0 3px #ff6b351a;outline:none}.input-field-modern:focus+.input-icon-modern,.input-wrapper-modern:focus-within .input-icon-modern{stroke:#ff6b35;stroke:var(--primary)}.toggle-password-modern{background:none;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:#fff6;cursor:pointer;padding:.5rem;padding:var(--space-2);position:absolute;right:1rem;right:var(--space-4);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.toggle-password-modern:hover{background:#ffffff0d;color:#fffc}.toggle-password-modern svg{stroke:currentColor;stroke-width:2;display:block}.password-strength{align-items:center;display:flex;gap:.75rem;gap:var(--space-3);margin-top:.5rem;margin-top:var(--space-2)}.strength-bar{background:#ffffff1a;flex:1 1;height:4px;overflow:hidden}.strength-bar,.strength-fill{border-radius:9999px;border-radius:var(--radius-full)}.strength-fill{height:100%;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.strength-label{font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.input-hint-modern{color:#fff6;font-size:.75rem;margin-top:.5rem;margin-top:var(--space-2)}.form-options{align-items:center;display:flex;justify-content:space-between;margin:-.5rem 0;margin:calc(var(--space-2)*-1) 0}.checkbox-label-modern{align-items:center;color:#ffffffb3;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;gap:var(--space-2);-webkit-user-select:none;user-select:none}.checkbox-label-modern input[type=checkbox]{opacity:0;pointer-events:none;position:absolute}.checkbox-custom{border:2px solid #ffffff4d;border-radius:.375rem;border-radius:var(--radius-sm);height:20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:20px}.checkbox-label-modern input:checked+.checkbox-custom{background:linear-gradient(135deg,#ff6b35,#f7931e);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border-color:#ff6b35;border-color:var(--primary)}.checkbox-label-modern input:checked+.checkbox-custom:after{border:solid #fff;border-width:0 2px 2px 0;content:"";height:8px;left:6px;position:absolute;top:2px;transform:rotate(45deg);width:4px}.forgot-link-modern{background:none;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:#ff6b35;color:var(--primary);cursor:pointer;font-size:.875rem;font-weight:600;margin:-.5rem;margin:calc(var(--space-2)*-1);padding:.5rem;padding:var(--space-2);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.forgot-link-modern:hover{background:#ff6b351a;color:#ff8b5c;color:var(--primary-light)}.submit-btn-modern{align-items:center;background:linear-gradient(135deg,#ff6b35,#f7931e);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border:none;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 15px #ff6b354d;color:#fff;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.75rem;gap:var(--space-3);justify-content:center;overflow:hidden;padding:1rem 1.5rem;padding:var(--space-4) var(--space-6);position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.submit-btn-modern:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.submit-btn-modern:hover:not(:disabled):before{left:100%}.submit-btn-modern:hover:not(:disabled){box-shadow:0 6px 25px #ff6b3566;transform:translateY(-2px)}.submit-btn-modern:active:not(:disabled){transform:translateY(0)}.submit-btn-modern:disabled{cursor:not-allowed;opacity:.6}.submit-btn-modern svg{stroke:currentColor;stroke-width:2}.spinner-modern{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.back-btn-modern{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.75rem;border-radius:var(--radius-lg);color:#ffffffb3;cursor:pointer;display:flex;font-size:.9375rem;font-weight:500;gap:.5rem;gap:var(--space-2);justify-content:center;padding:.75rem 1.25rem;padding:var(--space-3) var(--space-5);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}.back-btn-modern:hover:not(:disabled){background:#ffffff14;border-color:#fff3;color:#fff}.back-btn-modern svg{stroke:currentColor;stroke-width:2}.reset-info-box{background:#ff6b350d;border:1px solid #ff6b3533;border-radius:.75rem;border-radius:var(--radius-lg);margin-bottom:1.5rem;margin-bottom:var(--space-6);padding:1.5rem;padding:var(--space-6);text-align:center}.reset-info-box svg{stroke:#ff6b35;stroke:var(--primary);stroke-width:2;margin-bottom:1rem;margin-bottom:var(--space-4)}.reset-info-box p{color:#ffffffb3;line-height:1.6}.verify-email-modern{padding:2rem 0;padding:var(--space-8) 0;text-align:center}.verify-icon-large{align-items:center;animation:bounce 2s ease-in-out infinite;background:#ff6b351a;border:2px solid #ff6b354d;border-radius:50%;display:flex;height:120px;justify-content:center;margin:0 auto 1.5rem;margin:0 auto var(--space-6);width:120px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.verify-icon-large svg{stroke:#ff6b35;stroke:var(--primary);stroke-width:2}.verify-title{color:#fff;font-size:2rem;font-weight:700;margin-bottom:1rem;margin-bottom:var(--space-4)}.verify-text{color:#ffffffb3;font-size:1rem;line-height:1.8;margin-bottom:2rem;margin-bottom:var(--space-8);margin-left:auto;margin-right:auto;max-width:400px}.verify-actions{flex-direction:column;margin-bottom:1.5rem;margin-bottom:var(--space-6)}.resend-btn-modern,.verify-actions{display:flex;gap:.75rem;gap:var(--space-3)}.resend-btn-modern{align-items:center;background:linear-gradient(135deg,#ff6b35,#f7931e);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border:none;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 15px #ff6b354d;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;justify-content:center;padding:1rem 1.5rem;padding:var(--space-4) var(--space-6);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.resend-btn-modern:hover:not(:disabled){box-shadow:0 6px 25px #ff6b3566;transform:translateY(-2px)}.resend-btn-modern svg{stroke:currentColor;stroke-width:2}.verify-hint{color:#ffffff80;font-size:.875rem}.form-footer-modern{border-top:1px solid #ffffff1a;margin-top:2.5rem;margin-top:var(--space-10);padding-top:1.5rem;padding-top:var(--space-6);text-align:center}.admin-link-modern{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:9999px;border-radius:var(--radius-full);color:#fff9;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;gap:var(--space-2);margin-bottom:1.5rem;margin-bottom:var(--space-6);padding:.5rem 1rem;padding:var(--space-2) var(--space-4);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.admin-link-modern:hover:not(:disabled){background:#ffffff14;border-color:#ff6b354d;color:#ff6b35;color:var(--primary)}.admin-link-modern svg{stroke:currentColor;stroke-width:2}.terms-text{color:#fff6;font-size:.75rem;line-height:1.6;margin-bottom:1rem;margin-bottom:var(--space-4)}.terms-link{color:#ff6b35;color:var(--primary);font-weight:500;text-decoration:none;transition:color .3s cubic-bezier(.4,0,.2,1);transition:color var(--transition-base)}.terms-link:hover{color:#ff8b5c;color:var(--primary-light);text-decoration:underline}.support-text{color:#ffffff80;font-size:.875rem}.support-link{color:#ff6b35;color:var(--primary);font-weight:600;text-decoration:none;transition:color .3s cubic-bezier(.4,0,.2,1);transition:color var(--transition-base)}.support-link:hover{color:#ff8b5c;color:var(--primary-light);text-decoration:underline}@media (max-width:1200px){.modern-login-container{min-height:85vh;width:98%}.modern-branding,.modern-form-side{padding:2.5rem;padding:var(--space-10)}.features-grid{gap:.75rem;gap:var(--space-3)}}@media (max-width:968px){.modern-login-container{grid-template-columns:1fr;max-width:600px}.modern-branding{display:none}.modern-form-side{padding:2rem;padding:var(--space-8)}.mobile-brand{display:flex}.form-title-modern{font-size:2rem}}@media (max-width:640px){.modern-login-layout{padding:1rem;padding:var(--space-4)}.modern-login-container{min-height:auto;width:100%}.modern-form-side{padding:1.5rem;padding:var(--space-6)}.form-header-modern{margin-bottom:1.5rem;margin-bottom:var(--space-6)}.form-title-modern{font-size:1.75rem}.form-subtitle-modern{font-size:.9375rem}.mode-tabs-modern{margin-bottom:1.5rem;margin-bottom:var(--space-6)}.modern-form{gap:1.25rem;gap:var(--space-5)}.input-field-modern{font-size:1rem;padding:.75rem .75rem .75rem 2.5rem;padding:var(--space-3) var(--space-3) var(--space-3) var(--space-10)}.submit-btn-modern{padding:.75rem 1.25rem;padding:var(--space-3) var(--space-5)}.verify-title{font-size:1.5rem}.verify-icon-large{height:100px;width:100px}.verify-icon-large svg{height:64px;width:64px}}@media (max-width:480px){.modern-form-side{padding:1.25rem;padding:var(--space-5)}.form-title-modern{font-size:1.5rem}.features-grid{grid-template-columns:1fr}.stats-row{flex-direction:column;gap:.75rem;gap:var(--space-3)}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:focus-visible{outline:2px solid #ff6b35;outline:2px solid var(--primary);outline-offset:2px}.dashboard-layout{background:var(--gray-50);min-height:100vh}.dashboard-content{margin:0 auto;max-width:1400px;padding:var(--space-8) var(--space-6)}.dashboard-error,.dashboard-loading{align-items:center;display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;min-height:60vh}.loading-spinner{animation:spin .8s linear infinite;border:4px solid var(--gray-200);border-radius:50%;border-top-color:var(--infinos-orange-500);height:48px;width:48px}.dashboard-header{align-items:center;animation:fadeInUp var(--transition-slow);display:flex;justify-content:space-between;margin-bottom:var(--space-8)}.dashboard-title{color:var(--gray-900);font-size:2rem;font-weight:700;margin:0 0 var(--space-2) 0}.dashboard-subtitle{color:var(--gray-600);font-size:1rem;margin:0}.stats-grid{grid-gap:var(--space-6);animation:fadeInUp var(--transition-slow) .1s;display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:var(--space-8)}.stat-card{overflow:visible;position:relative}.stat-card:before{background:linear-gradient(90deg,var(--infinos-orange-500),var(--infinos-orange-400));border-radius:var(--radius-xl) var(--radius-xl) 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card-online:before{background:linear-gradient(90deg,var(--success),var(--success-dark))}.stat-card-offline:before{background:linear-gradient(90deg,var(--warning),var(--warning-dark))}.stat-card-alerts:before{background:linear-gradient(90deg,var(--info),var(--info-dark))}.stat-card .card-body{align-items:center;display:flex;flex-direction:column;padding:var(--space-5);text-align:center}.stat-icon{align-items:center;border-radius:var(--radius-lg);display:flex;height:40px;justify-content:center;margin-bottom:var(--space-3);width:40px}.stat-icon svg{stroke-width:2;height:20px;width:20px}.stat-icon-total{background:var(--infinos-orange-50);color:var(--infinos-orange-600)}.stat-icon-online{background:var(--success-light);color:var(--success-dark)}.stat-icon-offline{background:var(--warning-light);color:var(--warning-dark)}.stat-icon-alerts{background:var(--info-light);color:var(--info-dark)}.stat-label{color:var(--gray-500);font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.stat-label,.stat-value{margin:0 0 var(--space-1) 0}.stat-value{color:var(--gray-900);font-size:1.75rem;font-weight:700;line-height:1.2}.stat-description{color:var(--gray-500);font-size:.8125rem;margin:0}.stat-success{color:var(--success-dark)}.stat-warning{color:var(--warning-dark)}.devices-table-card{animation:fadeInUp var(--transition-slow) .2s}.devices-table-wrapper{overflow-x:auto}.devices-table{border-collapse:collapse;width:100%}.devices-table thead{background:var(--gray-50)}.devices-table th{border-bottom:1px solid var(--gray-200);font-weight:600;text-align:left}.devices-table td,.devices-table th{color:var(--gray-700);font-size:.875rem;padding:var(--space-4)}.devices-table td{border-bottom:1px solid var(--gray-100)}.device-row{transition:background var(--transition-base)}.device-row:hover{background:var(--gray-50)}.device-name-cell{gap:var(--space-3)}.device-icon,.device-name-cell{align-items:center;display:flex}.device-icon{background:var(--infinos-orange-50);border-radius:var(--radius-md);color:var(--infinos-orange-600);height:36px;justify-content:center;width:36px}.device-name{color:var(--gray-900);font-weight:600}.status-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-weight:600;gap:var(--space-2);padding:var(--space-1) var(--space-3)}.status-online{background:var(--success-light);color:var(--success-dark)}.status-offline{background:var(--gray-200);color:var(--gray-600)}.status-dot{animation:pulse 2s ease-in-out infinite;background:currentColor;border-radius:50%;height:6px;width:6px}.component-badges{display:flex;flex-wrap:wrap;gap:var(--space-2)}.component-badge{border-radius:var(--radius-md);font-size:.75rem;font-weight:500;padding:var(--space-1) var(--space-2)}.component-heater{background:var(--error-light);color:var(--error-dark)}.component-cooler{background:var(--info-light);color:var(--info-dark)}.component-battery{background:var(--warning-light);color:var(--warning-dark)}.action-buttons{display:flex;gap:var(--space-2)}.last-updated{color:var(--gray-500);font-size:.875rem}.empty-state{flex-direction:column;padding:var(--space-16) var(--space-8);text-align:center}.empty-state,.empty-state-icon{align-items:center;display:flex}.empty-state-icon{background:var(--gray-100);border-radius:var(--radius-full);color:var(--gray-400);height:80px;justify-content:center;margin-bottom:var(--space-6);width:80px}.empty-state-icon svg{stroke-width:1.5}.empty-state-title{color:var(--gray-900);font-size:1.5rem;font-weight:600;margin:0 0 var(--space-2) 0}.empty-state-description{color:var(--gray-600);font-size:1rem;margin:0 0 var(--space-6) 0}.quick-actions{animation:fadeInUp var(--transition-slow) .3s;margin-top:var(--space-8)}.quick-action-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.quick-action-btn{align-items:center;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);color:var(--gray-700);cursor:pointer;display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-6);transition:all var(--transition-base)}.quick-action-btn:hover{background:#fff;border-color:var(--infinos-orange-300);box-shadow:var(--shadow-md);color:var(--infinos-orange-600);transform:translateY(-2px)}.quick-action-btn svg{stroke-width:2}.quick-action-btn span{font-size:.875rem;font-weight:500}@media (max-width:768px){.dashboard-content{padding:var(--space-6) var(--space-4)}.dashboard-header{align-items:flex-start;flex-direction:column;gap:var(--space-4)}.dashboard-header-actions{flex-wrap:wrap;width:100%}.dashboard-title{font-size:1.5rem}.stats-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr)}.stat-card .card-body{padding:var(--space-3)}.stat-icon{height:32px;margin-bottom:var(--space-2);width:32px}.stat-icon svg{height:16px;width:16px}.stat-value{font-size:1.25rem}.stat-label{font-size:.7rem}.devices-table{font-size:.75rem}.devices-table td,.devices-table th{padding:var(--space-3) var(--space-2)}.action-buttons{flex-direction:column}.quick-action-grid{grid-template-columns:repeat(2,1fr)}}
/*# sourceMappingURL=main.6e6dacdb.css.map*/