.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;background:#fff}.login-logo{margin-bottom:1.5rem}.login-logo img{width:120px;height:auto}.login-box{background:var(--card-bg);border-radius:12px;box-shadow:0 8px 32px #0000001a;width:100%;max-width:400px;overflow:hidden}.login-header{background:var(--primary-color);color:#fff;padding:2rem 1.5rem;text-align:center}.login-header h1{font-size:1.75rem;margin-bottom:.5rem}.login-header p{opacity:.9;font-size:.95rem}.login-form{padding:2rem 1.5rem}.error-message{padding:.75rem;background:#ffebee;color:#c62828;border-radius:6px;margin-bottom:1.5rem;font-size:.9rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.password-input-wrapper{position:relative;width:100%}.password-input-wrapper input{width:100%;padding:.75rem 3rem .75rem .75rem;border:2px solid var(--border-color);border-radius:6px;font-size:1rem;transition:border-color .3s}.toggle-password-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.375rem .5rem;border-radius:4px;transition:background .2s;line-height:1;display:flex;align-items:center;justify-content:center}.toggle-password-btn:hover{background:#667eea1a}.toggle-password-btn:active{background:#667eea33}.form-group input{width:100%;padding:.75rem;border:2px solid var(--border-color);border-radius:6px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:var(--primary-color)}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.btn-login{width:100%;padding:.875rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}.btn-login:hover:not(:disabled){background:var(--primary-dark)}.btn-login:disabled{opacity:.6;cursor:not-allowed}.circular-gauge{width:100%;max-width:160px;flex-shrink:0}.gauge-svg{width:100%;height:auto;display:block}.gauge-value{font-size:1.75rem;font-weight:700;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif;letter-spacing:-.5px;dominant-baseline:middle}.gauge-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif}@media(max-width:480px){.circular-gauge{max-width:120px}.gauge-value{font-size:1.5rem}.gauge-label{font-size:.65rem}}.battery-indicator{width:100%;max-width:120px;flex-shrink:0}.battery-svg{width:100%;height:auto;display:block}.battery-value{font-size:.95rem;font-weight:700;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif;letter-spacing:-.5px}.battery-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif}@media(max-width:480px){.battery-indicator{max-width:100px}.battery-value{font-size:.85rem}.battery-label{font-size:.6rem}}.sensor-card{background:var(--card-bg);border-radius:12px;padding:1rem;min-height:140px;cursor:grab;transition:all .3s;box-shadow:0 2px 8px #0000001a;border:2px solid transparent;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif;display:flex;flex-direction:column;gap:.75rem;width:100%}.sensor-card:active{cursor:grabbing}.sensor-card-header-row{display:flex;justify-content:space-between;align-items:center;width:100%}.sensor-card.online{border-color:var(--success-color)}.sensor-card.warning{border-color:var(--warning-color)}.sensor-card.offline{border-color:var(--border-color);opacity:.7}.sensor-card.critical-alert{border-color:var(--danger-color);background:#ffebee;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 2px 8px #f443364d}50%{box-shadow:0 4px 16px #f4433699}}.sensor-card-drag-handle{width:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:grab;color:#666}.sensor-card-drag-handle svg{width:24px;height:24px}.sensor-card-drag-handle:active{cursor:grabbing}.sensor-card-status{width:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sensor-icon{font-size:2rem;display:none}.sensor-status-dot{width:12px;height:12px;border-radius:50%;background:var(--border-color)}.sensor-card.online .sensor-status-dot{background:var(--success-color);box-shadow:0 0 8px var(--success-color)}.sensor-card.warning .sensor-status-dot{background:var(--warning-color);box-shadow:0 0 8px var(--warning-color)}.sensor-card.offline .sensor-status-dot{background:var(--text-secondary)}.sensor-card-body{display:flex;flex-direction:column;gap:.75rem;flex:1;align-items:center}.sensor-info{display:flex;flex-direction:column;gap:.35rem;align-items:center;text-align:center;width:100%}.sensor-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);line-height:1.3;letter-spacing:-.3px;margin:0}.sensor-location{font-size:.85rem;color:var(--text-secondary);line-height:1.2}.gauges-container{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:1rem;width:100%;padding:0}.sensor-card-footer{display:flex;justify-content:center;width:100%}.no-data{text-align:center;padding:2rem 1rem;color:var(--text-secondary);font-size:.9rem}.sensor-value .alert-icon{font-size:1.25rem;animation:shake .5s infinite}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.sensor-value .value{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.sensor-card.critical-alert .sensor-value .value{color:var(--danger-color)}.sensor-time{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;min-width:fit-content}@media(max-width:480px){.sensor-card{padding:.75rem;min-height:130px;gap:.5rem}.sensor-name{font-size:1rem}.sensor-location{font-size:.75rem}.gauges-container{gap:.75rem}.sensor-time{font-size:.7rem}}@media(min-width:768px){.sensor-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}}.sensor-card.temp-high{border:2px solid #d32f2f!important;background:linear-gradient(135deg,#fff5f5,#ffebee)!important;box-shadow:0 4px 12px #d32f2f66!important}.sensor-card.temp-low{border:2px solid #1976d2!important;background:linear-gradient(135deg,#f5f9ff,#e3f2fd)!important;box-shadow:0 4px 12px #1976d266!important}.sensor-card.sensor-offline{opacity:.6!important}.offline-badge{background:#666;color:#fff;font-size:.65rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;letter-spacing:.5px;margin-top:.25rem}.offline-message{display:flex;flex-direction:column;align-items:center;gap:.25rem}.offline-message p:first-child{font-size:2rem;margin:0}.offline-message p:last-child{font-size:.85rem;color:#999;margin:0}.dashboard{min-height:100vh;background:var(--bg-color)}.dashboard-header{background:var(--primary-color);color:#fff;padding:.75rem 1rem;padding-top:max(.75rem,env(safe-area-inset-top));box-shadow:0 2px 8px #00000026}.header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;background:transparent!important}.header-logo{height:100px;width:auto;filter:brightness(0) invert(1)}.user-info{display:flex;align-items:center;gap:.75rem;background:transparent!important;padding:0;border-radius:0}.user-name{font-size:.9rem;opacity:.95}.btn-notifications{padding:0;margin:0;background:none!important;background-color:transparent!important;color:#fff;border:0;outline:0;cursor:pointer;transition:transform .2s ease;display:inline-flex;align-items:center;justify-content:center;position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;box-shadow:none!important;min-width:32px;min-height:32px}.btn-notifications:hover{transform:scale(1.1);background:none!important}.btn-notifications:active{transform:scale(.95);background:none!important}.btn-notifications:focus{outline:0;background:none!important}.btn-notifications:focus-visible{outline:0;background:none!important}.btn-notifications svg{width:24px;height:24px;display:block}.btn-logout{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:.85rem;cursor:pointer;transition:background .3s}.btn-logout:hover{background:#ffffff4d}.header-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.stat{display:flex;flex-direction:column;align-items:center;padding:.4rem .5rem;background:#ffffff26;border-radius:6px}.stat-value{font-size:.95rem;font-weight:700;color:#fff!important}.stat-label{font-size:.6rem;color:#fff!important;margin-top:.1rem}.filter-bar{display:flex;gap:.5rem;padding:1rem;overflow-x:auto;background:#fff;border-bottom:1px solid var(--border-color)}.filter-bar button{padding:.5rem 1rem;background:#e8f4fd;color:var(--primary-color);border:2px solid var(--primary-color);border-radius:20px;font-size:.85rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .3s}.filter-bar button.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.sensors-grid{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.no-sensors{grid-column:1 / -1;text-align:center;padding:3rem 1rem;color:var(--text-secondary)}@media(min-width:768px){.dashboard-header{padding:1.5rem 2rem}.dashboard-header h1{font-size:2rem}.sensors-grid{padding:2rem;gap:1.5rem}}.error-banner{background:linear-gradient(135deg,#ff416c,#ff4757);color:#fff;padding:1rem;margin:0 1rem 1rem;border-radius:8px;text-align:center;font-weight:500;box-shadow:0 4px 12px #ff416c4d}.alert-banner{background:linear-gradient(135deg,#ff9800,#ff5722);color:#fff;padding:1rem;margin:0 1rem 1rem;border-radius:8px;box-shadow:0 4px 12px #ff980066;animation:alertPulse 2s ease-in-out infinite}@keyframes alertPulse{0%,to{box-shadow:0 4px 12px #ff980066}50%{box-shadow:0 4px 20px #ff9800b3}}.alert-banner-header{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:1rem;margin-bottom:.75rem}.alert-icon{font-size:1.5rem;animation:shake .5s ease-in-out infinite}@keyframes shake{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.alert-title{flex:1}.alert-list{display:flex;flex-direction:column;gap:.5rem}.alert-item{background:#ffffff26;padding:.5rem .75rem;border-radius:6px;display:flex;flex-direction:column;gap:.25rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.alert-sensor-name{font-weight:600;font-size:.9rem}.alert-message{font-size:.85rem;opacity:.95}.alert-item.alert-high{border-left:4px solid #d32f2f}.alert-item.alert-low{border-left:4px solid #1976d2}.alert-item.alert-dismissible{cursor:pointer;transition:all .2s ease;position:relative}.alert-item.alert-dismissible:hover{background:#ffffff40;transform:scale(.98)}.alert-item.alert-dismissible:active{transform:scale(.95);opacity:.8}.temperature-chart{background:#fff;border-radius:12px;padding:1rem;margin:1rem 0;box-shadow:0 2px 8px #0000001a}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.chart-title{font-size:.9rem;font-weight:600;color:#333;margin:0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif}.chart-container{position:relative;width:100%}.chart-svg{width:100%;height:200px;display:block;cursor:crosshair}.chart-label{font-size:.4rem;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif}.chart-no-data{text-align:center;padding:2rem;color:#999;font-size:.9rem}.chart-stats{display:flex;justify-content:space-around;margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.stat-item{text-align:center}.stat-label{display:block;font-size:.7rem;color:#999;margin-bottom:.25rem;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif}.stat-value{display:block;font-size:1rem;font-weight:700;color:#2196f3;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif}.time-range-selector{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding:.25rem;-webkit-overflow-scrolling:touch}.time-range-btn{flex:1;min-width:50px;padding:.5rem .75rem;border:1px solid #ddd;border-radius:8px;background:#fff;color:#666;font-size:.85rem;font-weight:600;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif;cursor:pointer;transition:all .2s ease;white-space:nowrap}.time-range-btn:hover{background:#f5f5f5;border-color:#bbb}.time-range-btn.active{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff;border-color:#1976d2;box-shadow:0 2px 8px #2196f34d}.time-range-btn:active{transform:scale(.95)}.chart-tooltip{position:absolute;background:#000000e6;color:#fff;padding:.5rem .75rem;border-radius:8px;pointer-events:none;transform:translate(-50%,-120%);white-space:nowrap;box-shadow:0 4px 12px #0000004d;z-index:1000;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif}.tooltip-time{font-size:.7rem;opacity:.9;margin-bottom:.2rem}.tooltip-value{font-size:.95rem;font-weight:700;color:#ff5722}.gps-map-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;overflow:hidden;margin-bottom:16px}.gps-map-header{padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.gps-map-header h3{margin:0;font-size:1rem;font-weight:600}.gps-time-controls{display:flex;gap:6px}.gps-time-controls button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease}.gps-time-controls button:hover{background:#ffffff4d;transform:translateY(-1px)}.gps-time-controls button.active{background:#fff;color:#667eea;border-color:#fff}.gps-info-bar{background:#f3f4f6;padding:8px 16px;display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#6b7280;border-bottom:1px solid #e5e7eb}.gps-update-time{font-size:.75rem;opacity:.9}.gps-points-count{background:#ddd6fe;color:#667eea;padding:2px 8px;border-radius:12px;font-weight:600}.gps-map{width:100%;height:280px;position:relative;z-index:1}.gps-map-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffff2;padding:16px 24px;border-radius:8px;box-shadow:0 2px 8px #00000026;font-size:.9rem;color:#666;z-index:10}.gps-map-error{padding:32px 16px;text-align:center;color:#666}.gps-map-error .error-icon{font-size:2rem;display:block;margin-bottom:8px}.gps-map-error p{margin:0;font-size:.9rem}.leaflet-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.leaflet-popup-content-wrapper{border-radius:8px}.leaflet-popup-content{margin:12px}.custom-marker{background:transparent;border:none}@media(max-width:480px){.gps-map{height:250px}.gps-map-header{flex-direction:column;align-items:flex-start}.gps-update-time{font-size:.7rem}}@media(max-width:360px){.gps-map{height:220px}}.sensor-detail{min-height:100vh;background:var(--bg-color)}.detail-header{background:var(--primary-color);color:#fff;padding:1rem;padding-top:max(1rem,env(safe-area-inset-top));display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #00000026}.btn-back{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:.9rem;cursor:pointer;transition:background .3s}.btn-back:hover{background:#ffffff4d}.detail-header h1{font-size:1.25rem;font-weight:600;flex:1}.alert-banner{padding:1rem;margin:1rem;border-radius:8px;display:flex;align-items:center;gap:1rem}.alert-banner.critical{background:#ffebee;border-left:4px solid var(--danger-color);color:#c62828}.alert-banner .alert-icon{font-size:2rem;animation:shake .5s infinite}.detail-content{padding:1rem;display:flex;flex-direction:column;gap:1rem}.info-card{background:var(--card-bg);border-radius:8px;padding:.75rem;box-shadow:0 2px 8px #0000001a}.info-card h2{font-size:.85rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);padding-bottom:.3rem}.current-value-display{display:flex;flex-direction:column;gap:1rem;align-items:center;padding:1rem 0}.status-indicator{display:flex;align-items:center;gap:.4rem}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-secondary);flex-shrink:0}.status-indicator.online .status-dot{background:var(--success-color);box-shadow:0 0 8px var(--success-color)}.status-indicator.warning .status-dot{background:var(--warning-color);box-shadow:0 0 8px var(--warning-color)}.status-text{font-weight:600;font-size:.75rem;color:var(--text-primary)}.value-large{font-size:3rem;font-weight:700;color:var(--primary-color)}.info-grid{display:flex;flex-direction:column;gap:.35rem}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.35rem .5rem;background:var(--bg-color);border-radius:4px}.info-item.status-item{flex-direction:row;gap:0;align-items:center}.info-label{font-weight:500;color:var(--text-secondary);font-size:.75rem}.info-value{font-weight:600;color:var(--text-primary);text-align:right;font-size:.75rem}.device-data{display:flex;flex-direction:column;gap:.5rem}.data-row{display:flex;justify-content:space-between;padding:.75rem;background:var(--bg-color);border-radius:6px}.data-label{font-weight:500;color:var(--text-secondary);font-size:.85rem}.data-value{font-family:Courier New,monospace;color:var(--text-primary);font-size:.85rem}.message-list{max-height:400px;overflow-y:auto}.message-item{padding:.75rem;border-bottom:1px solid var(--border-color)}.message-item:last-child{border-bottom:none}.message-topic{font-size:.75rem;color:var(--primary-color);font-weight:600;margin-bottom:.25rem}.message-content{display:flex;justify-content:space-between;align-items:center}.message-value{font-family:Courier New,monospace;font-size:.9rem;color:var(--text-primary)}.message-time{font-size:.75rem;color:var(--text-secondary)}.loading-text,.no-messages,.no-data-message{text-align:center;color:var(--text-secondary);padding:2rem 1rem;font-size:.9rem}.readings-grid{display:grid;grid-template-columns:1fr;gap:1rem}.reading-card{background:var(--bg-color);border-radius:8px;padding:1.25rem;display:flex;flex-direction:column;gap:.5rem;border:2px solid var(--border-color);transition:all .3s}.reading-card.alert{border-color:var(--danger-color);background:#ffebee}.reading-label{font-size:.85rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.reading-value{font-size:2.5rem;font-weight:700;color:var(--primary-color);display:flex;align-items:center;gap:.5rem}.reading-card.alert .reading-value{color:var(--danger-color)}.reading-value .alert-icon{font-size:2rem;animation:shake .5s infinite}.reading-time{font-size:.75rem;color:var(--text-secondary)}@media(min-width:768px){.detail-content{padding:2rem;max-width:1200px;margin:0 auto}.info-grid{grid-template-columns:repeat(2,1fr)}.detail-header h1{font-size:1.75rem}.readings-grid{grid-template-columns:repeat(2,1fr)}}.gauges-container-detail{display:flex;justify-content:space-around;gap:2rem;padding:1rem;align-items:center}.notifications-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding-bottom:max(20px,env(safe-area-inset-bottom))}.notifications-header{background:#fffffff2;padding:12px 20px;padding-top:max(12px,env(safe-area-inset-top));box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:15px}.notifications-header h1{margin:0;font-size:1.3rem;color:#2d3748;flex:1}.back-button{background:transparent;border:none;color:#667eea;font-size:1rem;font-weight:600;cursor:pointer;padding:8px 12px;border-radius:6px;transition:background .2s}.back-button:hover{background:#667eea1a}.notifications-content{max-width:600px;margin:15px auto;padding:0 15px;padding-bottom:env(safe-area-inset-bottom)}.user-info{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;display:flex;align-items:center;gap:15px;box-shadow:0 4px 12px #0000001a}.user-icon{font-size:3rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%}.user-details h2{margin:0 0 5px;color:#2d3748;font-size:1.3rem}.user-email{margin:0;color:#718096;font-size:.9rem}.notification-settings{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 12px #0000001a}.settings-title{margin:0 0 5px;color:#2d3748;font-size:1.2rem}.settings-subtitle{margin:0 0 20px;color:#718096;font-size:.9rem}.setting-card{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f7fafc;border-radius:8px;margin-bottom:20px}.setting-header{display:flex;align-items:center;gap:15px;flex:1}.setting-icon{font-size:2rem}.setting-info h3{margin:0 0 5px;color:#2d3748;font-size:1.1rem}.setting-info p{margin:0;color:#718096;font-size:.85rem}.coming-soon-badge{display:inline-block;background:linear-gradient(135deg,#f6ad55,#ed8936);color:#fff;font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:10px;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.email-icon{background:linear-gradient(135deg,#4299e1,#3182ce);width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.telegram-icon{background:linear-gradient(135deg,#38b2ac,#319795);width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.push-icon{background:linear-gradient(135deg,#9f7aea,#805ad5);width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.toggle-switch{position:relative;display:inline-block;width:56px;height:30px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e0;transition:.3s;border-radius:30px}.slider:before{position:absolute;content:"";height:22px;width:22px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.slider{background:linear-gradient(135deg,#667eea,#764ba2)}input:checked+.slider:before{transform:translate(26px)}input:disabled+.slider{opacity:.5;cursor:not-allowed}.permission-status{margin-bottom:20px;display:flex;flex-direction:column;gap:8px}.status-message{padding:10px 15px;border-radius:8px;font-size:.85rem;font-weight:500}.status-message.success{background:#c6f6d5;color:#22543d;border-left:4px solid #38a169}.status-message.error{background:#fed7d7;color:#742a2a;border-left:4px solid #e53e3e}.status-message.info{background:#bee3f8;color:#2c5282;border-left:4px solid #3182ce}.notification-info{margin-bottom:20px}.notification-info h4{margin:0 0 12px;color:#2d3748;font-size:1rem}.notification-info ul{list-style:none;padding:0;margin:0}.notification-info li{padding:8px 0;color:#4a5568;font-size:.9rem;border-bottom:1px solid #e2e8f0}.notification-info li:last-child{border-bottom:none}.notification-note{background:#edf2f7;padding:15px;border-radius:8px;border-left:4px solid #667eea}.notification-note p{margin:0;color:#4a5568;font-size:.85rem;line-height:1.6}.notification-note strong{color:#2d3748}.unlink-button{background:transparent;border:1px solid #e53e3e;color:#e53e3e;padding:4px 10px;border-radius:4px;font-size:.75rem;cursor:pointer;margin-top:6px;transition:all .2s}.unlink-button:hover{background:#e53e3e;color:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.telegram-modal{background:#fff;border-radius:16px;width:100%;max-width:400px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000004d}.modal-close{position:absolute;top:12px;right:12px;background:#edf2f7;border:none;width:32px;height:32px;border-radius:50%;font-size:1.5rem;cursor:pointer;color:#4a5568;display:flex;align-items:center;justify-content:center;line-height:1}.modal-header{background:linear-gradient(135deg,#08c,#00a2e8);padding:25px 20px;text-align:center;border-radius:16px 16px 0 0}.telegram-logo{font-size:3rem;display:block;margin-bottom:10px}.modal-header h2{margin:0;color:#fff;font-size:1.4rem}.modal-body{padding:25px 20px}.modal-instructions{margin:0 0 20px;color:#4a5568;font-size:.95rem;text-align:center}.step{display:flex;gap:15px;margin-bottom:20px}.step-number{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.step-content{flex:1}.step-content p{margin:0 0 10px;color:#2d3748;font-size:.9rem}.code-box{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px 15px;display:flex;align-items:center;justify-content:space-between;gap:10px}.code-box code{font-family:Monaco,Menlo,monospace;font-size:1rem;color:#2d3748}.code-highlight{background:linear-gradient(135deg,#667eea15,#764ba215);border-color:#667eea}.code-highlight code{font-size:1.2rem;font-weight:700;color:#667eea;letter-spacing:2px}.copy-btn{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:5px;border-radius:4px;transition:background .2s}.copy-btn:hover{background:#e2e8f0}.verify-btn{width:100%;background:linear-gradient(135deg,#38a169,#2f855a);color:#fff;border:none;padding:14px 20px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.verify-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #38a16966}.code-expiry{margin:20px 0 0;text-align:center;color:#a0aec0;font-size:.8rem}.sensor-alerts-section{margin-top:25px;padding-top:20px;border-top:1px solid #e2e8f0}.loading-sensors,.no-sensors{text-align:center;padding:20px;color:#718096;font-size:.9rem}.sensor-list{display:flex;flex-direction:column;gap:10px}.sensor-alert-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#f7fafc;border-radius:8px;transition:background .2s}.sensor-alert-item:hover{background:#edf2f7}.sensor-alert-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.sensor-alert-icon{font-size:1.5rem;flex-shrink:0}.sensor-alert-details{display:flex;flex-direction:column;min-width:0}.sensor-alert-name{font-weight:600;color:#2d3748;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sensor-alert-sucursal{color:#718096;font-size:.8rem}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #1976d2;--primary-dark: #1565c0;--success-color: #4caf50;--warning-color: #ff9800;--danger-color: #f44336;--bg-color: #f5f5f5;--card-bg: #ffffff;--text-primary: #212121;--text-secondary: #757575;--border-color: #e0e0e0}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;background:var(--bg-color);color:var(--text-primary);line-height:1.6}#root,.app{min-height:100vh}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{padding:1rem;background:#fff3cd;color:#856404;border-left:4px solid var(--warning-color);margin:1rem;border-radius:4px}
