.history-modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.history-modal{animation:modalSlideIn .3s ease-out;background:linear-gradient(135deg,#fff,#f3f4f6);border-radius:16px;box-shadow:0 25px 50px -12px #00000080;display:flex;flex-direction:column;max-height:90vh;max-width:1200px;overflow:hidden;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.history-modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #fff3;color:#fff;display:flex;justify-content:space-between;padding:24px 32px}.history-modal-header h2{font-weight:600;gap:12px;margin:0}.close-btn,.history-modal-header h2{align-items:center;display:flex;font-size:1.5rem}.close-btn{background:#fff3;border:2px solid #ffffff4d;border-radius:50%;color:#fff;cursor:pointer;font-weight:700;height:40px;justify-content:center;transition:all .2s ease;width:40px}.close-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:rotate(90deg)}.history-modal-body{flex:1 1;overflow-y:auto;padding:24px 32px}.empty-state,.error-state,.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:60px 20px;text-align:center}.spinner{border:4px solid #e5e7eb;height:50px;width:50px}.loading-state p{color:#6b7280;font-size:1.1rem;margin:0}.error-state p{color:#dc2626;font-size:1.1rem;margin-bottom:20px}.error-state button{background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 24px;transition:background .2s ease}.error-state button:hover{background:#dc2626}.empty-state p{color:#9ca3af;font-size:1.2rem;margin:0}.charts-container{display:flex;flex-direction:column;gap:20px}.chart-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:24px}.chart-section h3{align-items:center;color:#1f2937;display:flex;font-size:1.25rem;font-weight:600;gap:8px;margin:0 0 20px}.history-info{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;margin-top:16px;padding:20px 24px;text-align:center}.history-info p{font-size:1rem;margin:8px 0}.history-info strong{font-size:1.1rem;font-weight:700}.date-range{font-size:.9rem!important;margin-top:4px!important;opacity:.9}@media (max-width:768px){.history-modal{border-radius:12px;margin:0;max-height:95vh;max-width:100%}.history-modal-header{padding:16px 20px}.history-modal-header h2{font-size:1.2rem}.history-modal-body{padding:16px 20px}.chart-section{padding:16px}.chart-section h3{font-size:1.1rem}}.history-modal-body::-webkit-scrollbar{width:8px}.history-modal-body::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.history-modal-body::-webkit-scrollbar-thumb{background:#9ca3af;border-radius:4px}.history-modal-body::-webkit-scrollbar-thumb:hover{background:#6b7280}.debug-btn{background:#ffffff26;border:2px solid #ffffff4d;border-radius:20px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;padding:6px 14px;transition:all .2s ease;white-space:nowrap}.debug-btn:hover{background:#ffffff40;border-color:#ffffff80}.debug-btn.active{background:#ffc8004d;border-color:#ffc80099}.debug-table-container{padding:4px 0}.debug-info{color:#6b7280;font-size:.85rem;margin-bottom:12px}.debug-table-scroll{border:1px solid #e5e7eb;border-radius:8px;overflow-x:auto}.debug-table{border-collapse:collapse;font-size:.82rem;min-width:700px;width:100%}.debug-table thead tr{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.debug-table th{font-weight:600;padding:10px 12px;text-align:left;white-space:nowrap}.debug-table td{border-bottom:1px solid #f3f4f6;font-family:monospace;padding:7px 12px;white-space:nowrap}.debug-table tr.even td{background:#fff}.debug-table tr.odd td{background:#f9fafb}.debug-table tr:hover td{background:#eff6ff}.debug-table td.cell-nan{color:#ef4444;font-weight:600}.top5-section{margin-top:4px}.top5-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.top5-column{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.top5-column-header{color:#fff;font-size:.88rem;font-weight:700;letter-spacing:.04em;padding:10px 14px;text-align:center;text-transform:uppercase}.top5-header-today{background:linear-gradient(135deg,#3b82f6,#2563eb)}.top5-header-week{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.top5-header-total{background:linear-gradient(135deg,#10b981,#059669)}.top5-row{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;font-size:.85rem;gap:8px;padding:8px 12px}.top5-row:last-child{border-bottom:none}.top5-row:nth-child(odd){background:#fafafa}.top5-rank{align-items:center;background:#e5e7eb;border-radius:50%;color:#374151;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:20px;justify-content:center;width:20px}.top5-row:first-of-type .top5-rank{background:#fbbf24;color:#78350f}.top5-date{font-feature-settings:"tnum";color:#6b7280;flex:1 1;font-size:.82rem;font-variant-numeric:tabular-nums}.top5-value{font-feature-settings:"tnum";color:#1f2937;font-size:.9rem;font-variant-numeric:tabular-nums;font-weight:700;white-space:nowrap}.top5-empty{color:#9ca3af;font-size:.85rem;font-style:italic;padding:20px 12px;text-align:center}@media (max-width:768px){.top5-grid{gap:12px;grid-template-columns:1fr}}[data-theme=dark] .history-modal{background:linear-gradient(135deg,#1e2340,#16213e)}[data-theme=dark] .history-modal-body{background:#0000}[data-theme=dark] .chart-section{background:#1e233ce6;border-color:#ffffff14}[data-theme=dark] .chart-section h3{color:#e2e8f0}[data-theme=dark] .history-modal-body::-webkit-scrollbar-track{background:#1e2340}[data-theme=dark] .history-modal-body::-webkit-scrollbar-thumb{background:#374151}[data-theme=dark] .debug-table-scroll{border-color:#374151}[data-theme=dark] .debug-info{color:#94a3b8}[data-theme=dark] .debug-table tr.even td{background:#1e2340;color:#e2e8f0}[data-theme=dark] .debug-table tr.odd td{background:#252b50;color:#e2e8f0}[data-theme=dark] .debug-table tr:hover td{background:#2d3561}[data-theme=dark] .debug-table td{border-color:#2d3748}[data-theme=dark] .top5-column{border-color:#ffffff14}[data-theme=dark] .top5-row{border-color:#ffffff0f}[data-theme=dark] .top5-row:nth-child(odd){background:#ffffff08}[data-theme=dark] .top5-rank{background:#374151;color:#d1d5db}[data-theme=dark] .top5-date{color:#94a3b8}[data-theme=dark] .top5-value{color:#e2e8f0}[data-theme=dark] .top5-empty{color:#4b5563}.device-card{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:#ffffffbf;border:1px solid #fff9;border-left:5px solid #ffffff80;border-radius:16px;box-shadow:0 8px 24px #0000001f,inset 0 1px 0 #ffffffe6;padding:20px 20px 35px;position:relative;transition:all .3s ease}.device-card:hover{background:#ffffffe0;box-shadow:0 12px 32px #0000002e,inset 0 1px 0 #fffffff2;transform:translateY(-2px)}.device-card.card-active{border-left-color:#22c55e}.device-card.card-active .device-icon{background:#22c55e2e;color:#16a34a}.device-card.card-dimmer{border-left-color:#f97316}.device-card.card-dimmer .device-icon{background:#f973162e;color:#ea580c}.device-card.card-inactive{border-left-color:#d1d5db}.device-card.card-inactive .device-icon{background:#9ca3af2e;color:#6b7280}.device-card.card-sensor{border-left-color:#38bdf8}.device-card.card-sensor .device-icon{background:#38bdf82e;color:#0284c7}.device-card.card-energy{border-left-color:#eab308}.device-card.card-energy .device-icon{background:#eab3082e;color:#ca8a04}.device-card.card-shutter{border-left-color:#64748b}.device-card.card-shutter .device-icon{background:#64748b2e;color:#475569}.device-card.card-alert{border-left-color:#ef4444}.device-card.card-alert .device-icon{background:#ef44442e;color:#dc2626}.device-card.card-motion{border-left-color:#f97316}.device-card.card-motion .device-icon{background:#f973162e;color:#ea580c}.device-card.card-gate{border-left-color:#f59e0b}.device-card.card-gate .device-icon{background:#f59e0b2e;color:#d97706}.device-card.card-scene{border-left-color:#8b5cf6}.device-card.card-scene .device-icon{background:#8b5cf62e;color:#7c3aed}.device-card.card-default{border-left-color:#e5e7eb}.device-card.card-default .device-icon{background:#f0f0f0}.device-card:hover{border-color:#667eea;box-shadow:0 8px 20px #00000026}.device-header{display:flex;gap:15px;margin-bottom:20px}.device-icon{align-items:center;background:#f0f0f0;border-radius:8px;display:flex;font-size:32px;height:50px;justify-content:center;min-width:50px;transition:background .3s ease,color .3s ease}.device-info{flex:1 1}.device-actions{align-items:flex-start}.device-favorite-btn{background:#0000;border:none;border-radius:6px;cursor:pointer;font-size:22px;line-height:1;padding:4px 8px;transition:all .2s ease}.device-favorite-btn:hover{background:#fff3cd;transform:scale(1.1)}.device-favorite-btn.active{color:#ffc107;filter:drop-shadow(0 0 4px rgba(255,193,7,.5))}.device-details-btn{align-self:flex-start;background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;color:#4c51bf;cursor:pointer;font-size:12px;font-weight:600;padding:6px 10px;transition:all .2s ease}.device-details-btn:hover{background:#e0e7ff;border-color:#a5b4fc}.device-name{color:#333;font-size:18px;font-weight:700;line-height:1.2;margin:0}.device-type{color:#999;font-size:12px;letter-spacing:.5px;margin:4px 0 0;text-transform:uppercase}.device-room{color:#667eea;font-size:12px;font-weight:500;margin:2px 0 0}.device-lastupdate{bottom:8px;color:#bbb;cursor:default;font-size:10px;font-weight:300;opacity:.7;position:absolute;right:12px;transition:all .2s ease}.device-lastupdate:hover{color:#333;font-weight:400;opacity:1}.btn-history{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;bottom:8px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:600;gap:4px;left:12px;opacity:.8;padding:6px 12px;position:absolute;transition:all .2s ease}.btn-history:hover{box-shadow:0 4px 8px #667eea66;opacity:1;transform:translateY(-1px)}.btn-history:active{transform:translateY(0)}.device-status{align-items:center;background:#f8f8f8;border-radius:8px;display:flex;font-size:14px;justify-content:space-between;margin-bottom:15px;padding:10px 15px}.status-label{color:#666;font-weight:500}.status-value{color:#333;font-size:16px;font-weight:700}.devdoor-section{align-items:center;display:flex;justify-content:center;margin-bottom:10px;padding:15px}.devdoor-container{align-items:center;display:flex;flex-direction:column;gap:10px}.devdoor-icon{height:148px;transition:transform .3s ease;width:120px}.devdoor-icon.door-open{animation:door-pulse 2s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(220,38,38,.5)) drop-shadow(0 4px 8px rgba(0,0,0,.2))}.devdoor-icon.door-closed{filter:drop-shadow(0 4px 10px rgba(0,0,0,.2)) drop-shadow(0 1px 3px rgba(0,0,0,.1))}.door-svg{height:100%;width:100%}.devdoor-status{border-radius:20px;font-size:15px;font-weight:700;letter-spacing:.3px;padding:4px 16px}.devdoor-status.status-open{background:#dc26261a;border:1.5px solid #dc26264d;color:#dc2626}.devdoor-status.status-closed{background:#6b72801a;border:1.5px solid #6b728040;color:#6b7280}@keyframes door-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.temperature-display{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.temp-value{align-items:flex-start;color:#667eea;display:flex;font-size:48px;font-weight:700;gap:4px;line-height:1}.temp-unit{color:#999;font-size:24px;font-weight:400;margin-top:4px}.humidity-value{color:#64b5f6;font-size:32px;font-weight:700}.shutter-control{margin-bottom:10px}.shutter-buttons{display:flex;flex-direction:column;gap:8px;margin:0 auto;max-width:200px}.shutter-btn{align-items:center;background:linear-gradient(145deg,#f8f8f8,#e0e0e0);border:none;border-radius:10px;box-shadow:0 6px 12px #0003,0 3px 6px #00000026,inset 0 -3px 6px #00000026,inset 0 3px 6px #fff6;color:#333;cursor:pointer;display:flex;font-weight:600;gap:15px;justify-content:flex-start;overflow:hidden;padding:12px 20px;position:relative;transition:all .2s ease}.shutter-btn:before{background:linear-gradient(180deg,#ffffff4d,#0000);content:"";height:50%;left:0;pointer-events:none;position:absolute;right:0;top:0}.shutter-btn:hover:not(:disabled){background:linear-gradient(145deg,#fff,#e8e8e8);box-shadow:0 8px 16px #00000040,0 4px 8px #0003,inset 0 -3px 6px #00000026,inset 0 3px 6px #ffffff80;transform:translateY(-2px)}.shutter-btn:active:not(:disabled){box-shadow:0 2px 4px #0003,inset 0 4px 8px #00000040,inset 0 -2px 4px #fff3;transform:translateY(1px)}.shutter-btn:disabled{cursor:not-allowed;opacity:.5}.shutter-icon{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));font-size:20px;font-weight:700}.shutter-label{font-size:14px;text-shadow:0 1px 2px #fffc}.shutter-up{border-left:5px solid #4caf50;box-shadow:0 6px 12px #4caf504d,0 3px 6px #00000026,inset 0 -3px 6px #00000026,inset 0 3px 6px #fff6}.shutter-up:hover:not(:disabled){box-shadow:0 8px 16px #4caf5066,0 4px 8px #0003,inset 0 -3px 6px #00000026,inset 0 3px 6px #ffffff80}.shutter-down{border-left:5px solid #f44336;box-shadow:0 6px 12px #f443364d,0 3px 6px #00000026,inset 0 -3px 6px #00000026,inset 0 3px 6px #fff6}.shutter-down:hover:not(:disabled){box-shadow:0 8px 16px #f4433666,0 4px 8px #0003,inset 0 -3px 6px #00000026,inset 0 3px 6px #ffffff80}.switch-control{margin-top:20px}.switch-button,.switch-control{align-items:center;display:flex;justify-content:center}.switch-button{border:none;border-radius:50%;box-shadow:0 10px 20px #00000059,0 6px 10px #00000040,inset 0 -5px 10px #00000059,inset 0 5px 10px #ffffff40;cursor:pointer;height:100px;position:relative;transition:all .3s ease;width:100px}.switch-button:before{background:#ffffff59;border-radius:50%;content:"";filter:blur(10px);height:30%;left:20%;position:absolute;right:20%;top:10px}.switch-button:hover{box-shadow:0 14px 24px #00000073,0 8px 14px #00000059,inset 0 -5px 10px #00000059,inset 0 5px 10px #ffffff40;transform:scale(1.08)}.switch-button:active{box-shadow:0 5px 10px #00000059,inset 0 5px 15px #00000073,inset 0 -3px 6px #ffffff26;transform:scale(.98)}.switch-button:disabled{cursor:not-allowed;opacity:.5}.switch-off{background:linear-gradient(145deg,#7c8591,#4b5563);border:3px solid #2d3748}.switch-off:hover:not(:disabled){background:linear-gradient(145deg,#8c95a1,#5b6573)}.switch-on{background:linear-gradient(145deg,#34d870,#16a34a);border:3px solid #15803d;box-shadow:0 8px 16px #22c55e80,0 4px 8px #22c55e4d,inset 0 -4px 8px #0000004d,inset 0 4px 8px #ffffff4d}.switch-on:hover:not(:disabled){background:linear-gradient(145deg,#44e880,#26b35a);box-shadow:0 12px 20px #22c55e99,0 6px 12px #22c55e66,inset 0 -4px 8px #0000004d,inset 0 4px 8px #ffffff4d}.switch-label{color:#fff;font-size:24px;font-weight:700;letter-spacing:1.5px;text-shadow:0 2px 6px #0006;z-index:1}.device-actions{display:flex;gap:8px;margin-bottom:10px}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:700;justify-content:center;min-height:40px;padding:10px 12px;transition:all .3s}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-on{background:#4caf50;color:#fff}.btn-on:hover:not(:disabled){background:#45a049;transform:scale(1.05)}.btn-toggle{background:#ff9800;color:#fff}.btn-toggle:hover:not(:disabled){background:#fb8c00;transform:scale(1.05)}.btn-off{background:#f44336;color:#fff}.btn-off:hover:not(:disabled){background:#da190b;transform:scale(1.05)}.error-message{background:#ffe6e6;border-left:3px solid #d32f2f;color:#d32f2f;font-size:12px;margin-bottom:10px;padding:8px 12px}.loading-spinner{border:2px solid #f0f0f0;height:20px;position:absolute;right:10px;top:10px;width:20px}.barometer{align-items:center;cursor:pointer;display:flex;justify-content:center;margin-bottom:10px;padding:10px 0}.barometer-svg{filter:drop-shadow(0 4px 8px rgba(0,0,0,.15));height:220px;width:220px}.barometer-overlay{align-items:center;animation:baro-overlay-in .5s ease forwards;background:#0f172a00;display:flex;inset:0;justify-content:center;position:fixed;z-index:30}.barometer-overlay.closing{animation:baro-overlay-out .5s ease forwards;pointer-events:none}@keyframes baro-overlay-in{0%{background:#0f172a00}to{background:#0f172abf}}@keyframes baro-overlay-out{0%{background:#0f172abf}to{background:#0f172a00}}.barometer-zoomed{align-items:center;animation:baro-zoom-in .6s cubic-bezier(.22,1,.36,1) forwards;cursor:pointer;display:flex;flex-direction:column}.barometer-zoomed.closing{animation:baro-zoom-out .5s ease forwards}@keyframes baro-zoom-in{0%{opacity:0;transform:translate(0) scale(.15);transform:translate(var(--baro-dx,0),var(--baro-dy,0)) scale(.15)}40%{opacity:1}to{opacity:1;transform:translate(0) scale(1)}}@keyframes baro-zoom-out{0%{opacity:1;transform:translate(0) scale(1)}60%{opacity:.6}to{opacity:0;transform:translate(0) scale(.15);transform:translate(var(--baro-dx,0),var(--baro-dy,0)) scale(.15)}}.barometer-svg-zoomed{filter:drop-shadow(0 8px 24px rgba(0,0,0,.4));height:min(500px,85vw);width:min(500px,85vw)}.barometer-title{color:#fff;font-family:serif;font-size:22px;font-weight:700;margin:0 0 10px;text-shadow:0 2px 4px #0000004d}.barometer-subtitle{color:#ffffffd9;font-family:serif;font-size:16px;margin:10px 0 0}.barometer-close{background:#ffffff26;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:20px;height:40px;position:absolute;right:20px;top:20px;transition:background .2s;width:40px;z-index:31}.barometer-close:hover{background:#ffffff4d}@media (max-width:480px){.barometer-svg{height:180px;width:180px}.barometer-svg-zoomed{height:90vw;width:90vw}.barometer-title{font-size:18px}}.lux-widget{align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:16px;display:flex;flex-direction:column;margin-bottom:8px;margin-top:12px;padding:14px 8px 8px}.lux-arc-svg{height:130px;overflow:visible;width:200px}.lux-labels{color:#9ca3af;display:flex;font-size:10px;font-weight:500;justify-content:space-between;margin-top:4px;padding:0 4px;width:200px}.lux-label-current{color:#6b7280;font-weight:700}[data-theme=dark] .lux-widget{background:#ffffff0a;border-color:#ffffff14}[data-theme=dark] .lux-labels{color:#4b5563}[data-theme=dark] .lux-label-current{color:#9ca3af}.barometer-container{align-items:center;display:flex;justify-content:center;margin-top:15px;padding:10px}.barometer-compact{cursor:pointer;height:180px;transition:transform .2s ease;width:180px}.barometer-compact:hover{transform:scale(1.05)}.barometer-svg-compact{height:100%;width:100%}@media (max-width:768px){.barometer-container{padding:5px}.barometer-compact{height:140px;width:140px}}.dimmer-control{flex-direction:column;gap:16px;margin-top:15px}.dimmer-control,.dimmer-top{align-items:center;display:flex}.dimmer-top{gap:20px}.switch-button--small{height:70px!important;width:70px!important}.dimmer-percent{color:#f97316;font-size:32px;font-weight:700;min-width:70px;text-align:center}.dimmer-slider{appearance:none;background:linear-gradient(90deg,#f97316,#fde68a);border-radius:4px;cursor:pointer;height:8px;outline:none;width:100%}.dimmer-slider::-webkit-slider-thumb{-webkit-appearance:none;background:#f97316;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #f9731680;cursor:grab;height:24px;-webkit-transition:transform .1s ease;transition:transform .1s ease;width:24px}.dimmer-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.2)}.dimmer-slider::-moz-range-thumb{background:#f97316;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #f9731680;cursor:grab;height:24px;width:24px}.dimmer-slider:disabled{cursor:not-allowed;opacity:.5}.rgb-control{align-items:center;display:flex;flex-direction:column;gap:16px;margin-top:15px}.rgb-brightness-slider{background:linear-gradient(90deg,#1a1a1a,#fff)!important}.rgb-palette{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.rgb-color-btn{border:3px solid #fffc;border-radius:50%;box-shadow:0 2px 6px #00000040;cursor:pointer;height:32px;transition:all .2s ease;width:32px}.rgb-color-btn:hover:not(:disabled){border-color:#fff;box-shadow:0 4px 12px #00000059;transform:scale(1.2)}.rgb-color-btn:disabled{cursor:not-allowed;opacity:.5}.baie-vitree-display{align-items:center;display:flex;justify-content:center;min-height:140px;padding:20px}.vibrating{animation:vibrate .3s infinite}@keyframes vibrate{0%,to{transform:translate(0) rotate(0deg)}10%{transform:translate(-2px,-1px) rotate(-1deg)}20%{transform:translate(2px,1px) rotate(1deg)}30%{transform:translate(-2px,1px) rotate(-.5deg)}40%{transform:translate(2px,-1px) rotate(.5deg)}50%{transform:translate(-1px,2px) rotate(-1deg)}60%{transform:translate(1px,-2px) rotate(1deg)}70%{transform:translate(-2px,-1px) rotate(-.5deg)}80%{transform:translate(2px,1px) rotate(.5deg)}90%{transform:translate(-1px,-2px) rotate(-1deg)}}.portail-display{cursor:pointer;flex-direction:column;min-height:180px}.ordi-status-display,.portail-display{align-items:center;display:flex;justify-content:center;padding:20px}.ordi-status-display{border-radius:8px;font-size:18px;font-weight:700}.pv-production{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde047 50%,#facc15);border:2px solid #eab308;border-radius:12px;box-shadow:0 4px 12px #eab30833;display:flex;flex-direction:column;gap:10px;margin-top:15px;padding:20px;transition:all .3s ease}.pv-production:hover{box-shadow:0 6px 16px #eab3084d;transform:translateY(-2px)}.pv-icon{font-size:48px;text-shadow:0 2px 4px #0000001a}.pv-value{color:#78350f;font-size:32px;font-weight:700;text-align:center;text-shadow:0 1px 2px #ffffff80}.phone-presence-display{margin:12px 0}.phone-presence-display,.presence-status{align-items:center;display:flex;justify-content:center}.presence-status{border-radius:10px;box-shadow:0 2px 8px #0000001a;font-size:18px;font-weight:600;gap:8px;min-width:140px;padding:12px 24px;text-align:center;transition:all .3s ease}.presence-icon{font-size:32px;transition:all .3s ease}.presence-text{font-size:16px}.presence-status.present{animation:pulse-present 2s ease-in-out infinite;background:linear-gradient(135deg,#fff,#f5f5f5);border:2px solid #dc2626;color:#dc2626}.presence-status.present .presence-icon{filter:hue-rotate(0deg) saturate(2)}.presence-status.absent{background:linear-gradient(135deg,#f5f5f5,#e5e5e5);border:2px solid #d1d5db;color:#6b7280}.presence-status.absent .presence-icon{filter:grayscale(100%) opacity(.7)}@keyframes pulse-present{0%,to{box-shadow:0 4px 12px #10b9814d}50%{box-shadow:0 6px 20px #10b98180}}@media (max-width:480px){.device-card{padding:15px}.device-header{gap:12px;margin-bottom:15px}.device-icon{font-size:28px;height:45px;min-width:45px}.device-name{font-size:16px}.btn{font-size:14px;min-height:36px;padding:8px 10px}}[data-theme=dark] .device-card{background:var(--card-bg);border-color:var(--card-border);box-shadow:var(--card-shadow)}[data-theme=dark] .device-card:hover{background:var(--card-bg-hover);border-color:#667eea66;box-shadow:var(--card-shadow-hover)}[data-theme=dark] .device-name{color:var(--text-primary)}[data-theme=dark] .device-type{color:var(--text-muted)}[data-theme=dark] .device-room{color:#818cf8}[data-theme=dark] .device-lastupdate{color:#475569}[data-theme=dark] .device-lastupdate:hover{color:#94a3b8}[data-theme=dark] .device-details-btn{background:#1e2340;border-color:#3730a3;color:#818cf8}[data-theme=dark] .device-details-btn:hover{background:#252b50;border-color:#4f46e5}[data-theme=dark] .device-favorite-btn:hover{background:#ffc1071a}[data-theme=dark] .error-message{background:#ef444426;border-color:#dc2626;color:#f87171}[data-theme=dark] .device-status{background:#ffffff0f;color:var(--text-secondary)}[data-theme=dark] .status-label{color:#94a3b8}[data-theme=dark] .status-value{color:#e2e8f0}[data-theme=dark] .switch-button.switch-off{background:#374151;border-color:#4b5563;color:#9ca3af}[data-theme=dark] .switch-button.switch-off:hover:not(:disabled){background:#4b5563}[data-theme=dark] .dimmer-percent{color:#fb923c}[data-theme=dark] .dimmer-slider{accent-color:#f97316}[data-theme=dark] .temp-value{color:#fca5a5}[data-theme=dark] .humidity-value{color:#93c5fd}[data-theme=dark] .pv-production{background:#eab3081a;border-color:#eab3084d}[data-theme=dark] .pv-value{color:#fde047}[data-theme=dark] .presence-status{color:var(--text-secondary)}[data-theme=dark] .presence-status.present{background:linear-gradient(135deg,#dc262626,#dc262614);color:#fca5a5}[data-theme=dark] .presence-status.absent{background:linear-gradient(135deg,#1e233ccc,#2d3748cc);color:#94a3b8}[data-theme=dark] .barometer,[data-theme=dark] .barometer-compact{background:#1e233c99}[data-theme=dark] .btn-history{background:#667eea26;border-color:#667eea4d;color:#818cf8}[data-theme=dark] .btn-history:hover{background:#667eea40}[data-theme=dark] .btn-on{background:#10b98126;border-color:#10b9814d;color:#34d399}[data-theme=dark] .btn-toggle{background:#3b82f626;border-color:#3b82f64d;color:#60a5fa}[data-theme=dark] .btn-off{background:#ef444426;border-color:#ef44444d;color:#f87171}[data-theme=dark] .shutter-btn{background:#1e2340;border-color:#374151;color:#94a3b8}[data-theme=dark] .shutter-btn:hover:not(:disabled){background:#252b50}[data-theme=dark] .ordi-status-display{background:#1e233ccc!important;border-color:#374151!important}.device-list-container{margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.device-list-header{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:#ffffffbf;border:1px solid #fff9;border-radius:16px;box-shadow:0 8px 24px #0000001a;margin-bottom:30px;padding:30px}.device-list-header h1{color:#1e1b4b;font-size:28px;font-weight:700;margin:0 0 20px}.header-actions{align-items:center;display:flex;gap:10px}.search-input{border:2px solid #ddd;flex:1 1;padding:10px 15px;transition:border-color .3s}.search-input:focus{outline:none}.refresh-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:700;padding:10px 20px;transition:background .3s}.refresh-btn:hover:not(:disabled){background:#764ba2}.refresh-btn:disabled{cursor:not-allowed;opacity:.6}.error-banner{align-items:center;background:#fee;border:2px solid #f88;border-radius:8px;color:#d33;display:flex;justify-content:space-between;margin-bottom:20px;padding:15px 20px}.error-banner button{background:#f88;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 16px}.loading-container{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.spinner{animation:spin 1s linear infinite;border:4px solid #f0f0f0;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:20px;width:40px}.loading-container p{color:#666;font-size:16px}.empty-state{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;color:#999;font-size:18px;padding:60px 20px}.room-group{margin-bottom:30px}.room-title{border-left:4px solid #fff;color:#fff;margin-bottom:15px;padding-left:10px}.devices-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:20px}@media (max-width:768px){.devices-grid{gap:15px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media (max-width:480px){.devices-grid{gap:10px;grid-template-columns:1fr}.device-list-header{padding:20px}.device-list-header h1{font-size:22px;margin-bottom:15px}.header-actions{flex-direction:column}.refresh-btn,.search-input{width:100%}}.device-list-footer{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;color:#666;margin-top:30px;padding:20px;text-align:center}.device-list-footer p{font-size:14px;margin:0}.device-modal-overlay{align-items:center;background:#0f172a99;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:20}.device-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0003;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:min(900px,95vw)}.device-modal-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px 10px}.device-modal-header h2{color:#111827;font-size:20px;margin:0}.device-modal-header p{color:#6b7280;font-size:13px;letter-spacing:.5px;margin:4px 0 0;text-transform:uppercase}.device-modal-close{background:#f3f4f6;border:none;border-radius:50%;color:#374151;cursor:pointer;font-size:16px;height:32px;width:32px}.device-modal-close:hover{background:#e5e7eb}.device-modal-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));overflow:auto;padding:20px 24px 24px}.device-modal-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;min-height:200px;padding:12px 14px}.device-modal-section h3{color:#4b5563;font-size:12px;letter-spacing:.6px;margin:0 0 10px;text-transform:uppercase}.device-modal-section pre{color:#111827;font-family:Courier New,Courier,monospace;font-size:12px;margin:0;white-space:pre-wrap;word-break:break-word}.rooms-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:8px;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px;padding:15px}.room-tab{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.room-tab:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.room-tab.active{background:#fff;border-color:#fff;box-shadow:0 4px 12px #00000026;color:#667eea}.device-count{background:#0000001a;border-radius:12px;font-size:12px;font-weight:700;padding:2px 8px}[data-theme=dark] .device-list-header{background:#141932d9;border-color:#ffffff0f}[data-theme=dark] .device-list-header h1{color:#e2e8f0}[data-theme=dark] .search-input{background:var(--input-bg);border-color:var(--input-border);color:var(--text-primary)}[data-theme=dark] .search-input::placeholder{color:var(--text-muted)}[data-theme=dark] .room-title{border-left-color:#818cf8;color:var(--room-title-color)}[data-theme=dark] .room-tab{background:#ffffff14;border-color:#ffffff1f}[data-theme=dark] .room-tab:hover{background:#ffffff24}[data-theme=dark] .room-tab.active{background:#4f46e5;border-color:#4f46e5;color:#fff}[data-theme=dark] .device-list-footer{background:#141932d9;color:var(--text-secondary)}[data-theme=dark] .loading-container{background:#141932d9}[data-theme=dark] .loading-container p{color:var(--text-secondary)}[data-theme=dark] .empty-state{background:#141932d9;color:var(--text-muted)}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;width:100%}.login-title{color:#333;font-size:32px;font-weight:700;margin:0 0 10px;text-align:center}.login-subtitle{color:#666;font-size:16px;margin:0 0 30px;text-align:center}.login-form{gap:20px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#333}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:12px 16px;transition:all .3s}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px 24px;transition:all .3s}.login-button:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.6}.login-error{background-color:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px;padding:12px;text-align:center}.db-modal-backdrop{align-items:center;animation:fadeIn .2s ease;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.db-modal{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:900px;width:90%}.db-modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e5e7eb;border-radius:16px 16px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.db-modal-header h2{font-size:1.5rem;font-weight:600;margin:0}.db-modal-header .close-btn{align-items:center;background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:36px;justify-content:center;transition:all .2s;width:36px}.db-modal-header .close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.db-modal-body{overflow-y:auto;padding:24px}.db-section{margin-bottom:32px}.db-section h3{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:1.2rem;margin:0 0 16px;padding-bottom:8px}.db-table{background:#f9fafb;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.db-table td{border-bottom:1px solid #e5e7eb;padding:12px 16px}.db-table td:first-child{color:#6b7280;width:180px}.db-table td code{background:#fff;border:1px solid #e5e7eb;border-radius:4px;color:#1f2937;font-size:.9rem;padding:4px 8px}.status-badge{border-radius:12px;font-size:.85rem;font-weight:600;padding:4px 12px}.status-badge.success{background:#d1fae5;color:#065f46}.status-badge.error{background:#fee2e2;color:#991b1b}.status-badge.warning{background:#fef3c7;color:#92400e}.env-badge{border-radius:12px;font-size:.85rem;font-weight:600;padding:4px 12px}.env-badge.prod{background:#dbeafe;color:#1e40af}.env-badge.dev{background:#fef3c7;color:#92400e}.migrations-list{display:flex;flex-direction:column;gap:12px}.migration-item{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:16px;padding:16px;transition:all .2s}.migration-item:hover{background:#f3f4f6;box-shadow:0 2px 8px #0000000d}.migration-number{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;height:40px;justify-content:center;width:40px}.migration-details{flex:1 1}.migration-name{color:#1f2937;font-weight:600;margin-bottom:4px}.migration-timestamp{align-items:center;display:flex;font-size:.85rem;gap:8px}.timestamp-label{color:#6b7280}.migration-timestamp code{background:#fff;border:1px solid #e5e7eb;border-radius:4px;color:#4b5563;padding:2px 8px}.migration-status{flex-shrink:0;font-size:1.5rem}.tables-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.table-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:all .2s}.table-card:hover{border-color:#667eea;box-shadow:0 4px 12px #0000001a}.table-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:12px 16px}.table-header h4{font-size:1rem;font-weight:600;margin:0}.row-count{background:#fff3;border-radius:12px;font-size:.85rem;font-weight:600;padding:4px 10px}.columns-list{display:flex;flex-direction:column;gap:8px;padding:12px}.column-item{align-items:center;background:#fff;border-radius:4px;display:flex;font-size:.85rem;gap:8px;padding:8px}.column-name{color:#1f2937;flex:1 1;font-weight:600}.column-type{color:#6b7280;font-family:monospace;font-size:.8rem}.column-badge{border-radius:4px;font-size:.7rem;font-weight:700;padding:2px 6px;text-transform:uppercase}.column-badge.pk{background:#dbeafe;color:#1e40af}.column-badge.nn{background:#fef3c7;color:#92400e}.table-error{color:#dc2626;font-size:.9rem;padding:12px 16px}.empty-state{color:#9ca3af;font-style:italic;padding:32px;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.db-modal{max-height:95vh;width:95%}.tables-grid{grid-template-columns:1fr}.migration-item{align-items:flex-start;flex-direction:column}}.config-page{margin:0 auto;max-width:1200px;padding:20px}.config-header{margin-bottom:40px;text-align:center}.config-header h1{color:#333;font-size:32px;margin-bottom:10px}.config-description{color:#666;font-size:16px;margin-bottom:20px}.config-actions{margin:20px auto;text-align:center}.btn-database-info{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-database-info:hover:not(:disabled){box-shadow:0 4px 16px #667eea66;transform:translateY(-2px)}.btn-database-info:active:not(:disabled){transform:translateY(0)}.btn-database-info:disabled{cursor:not-allowed;opacity:.6}.search-filter{margin:20px auto 0;max-width:600px;position:relative}.search-input{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:16px;outline:none;padding:12px 40px 12px 16px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.clear-search{background:#0000;border:none;border-radius:4px;color:#999;cursor:pointer;font-size:20px;padding:5px 10px;position:absolute;right:10px;top:50%;transform:translateY(-50%);transition:all .2s ease}.clear-search:hover{background:#f5f5f5;color:#333}.no-results{color:#999;font-size:18px;font-style:italic;padding:40px;text-align:center}.room-actions{display:flex;gap:12px;justify-content:center;margin-top:16px;padding:12px}.btn-collapse-all,.btn-expand-all{background:#fff;border:2px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .3s ease}.btn-collapse-all:hover,.btn-expand-all:hover{background:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff;transform:translateY(-2px)}.btn-collapse-all:active,.btn-expand-all:active{transform:translateY(0)}.error,.loading{color:#666;font-size:18px;padding:40px;text-align:center}.error{color:#d32f2f}.btn-reload{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;margin-top:20px;padding:10px 20px}.btn-reload:hover{background:#5568d3}.system-config-section{background:#fff;border-left:4px solid #667eea;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:20px}.system-config-header h2{align-items:center;color:#333;display:flex;font-size:22px;gap:10px;margin:0;-webkit-user-select:none;user-select:none}.system-config-header h2:hover{color:#667eea}.devices-config-section{background:#fff;border-left:4px solid #4caf50;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:20px}.devices-error-banner{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;font-size:.9rem;margin:12px 0;padding:12px 16px}.btn-reload-inline{background:none;border:1px solid #856404;border-radius:4px;color:#856404;cursor:pointer;font-size:.85rem;margin-left:8px;padding:2px 8px}.btn-reload-inline:hover{background:#ffc107;color:#fff}.devices-config-header h2{align-items:center;color:#333;display:flex;font-size:22px;gap:10px;margin:0;-webkit-user-select:none;user-select:none}.devices-config-header h2:hover{color:#4caf50}.system-config-form{border-top:1px solid #e0e0e0;margin-top:20px;padding-top:20px}.form-group{margin-bottom:20px}.form-group label{color:#555;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-input{background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:16px;outline:none;padding:12px;transition:all .3s ease;width:100%}.form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input::placeholder{color:#aaa;font-style:italic}.form-hint{color:#999;display:block;font-size:12px;font-style:italic;margin-top:6px}.form-actions{margin-top:24px;text-align:right}.btn-save{background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:8px;box-shadow:0 2px 8px #4caf504d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 32px;transition:all .3s ease}.btn-save:hover:not(:disabled){box-shadow:0 4px 16px #4caf5066;transform:translateY(-2px)}.btn-save:active:not(:disabled){transform:translateY(0)}.btn-save:disabled{cursor:not-allowed;opacity:.6}.error-message{background:#ffebee;border-left:4px solid #c62828;color:#c62828}.error-message,.success-message{border-radius:6px;font-size:14px;margin-bottom:16px;padding:12px}.success-message{background:#e8f5e9;border-left:4px solid #4caf50;color:#2e7d32}.room-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:20px}.room-title{align-items:center;border-bottom:2px solid #f0f0f0;color:#333;display:flex;font-size:24px;gap:12px;margin-bottom:20px;padding-bottom:12px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.room-title.clickable:hover{border-bottom-color:#667eea;color:#667eea}.room-toggle{display:inline-block;font-size:18px;min-width:20px;transition:transform .2s ease}.room-icon{font-size:28px}.room-count{color:#999;font-size:16px;font-weight:400}.devices-list{display:flex;flex-direction:column;gap:12px}.device-config-item{align-items:center;background:#f8f8f8;border:2px solid #0000;border-radius:8px;display:flex;gap:16px;justify-content:space-between;padding:16px;transition:all .3s ease}.device-config-item.visible{background:#f0f9ff;border-color:#667eea}.device-config-item.hidden{background:#f5f5f5;opacity:.6}.device-config-info{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.device-config-name{color:#333;font-size:16px;font-weight:600}.device-config-type{color:#999;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.device-config-room{color:#667eea;font-size:12px;font-weight:500}.device-config-controls{align-items:center;display:flex;flex-shrink:0;gap:16px}.btn-favorite{background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:24px;line-height:1;min-width:50px;padding:8px 12px;transition:all .3s ease}.btn-favorite:hover{border-color:#ffc107;transform:scale(1.1)}.btn-favorite.active{background:linear-gradient(135deg,#ffd54f,#ffc107);border-color:#ffa000;box-shadow:0 2px 8px #ffc10766}.btn-favorite.active:hover{box-shadow:0 4px 12px #ffc10780;transform:scale(1.15)}.widget-selector{align-items:center;display:flex;gap:8px}.widget-selector label{color:#666;font-size:14px;font-weight:500;white-space:nowrap}.widget-select{background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:14px;min-width:200px;outline:none;padding:8px 12px;transition:all .2s ease}.widget-select:hover:not(:disabled){border-color:#667eea}.widget-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.widget-select:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.5}.widget-select optgroup{color:#333;font-size:13px;font-weight:600}.widget-select option{font-size:14px;padding:8px}.device-config-status{min-width:100px;text-align:right}.status-visible{color:#4caf50;font-size:14px;font-weight:600}.status-hidden{color:#999;font-size:14px;font-weight:600}.toggle-switch{display:inline-block;height:34px;margin-left:20px;position:relative;width:60px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#ccc;border-radius:34px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.4s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:4px;content:"";height:26px;left:4px;position:absolute;transition:.4s;width:26px}.toggle-switch input:checked+.toggle-slider{background-color:#667eea}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 1px #667eea}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(26px)}.toggle-switch:hover .toggle-slider{background-color:#aaa}.toggle-switch input:checked:hover+.toggle-slider{background-color:#5568d3}@media (max-width:768px){.config-page{padding:15px}.config-header h1{font-size:24px}.room-title{font-size:20px}.device-config-item{align-items:flex-start;flex-direction:column;gap:12px}.toggle-switch{margin-left:0}.device-config-status{margin-left:0;text-align:left}}[data-theme=dark] .config-header h1{color:#e2e8f0}[data-theme=dark] .config-description{color:#94a3b8}[data-theme=dark] .search-input{background:#1e2340;border-color:#374151;color:#e2e8f0}[data-theme=dark] .search-input:focus{border-color:#818cf8;box-shadow:0 0 0 3px #818cf826}[data-theme=dark] .search-input::placeholder{color:#64748b}[data-theme=dark] .clear-search:hover{background:#252b50;color:#e2e8f0}[data-theme=dark] .no-results{color:#64748b}.plugin-toggle-row{align-items:center;display:flex;gap:20px;justify-content:space-between;padding:8px 0}.plugin-toggle-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.plugin-toggle-title{color:var(--text-primary);font-size:1rem;font-weight:600}.plugin-toggle-desc{color:var(--text-secondary);font-size:.82rem;line-height:1.5}[data-theme=dark] .plugin-toggle-title{color:#e2e8f0}[data-theme=dark] .plugin-toggle-desc{color:#94a3b8}.tab-button-enphase{background:#f59e0b2e!important;border:1px solid #f59e0b59}.tab-button-enphase:hover{background:#f59e0b4d!important}.tab-button-enphase.active{background:#f59e0b!important;color:#1a1a1a!important}.favorites-page{margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.favorites-header{margin-bottom:40px;text-align:center}.favorites-header h1{color:#fff;font-size:36px;margin-bottom:10px;text-shadow:0 2px 8px #0003}.favorites-subtitle{color:#ffffffd9;font-size:16px}.favorites-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.empty-favorites{color:#999;padding:80px 20px;text-align:center}.empty-icon{font-size:80px;margin-bottom:20px;opacity:.3}.empty-favorites h2{color:#666;font-size:24px;margin-bottom:10px}.empty-favorites p{color:#999;font-size:16px}.error-container,.loading-container{padding:60px 20px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto 20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.btn-retry{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;margin-top:20px;padding:12px 24px;transition:all .3s ease}.btn-retry:hover{background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}@media (max-width:768px){.favorites-grid{grid-template-columns:1fr}.favorites-header h1{font-size:28px}}[data-theme=dark] .favorites-header h1{color:#e2e8f0;text-shadow:0 2px 8px #00000080}[data-theme=dark] .favorites-subtitle{color:#cbd5e1d9}[data-theme=dark] .empty-favorites h2{color:#94a3b8}[data-theme=dark] .empty-favorites p{color:#64748b}.enphase-page{flex-direction:column;gap:24px;min-height:60vh;padding:24px}.enphase-header,.enphase-page{align-items:center;display:flex}.enphase-header{flex-wrap:wrap;gap:16px;max-width:720px;width:100%}.enphase-title{color:var(--text-primary);flex:1 1;font-size:1.6rem;font-weight:700;margin:0}.enphase-last-update{color:var(--text-secondary);font-size:.82rem}.enphase-refresh-hint{color:var(--text-muted)}.enphase-refresh-btn{align-items:center;background:#ffffff26;border:1px solid #ffffff4d;border-radius:50%;color:var(--text-primary);cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;height:36px;justify-content:center;transition:background .2s,transform .3s;width:36px}.enphase-refresh-btn:hover{background:#ffffff40;transform:rotate(180deg)}[data-theme=dark] .enphase-refresh-btn{background:#ffffff14;border-color:#ffffff26}.enphase-error,.enphase-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;font-size:1rem;gap:16px;justify-content:center;padding:60px 24px}.enphase-spinner{animation:enphase-spin .9s linear infinite;border:4px solid #f59e0b33;border-radius:50%;border-top-color:#f59e0b;height:48px;width:48px}@keyframes enphase-spin{to{transform:rotate(1turn)}}.enphase-error-icon{font-size:2.5rem}.enphase-retry-btn{background:#f59e0b;border:none;border-radius:8px;color:#1a1a1a;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 24px;transition:background .2s}.enphase-retry-btn:hover{background:#d97706}.enphase-missing-warning{background:#f59e0b1f;border:1px solid #f59e0b66;border-radius:10px;color:var(--text-primary);font-size:.9rem;line-height:1.6;max-width:720px;padding:14px 18px;width:100%}.enphase-missing-warning small{color:var(--text-secondary)}.enphase-diagram-container{align-items:center;display:flex;flex-direction:column;gap:28px;max-width:720px;width:100%}.enphase-svg{background:radial-gradient(ellipse at center,#1e233ce6 0,#0a0c19fa 100%);border:1px solid #ffffff14;border-radius:20px;box-shadow:0 20px 60px #00000080,inset 0 1px 0 #ffffff0d;height:auto;max-width:480px;padding:10px;width:100%}:root:not([data-theme=dark]) .enphase-svg{background:radial-gradient(ellipse at center,#14142deb 0,#050512fa 100%)}.noeud-icone,.noeud-watts{dominant-baseline:middle}.noeud-watts{font-size:13px;font-weight:700}.noeud-watts-solaire{fill:#fbbf24}.noeud-watts-maison{fill:#c084fc}.noeud-watts-reseau{fill:#22d3ee}.noeud-kwh{fill:#ffffff8c;dominant-baseline:middle;font-size:10px}.noeud-label{font-size:11px;font-weight:600;letter-spacing:.03em}.label-solaire{fill:#fbbf24}.label-maison{fill:#c084fc}.label-reseau{fill:#22d3ee}.arc-anime{stroke-linecap:round}.arc-sol-maison{animation:dash-sol-maison 1.8s linear infinite}.arc-sol-reseau{animation:dash-sol-reseau 2s linear infinite}.arc-res-maison{animation:dash-res-maison 2.2s linear infinite}.arc-inactif{stroke-linecap:round;opacity:.35}@keyframes dash-sol-maison{0%{stroke-dashoffset:0}to{stroke-dashoffset:-54}}@keyframes dash-sol-reseau{0%{stroke-dashoffset:0}to{stroke-dashoffset:-54}}@keyframes dash-res-maison{0%{stroke-dashoffset:0}to{stroke-dashoffset:-54}}.noeud-solaire{animation:pulse-solaire 3s ease-in-out infinite}.noeud-maison{animation:pulse-maison 3.4s ease-in-out infinite}.noeud-reseau{animation:pulse-reseau 3.8s ease-in-out infinite}@keyframes pulse-solaire{0%,to{opacity:1}50%{opacity:.75}}@keyframes pulse-maison{0%,to{opacity:1}50%{opacity:.72}}@keyframes pulse-reseau{0%,to{opacity:1}50%{opacity:.68}}.enphase-summary{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr);width:100%}@media (max-width:520px){.enphase-summary{grid-template-columns:1fr}}.enphase-summary-card{align-items:center;background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:4px;padding:16px 14px;transition:transform .2s,box-shadow .2s}.enphase-summary-card.clickable{cursor:pointer}.enphase-summary-card.clickable:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-3px)}.summary-history-hint{font-size:.72rem;margin-top:6px;opacity:.6}.enphase-summary-card.solaire{border-top:3px solid #f59e0b}.enphase-summary-card.maison{border-top:3px solid #a855f7}.enphase-summary-card.reseau{border-top:3px solid #06b6d4}.summary-icon{font-size:1.6rem}.summary-label{color:var(--text-secondary);font-size:.8rem;font-weight:600;letter-spacing:.05em;text-align:center;text-transform:uppercase}.summary-watts{color:var(--text-primary);font-size:1.4rem;font-weight:800;margin-top:2px}.enphase-summary-card.solaire .summary-watts{color:#f59e0b}.enphase-summary-card.maison .summary-watts{color:#a855f7}.enphase-summary-card.reseau .summary-watts{color:#06b6d4}.summary-kwh{font-size:.78rem}.summary-device-name,.summary-kwh{color:var(--text-muted);text-align:center}.summary-device-name{font-size:.68rem;font-style:italic;margin-top:4px;opacity:.7}.reseau-direction{color:var(--text-muted);font-size:.7rem;font-weight:400}.viz-tab-bar{background:#00000040;border:1px solid #ffffff14;border-radius:14px;display:flex;flex-wrap:wrap;gap:6px;max-width:720px;padding:6px;width:100%}[data-theme=dark] .viz-tab-bar{background:#0006;border-color:#ffffff0f}.viz-tab-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-family:inherit;gap:3px;min-width:100px;padding:8px 6px;transition:background .18s,color .18s,border-color .18s}.viz-tab-btn:hover{background:#f59e0b14;border-color:#f59e0b33;color:var(--text-primary)}.viz-tab-btn--active{background:#f59e0b26;border-color:#f59e0b80;color:#f59e0b}[data-theme=dark] .viz-tab-btn--active{background:#f59e0b1f;border-color:#f59e0b66}.viz-tab-num{font-size:1rem;font-weight:800;line-height:1}.viz-tab-label{font-size:.7rem;font-weight:500;letter-spacing:.02em;white-space:nowrap}.viz2-graphique-container{background:radial-gradient(ellipse at center,#141932eb 0,#060814fc 100%);border:1px solid #ffffff14;border-radius:16px;box-shadow:0 16px 48px #00000073,inset 0 1px 0 #ffffff0a;padding:20px 16px 16px;width:100%}[data-theme=dark] .viz2-graphique-container{background:radial-gradient(ellipse at center,#0c1024f5 0,#03040c 100%)}.viz2-graphique-titre{color:#ffffff80;font-size:.82rem;font-weight:600;letter-spacing:.06em;margin-bottom:12px;text-align:center;text-transform:uppercase}.viz2-tooltip{background:#0a0c1cf5;border:1px solid #ffffff1f;border-radius:10px;box-shadow:0 8px 24px #00000080;padding:10px 14px}.viz2-tooltip-heure{color:#ffffffa6;font-size:.78rem;font-weight:700;letter-spacing:.04em;margin:0 0 6px}.viz2-tooltip-ligne{font-size:.82rem;font-weight:600;margin:2px 0}.viz2-info{align-items:center;background:#0a0c1cb3;border:1px solid #ffffff12;border-radius:16px;color:var(--text-secondary);display:flex;flex-direction:column;font-size:.92rem;gap:10px;justify-content:center;padding:40px 24px;text-align:center;width:100%}[data-theme=dark] .viz2-info{background:#050610d9}.viz2-info-icon{font-size:2rem}.viz2-info-sub{color:var(--text-muted);font-size:.8rem;margin:0}.viz2-chargement{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;font-size:.92rem;gap:14px;padding:40px 24px}@media (max-width:520px){.viz2-graphique-container{padding:14px 8px 12px}}:root{--bg-gradient:linear-gradient(135deg,#667eea,#764ba2);--card-bg:#ffffffbf;--card-bg-hover:#ffffffe0;--card-border:#fff9;--card-shadow:0 8px 24px #0000001f,inset 0 1px 0 #ffffffe6;--card-shadow-hover:0 12px 32px #0000002e,inset 0 1px 0 #fffffff2;--text-primary:#1f2937;--text-secondary:#6b7280;--text-muted:#9ca3af;--header-bg:#ffffffbf;--header-border:#fff9;--input-bg:#fff;--input-border:#ddd;--section-bg:#fff;--section-border:#e5e7eb;--room-title-color:#fff}[data-theme=dark]{--bg-gradient:linear-gradient(135deg,#1a1a2e,#16213e);--card-bg:#1e233cd9;--card-bg-hover:#282e4af2;--card-border:#ffffff14;--card-shadow:0 8px 24px #0006,inset 0 1px 0 #ffffff0f;--card-shadow-hover:0 12px 32px #0000008c,inset 0 1px 0 #ffffff14;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--header-bg:#141932d9;--header-border:#ffffff14;--input-bg:#1e2340;--input-border:#374151;--section-bg:#1e2340;--section-border:#2d3748;--room-title-color:#cbd5e1}#root,.App,body,html{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--bg-gradient)}.App{margin:0;min-height:100vh;padding:0;width:100%}.App.loading{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--bg-gradient);display:flex;justify-content:center}.loading-spinner{color:#fff;font-size:24px;font-weight:600}.app-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;display:flex;gap:20px;justify-content:space-between;left:0;padding:20px 40px;position:fixed;right:0;top:0;z-index:100}[data-theme=dark] .app-header{background:linear-gradient(135deg,#2d1b69,#1e1040);box-shadow:0 2px 10px #0006}.app-header h1{font-size:28px;font-weight:700;margin:0}.app-tabs{display:flex;flex:1 1;gap:8px;justify-content:center}.tab-button{background:#ffffff26;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;outline:none;padding:12px 24px;transition:all .3s}.tab-button:hover{background:#ffffff40}.tab-button.active{background:#fff;color:#667eea}.app-content{padding:100px 20px 20px}.header-user{align-items:center;display:flex;gap:16px}.username{font-size:14px;font-weight:500;opacity:.95}.logout-button{background:#fff3;border:2px solid #fff;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s}.logout-button:hover{background:#fff;color:#667eea}.darkmode-toggle{align-items:center;background:#ffffff26;border:2px solid #ffffff4d;border-radius:50%;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;padding:0;transition:all .2s ease;width:40px}.darkmode-toggle:hover{background:#ffffff40;transform:scale(1.1)}@media (max-width:1200px){.App{padding:0}}@media (max-width:768px){.App{padding:0}}body.degraded-mode *{animation:none!important;transition:none!important}.degraded-badge{background:#ea580cd9;border-radius:20px;color:#fff;font-size:.72rem;font-weight:600;letter-spacing:.02em;padding:4px 10px;white-space:nowrap}
/*# sourceMappingURL=main.aaa9bc65.css.map*/