.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.count-value-container{display:inline-flex;align-items:baseline;font-size:clamp(2.5rem,8vw,4rem);font-weight:700;color:#4a9eff;line-height:1;gap:.5rem}.count-value-container.long-content{flex-direction:column;align-items:center;font-size:clamp(2rem,6vw,3rem);gap:.25rem}.count-value-container.long-content .count-unit{font-size:.7em;margin-left:0}.count-value{display:inline-block;font-variant-numeric:tabular-nums}.count-value.slide-in{animation:slideUp .5s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.count-unit{font-size:.6em;color:#b0b0b0;display:inline-block}.modal-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #00000080;display:flex;flex-direction:column}.modal-header h2{margin:0;color:var(--accent-blue)}.modal-close{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.widget-builder-form{padding:1.5rem;overflow-y:auto;flex:1;min-height:0}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.form-section:last-of-type{border-bottom:none}.form-section h3{color:var(--text-primary);margin:0 0 1rem;font-size:1.1rem}.section-help{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem;font-style:italic}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group textarea{resize:vertical;font-family:Courier New,monospace;font-size:.9rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-blue)}.form-group small{display:block;margin-top:.25rem;color:var(--text-secondary);font-size:.8rem}.form-actions button{padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.form-actions button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.modal-overlay{padding:0}.modal-content{max-width:100%;max-height:100vh;border-radius:0}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}}.settings-container{max-width:1200px;margin:0 auto;padding:2rem}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.settings-header h2{color:var(--accent-blue);margin:0}.settings-content{display:flex;flex-direction:column;gap:2rem}.settings-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.settings-section h3{color:var(--text-primary);margin:0 0 1.5rem;font-size:1.25rem}.empty-state{color:var(--text-secondary);text-align:center;padding:2rem;font-style:italic}.widget-list{display:flex;flex-direction:column;gap:1rem}.widget-item{display:flex;align-items:center;gap:1rem;padding:1rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;transition:all .2s}.widget-item:hover{border-color:var(--accent-blue);transform:translate(2px)}.widget-item.on-dashboard{border-color:var(--accent-blue);background-color:#4a9eff0d}.widget-item-icon{font-size:2rem;min-width:50px;text-align:center}.widget-item-info{flex:1}.widget-item-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.widget-item-description{font-size:.9rem;color:var(--text-secondary);margin-bottom:.5rem}.widget-item-type{font-size:.85rem;color:var(--text-secondary);font-family:monospace}.btn-secondary{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;transition:all .2s;font-size:1rem;font-weight:500}.btn-secondary:hover{background-color:var(--border-color);transform:translateY(-1px)}.btn-primary-small{background-color:var(--accent-blue);border:none;color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500;min-width:100px}.btn-primary-small:hover{background-color:#3a8eef;transform:translateY(-1px)}.btn-secondary-small{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500;min-width:70px}.btn-secondary-small:hover{background-color:var(--border-color);transform:translateY(-1px)}.btn-danger-small{background-color:var(--accent-red);border:none;color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500;min-width:100px}.btn-danger-small:hover{background-color:#d32f2f;transform:translateY(-1px)}.badge-on-dashboard{background-color:#4a9eff33;color:var(--accent-blue);padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;border:1px solid var(--accent-blue);text-transform:uppercase;letter-spacing:.5px}.btn-remove-small{background-color:#ff980033;border:1px solid #ff9800;color:#ff9800;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500;min-width:100px}.btn-remove-small:hover{background-color:#ff9800;color:#fff;transform:translateY(-1px)}.success-message{background-color:#4caf5033;color:var(--accent-green);padding:1rem;border-radius:4px;margin-bottom:1rem;text-align:center;border:1px solid var(--accent-green);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;overflow-y:auto}.modal-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #00000080;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1.25rem;border-bottom:1px solid var(--border-color);flex-shrink:0;background-color:var(--bg-secondary)}.modal-header h2{margin:0;color:var(--accent-blue);font-size:1.5rem}.modal-close{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;line-height:1}.modal-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-content form{display:flex;flex-direction:column;padding:1.5rem;flex:1}.modal-content .form-group{margin-bottom:1.5rem}.modal-content .form-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem;font-weight:500}.modal-content .form-group input,.modal-content .form-group select,.modal-content .form-group textarea{width:100%;padding:.75rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem;font-family:inherit;transition:border-color .2s}.modal-content .form-group input:focus,.modal-content .form-group select:focus,.modal-content .form-group textarea:focus{outline:none;border-color:var(--accent-blue)}.modal-content .form-group small{display:block;margin-top:.5rem;color:var(--text-secondary);font-size:.85rem;line-height:1.4}.modal-content .form-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.25rem 1.5rem 1.5rem;border-top:1px solid var(--border-color);flex-shrink:0;background-color:var(--bg-secondary);margin-top:auto;margin-left:-1.5rem;margin-right:-1.5rem;margin-bottom:-1.5rem}.modal-content .form-actions button{padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}@media (max-width: 768px){.settings-container{padding:1rem}.settings-header{flex-direction:column;gap:1rem;align-items:flex-start}.widget-item{flex-direction:column;align-items:flex-start}.widget-item-icon{font-size:1.5rem}.btn-primary-small,.btn-secondary-small,.btn-danger-small,.btn-remove-small{width:100%}.modal-overlay{padding:0}.modal-content{max-width:100%;max-height:100vh;border-radius:0}.modal-content .form-actions{flex-direction:column}.modal-content .form-actions button{width:100%}}.user-management-container{max-width:1400px;margin:0 auto;padding:2rem}.user-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.user-management-header h2{color:var(--accent-blue);margin:0}.user-form-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:2rem;margin-bottom:2rem}.user-form-section h3{color:var(--text-primary);margin:0 0 1.5rem}.user-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.users-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:2rem}.users-section h3{color:var(--text-primary);margin:0 0 1.5rem}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table th{background-color:var(--bg-tertiary);padding:1rem;text-align:left;font-weight:600;font-size:.9rem;color:var(--text-secondary);border-bottom:2px solid var(--border-color);white-space:nowrap}.users-table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.users-table tr:hover{background-color:var(--bg-tertiary)}.role-badge{padding:.35rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;display:inline-block}.role-badge.admin{background-color:#4a9eff33;color:var(--accent-blue);border:1px solid var(--accent-blue)}.role-badge.user{background-color:#b0b0b033;color:var(--text-secondary);border:1px solid var(--text-secondary)}.status-badge{padding:.35rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;display:inline-block}.status-badge.active{background-color:#4caf5033;color:var(--accent-green);border:1px solid var(--accent-green)}.status-badge.inactive{background-color:#f4433633;color:var(--accent-red);border:1px solid var(--accent-red)}@media (max-width: 968px){.user-management-container{padding:1rem}.user-management-header{flex-direction:column;gap:1rem;align-items:flex-start}.form-row{grid-template-columns:1fr}.users-table{font-size:.85rem}.users-table th,.users-table td{padding:.75rem .5rem}}.api-key-management{padding:2rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h2{color:#4a9eff;margin:0}.api-keys-table-container{background:var(--bg-secondary);border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0003}.api-keys-table{width:100%;border-collapse:collapse}.api-keys-table thead{background:var(--bg-tertiary)}.api-keys-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-secondary);text-transform:uppercase;font-size:.85rem;letter-spacing:.5px;border-bottom:2px solid var(--border-color)}.api-keys-table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.api-keys-table tbody tr:hover{background:#4a9eff0d}.api-keys-table code{background:var(--bg-tertiary);padding:.25rem .5rem;border-radius:4px;font-family:monospace;font-size:.9rem;color:#4a9eff}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-badge.active{background:#4caf5033;color:#4caf50}.status-badge.inactive{background:#9e9e9e33;color:#9e9e9e}.action-buttons{display:flex;gap:.5rem}.btn-toggle{padding:.4rem .8rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.btn-toggle:hover{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.btn-delete{padding:.4rem .8rem;background:#f443361a;color:var(--accent-red);border:1px solid rgba(244,67,54,.3);border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.btn-delete:hover{background:var(--accent-red);border-color:var(--accent-red);color:#fff}.btn-secondary{padding:.5rem 1.5rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--border-color)}.api-key-management .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;overflow-y:auto}.api-key-management .modal-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;min-width:500px;max-width:600px;max-height:90vh;box-shadow:0 10px 40px #00000080;display:flex;flex-direction:column;overflow:hidden}.api-key-management .modal-content h3{margin:0;padding:1.5rem 1.5rem 1.25rem;color:var(--text-primary);font-size:1.5rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.api-key-management .modal-content>p,.api-key-management .modal-content>div:not(.api-key-display):not(.form-actions){padding:0 1.5rem}.api-key-display{background:var(--bg-tertiary);padding:1rem;border-radius:8px;margin:1rem 1.5rem}.api-key-display code{display:block;font-size:.95rem;color:#51cf66;word-wrap:break-word;word-break:break-all;background:none;padding:0 0 1rem;margin:0;font-family:Courier New,Courier,monospace;line-height:1.5}.api-key-display button{width:100%;white-space:nowrap}.api-key-management .modal-content button[onClick*=setCreatedKey],.api-key-management .modal-content button[onClick*=setShowCreateForm]{margin:0 1.5rem 1.5rem}@media (max-width: 768px){.api-key-management .modal-overlay{padding:0}.api-key-management .modal-content{min-width:auto;width:100%;max-height:100vh;border-radius:0}.api-key-management .form-actions{flex-direction:column}.api-key-management .form-actions button{width:100%}}.form-group input{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-group small{display:block;margin-top:.5rem;color:var(--text-secondary);font-size:.85rem;line-height:1.4}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.25rem 1.5rem 1.5rem;border-top:1px solid var(--border-color);flex-shrink:0;background-color:var(--bg-secondary);margin-top:auto}.api-key-management form{display:flex;flex-direction:column;padding:1.5rem;flex:1}.info-section h4{color:var(--text-primary)}.info-section ul{margin-top:.5rem}.info-section ul li{margin-bottom:.25rem}.company-management-container{padding:var(--spacing-lg);max-width:1400px;margin:0 auto}.company-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);gap:var(--spacing-md);flex-wrap:wrap}.company-management-header h2{margin:0;color:var(--text-primary);font-size:1.8rem}.company-form-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.company-form-section h3{margin:0 0 var(--spacing-lg) 0;color:var(--text-primary)}.company-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.companies-section{margin-bottom:var(--spacing-lg)}.companies-section h3{margin:0 0 var(--spacing-lg) 0;color:var(--text-primary)}.companies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.company-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:var(--spacing-lg);transition:transform .2s,box-shadow .2s}.company-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.company-card.inactive{opacity:.6;border-color:var(--accent-red)}.company-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.company-card-header h4{margin:0;color:var(--text-primary);font-size:1.2rem}.inactive-badge{background:var(--accent-red);color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.company-slug{color:var(--text-secondary);font-family:monospace;margin:var(--spacing-sm) 0}.company-card-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.user-assignment-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;width:100%;max-width:900px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;color:var(--text-primary)}.close-button{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:var(--spacing-sm);transition:color .2s}.close-button:hover{color:var(--text-primary)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.assigned-users-section,.unassigned-users-section{margin-bottom:var(--spacing-lg)}.assigned-users-section h4,.unassigned-users-section h4{margin:0 0 var(--spacing-md) 0;color:var(--text-primary)}.users-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.user-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px}.user-info{display:flex;flex-direction:column;gap:.25rem}.user-info strong{color:var(--text-primary)}.user-info span{color:var(--text-secondary);font-size:.9rem}.companies-checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:6px}.company-checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);cursor:pointer;border-radius:4px;transition:background .2s}.company-checkbox-label:hover{background:var(--bg-secondary)}.company-checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.company-checkbox-label span{color:var(--text-primary)}@media (max-width: 768px){.companies-grid{grid-template-columns:1fr}.company-management-header{flex-direction:column;align-items:stretch}.companies-checkbox-grid{grid-template-columns:1fr}}.user-profile-container{max-width:800px;margin:0 auto;padding:2rem}.page-title{color:var(--text-primary);font-size:2rem;margin-bottom:2rem;font-weight:600}.profile-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:2rem;margin-bottom:2rem}.section-title{color:var(--text-primary);font-size:1.5rem;margin-bottom:1.5rem;font-weight:600}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item label{display:block;color:var(--text-secondary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.info-value{color:var(--text-primary);font-size:1rem;padding:.75rem;background-color:var(--bg-tertiary);border-radius:4px;border:1px solid var(--border-color)}.role-badge{display:inline-block;padding:.5rem 1rem;border-radius:4px;font-weight:600;text-transform:capitalize}.role-super_admin{background-color:#ff6b6b33;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.role-admin{background-color:#4a9eff33;color:#4a9eff;border:1px solid rgba(74,158,255,.3)}.role-user{background-color:#51cf6633;color:#51cf66;border:1px solid rgba(81,207,102,.3)}.password-form{max-width:400px}.form-group label{display:block;color:var(--text-secondary);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.form-group input:focus{outline:none;border-color:var(--primary-color)}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-hint{display:block;color:var(--text-secondary);font-size:.75rem;margin-top:.25rem}.message{padding:.75rem 1rem;border-radius:4px;margin-bottom:1rem;font-weight:500}.success-message{background-color:#51cf6633;color:#51cf66;border:1px solid rgba(81,207,102,.3)}.error-message{background-color:#ff6b6b33;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.btn-primary{background-color:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.user-profile-container{padding:1rem}.page-title{font-size:1.5rem}.profile-section{padding:1.5rem}.section-title{font-size:1.25rem}.info-grid{grid-template-columns:1fr}.password-form{max-width:100%}}:root{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #3a3a3a;--text-primary: #ffffff;--text-secondary: #b0b0b0;--text-tertiary: #888;--accent-blue: #4a9eff;--accent-green: #51cf66;--accent-yellow: #ffc107;--accent-red: #ff6b6b;--accent-orange: #ff8c42;--accent-purple: #9775fa;--status-success: #51cf66;--status-error: #ff6b6b;--status-warning: #ffc107;--status-info: #4a9eff;--status-healthy: #51cf66;--status-degraded: #ffc107;--status-unhealthy: #ff6b6b;--status-unknown: #888;--border-color: #404040;--border-light: #555;--border-dark: #2a2a2a;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .5);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono: source-code-pro, Menlo, Monaco, Consolas, "Courier New", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--z-dropdown: 1000;--z-modal: 2000;--z-tooltip: 3000;--z-toast: 4000;--transition-fast: .15s;--transition-base: .2s;--transition-slow: .3s;--transition-easing: cubic-bezier(.4, 0, .2, 1);--navbar-height: 64px;--max-width-content: 1400px;--max-width-narrow: 800px}.container{max-width:var(--max-width-content);margin:0 auto;padding:var(--spacing-xl)}.container-narrow{max-width:var(--max-width-narrow);margin:0 auto;padding:var(--spacing-xl)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.m-0{margin:0}.mt-0{margin-top:0}.mr-0{margin-right:0}.mb-0{margin-bottom:0}.ml-0{margin-left:0}.p-0{padding:0}.pt-0{padding-top:0}.pr-0{padding-right:0}.pb-0{padding-bottom:0}.pl-0{padding-left:0}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-xl)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-color)}.section{margin-bottom:var(--spacing-2xl)}.section-title{color:var(--accent-blue);font-size:var(--text-2xl);margin-bottom:var(--spacing-lg)}.table-container{overflow-x:auto;border-radius:var(--radius-md)}.table{width:100%;border-collapse:collapse;background-color:var(--bg-tertiary)}.table thead{background-color:var(--bg-secondary);border-bottom:2px solid var(--border-color)}.table th{padding:1rem;text-align:left;font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.05em}.table td{padding:1rem;border-bottom:1px solid var(--border-color)}.table tbody tr:hover{background-color:var(--bg-secondary)}.loading-container{display:flex;justify-content:center;align-items:center;min-height:300px}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}.hidden{display:none!important}.invisible{visibility:hidden}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.error-message{background:#ff6b6b1a;border-left:4px solid var(--accent-red);padding:1rem;border-radius:var(--radius-md);color:#f99;margin-bottom:1rem}.success-message{background:#51cf661a;border-left:4px solid var(--accent-green);padding:1rem;border-radius:var(--radius-md);color:#7fd98a;margin-bottom:1rem}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:var(--font-medium);color:var(--text-primary);font-size:var(--text-sm)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-base);transition:border-color var(--transition-base) var(--transition-easing)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #4a9eff1a}.btn-primary,.btn-secondary,.btn-danger,.btn-secondary-small{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-base) var(--transition-easing)}.btn-primary{background:linear-gradient(135deg,var(--accent-blue),#3a7ecc);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#3a7ecc,#2a5e9c);transform:translateY(-1px);box-shadow:0 4px 12px #4a9eff66}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-color)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover:not(:disabled){background:#c00}.btn-secondary-small{padding:.4rem .8rem;font-size:var(--text-sm);background:var(--bg-tertiary);color:var(--text-primary)}button:disabled{opacity:.6;cursor:not-allowed}.role-badge,.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .75rem;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold)}.role-badge.admin{background:linear-gradient(135deg,#ffd70033,#ff8c0033);color:gold}.role-badge.user{background:#4a9eff26;color:var(--accent-blue)}.status-badge.active{background:#51cf6626;color:var(--accent-green)}.status-badge.inactive{background:#9ca3af26;color:var(--text-tertiary)}*{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden;width:100%;height:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;width:100%;height:100%;position:relative}code{font-family:var(--font-family-mono)}#root{width:100%;min-height:100%;overflow-x:hidden}.app{min-height:100vh;display:flex;flex-direction:column;width:100%;overflow-x:hidden}.navbar{background-color:var(--bg-secondary);padding:1.25rem 2rem;border-bottom:2px solid var(--border-color);display:flex;align-items:center;gap:2rem;box-shadow:0 2px 10px #0000004d;position:relative}.navbar-left{display:flex;align-items:center;flex-shrink:0}.navbar h1{font-size:1.5rem;color:var(--accent-blue);margin:0;font-weight:600;letter-spacing:-.5px}.navbar-center{display:flex;justify-content:center;flex-shrink:0}.selector-group{display:flex;gap:2rem;align-items:flex-start}.selector-wrapper{display:flex;flex-direction:column;gap:.5rem}.selector-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);padding-left:.25rem}.navbar-right{display:flex;justify-content:flex-end;align-items:center;gap:2rem;flex:1;margin-left:auto}.navbar-status{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.status-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.status-label{color:var(--text-secondary);font-weight:500}.status-value{color:var(--text-primary);font-family:var(--font-family-mono);font-size:.8rem}.connection-status{display:flex;align-items:center;gap:.5rem}.status-indicator{width:10px;height:10px;border-radius:50%;background-color:var(--accent-red);animation:pulse 2s infinite}.status-indicator.connected{background-color:var(--accent-green);animation:none}.status-indicator.stale{background-color:#ff9800;animation:pulse-slow 3s infinite}.status-indicator.disconnected{background-color:var(--accent-red);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes pulse-slow{0%,to{opacity:1}50%{opacity:.6}}.navbar-hidden{display:none!important}.fullscreen-exit-btn{position:fixed;top:20px;right:20px;z-index:9999;background-color:#000c;color:var(--text-primary);border:2px solid var(--accent-blue);padding:.75rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.fullscreen-exit-btn:hover{background-color:var(--accent-blue);color:#fff;transform:translateY(-2px);box-shadow:0 6px 16px #4a9eff66}.fullscreen-exit-btn:active{transform:translateY(0)}.dashboard-stale{position:relative;transition:all .5s ease-in-out}.dashboard-stale:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,#ff98001f,#ff980017,#ff98001f);pointer-events:none;z-index:-1}.dashboard-stale .layout{position:relative;z-index:1}.desktop-menu{display:flex;align-items:center;gap:2rem}.user-info-desktop{display:flex;align-items:center;gap:.75rem;padding-right:2rem;border-right:1px solid var(--border-color)}.desktop-menu-actions{display:flex;align-items:center;gap:.75rem}.btn-nav{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.6rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500;white-space:nowrap}.btn-nav:hover{background-color:var(--accent-blue);border-color:var(--accent-blue);transform:translateY(-1px);box-shadow:0 2px 4px #0003}.btn-nav.btn-logout-desktop{background-color:#f443361a;border-color:var(--accent-red);color:var(--accent-red)}.btn-nav.btn-logout-desktop:hover{background-color:var(--accent-red);color:#fff}.mobile-menu-toggle{display:none;background:none;border:none;color:var(--accent-blue);font-size:1.5rem;cursor:pointer;padding:.5rem;line-height:1;transition:color .2s}.mobile-menu-toggle:hover{color:var(--text-primary)}.navbar-menu{display:none;position:absolute;top:100%;left:0;right:0;background-color:var(--bg-secondary);border-bottom:2px solid var(--border-color);box-shadow:0 4px 10px #0000004d;z-index:1000;padding:1.5rem 2rem}.navbar-menu.open{display:block}.navbar-menu-header{border-bottom:1px solid var(--border-color);padding-bottom:1rem;margin-bottom:1rem}.user-info{display:flex;align-items:center;gap:.75rem}.user-name{font-weight:600;color:var(--text-primary);font-size:1rem}.navbar-menu-selectors{display:flex;flex-direction:column;gap:1rem;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--border-color)}.navbar-menu-selectors .company-selector,.navbar-menu-selectors .dashboard-selector{width:100%}.navbar-menu-selectors .company-selector-button,.navbar-menu-selectors .dashboard-selector-button{width:100%;justify-content:flex-start}.navbar-menu-actions{display:flex;flex-direction:column;gap:.5rem}.navbar-menu-actions button{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.75rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.95rem;font-weight:500;text-align:left}.navbar-menu-actions button:hover{background-color:var(--accent-blue);border-color:var(--accent-blue);transform:translate(4px)}.navbar-menu-actions button.btn-logout{background-color:#f443361a;border-color:var(--accent-red);color:var(--accent-red);margin-top:.5rem}.navbar-menu-actions button.btn-logout:hover{background-color:var(--accent-red);color:#fff}.main-content{flex:1;padding:2rem}.grid-options-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem 1.5rem;margin:0 2rem 1rem;display:flex;gap:2rem;align-items:center;flex-wrap:wrap}.grid-options-section{display:flex;align-items:center;gap:.75rem}.grid-option-label{color:var(--text-secondary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.grid-option-buttons{display:flex;gap:.5rem}.grid-option-btn{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.grid-option-btn:hover{background-color:var(--bg-primary);border-color:var(--primary-color)}.grid-option-btn.active{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.grid-option-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-primary);font-size:.875rem;font-weight:500}.grid-option-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color)}.grid-option-checkbox span{-webkit-user-select:none;user-select:none}.widget{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;height:100%;display:flex;flex-direction:column;box-shadow:0 4px 6px #0000004d;transition:transform .2s,box-shadow .2s}.widget:hover{transform:translateY(-2px);box-shadow:0 6px 12px #0006}.widget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.table-widget .widget-header{position:sticky;top:0;background-color:var(--bg-secondary);z-index:20;padding-top:0;margin-top:0}.table-widget .widget-body{overflow-y:auto;flex:1}.react-grid-item.react-draggable .widget-header{cursor:move;cursor:grab}.react-grid-item.react-draggable .widget-header:active{cursor:grabbing}.overlapping-widget .widget{border:2px solid #ff9800;box-shadow:0 0 20px #ff980099;animation:pulse-overlap 2s ease-in-out infinite}@keyframes pulse-overlap{0%,to{box-shadow:0 0 20px #ff980099}50%{box-shadow:0 0 30px #ff9800e6}}.widget-title{font-size:.9rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.widget-body{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}.gauge-widget{position:relative;width:100%;height:100%;display:flex;flex-direction:column;container-type:size;container-name:gauge}.gauge-widget-content{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;padding:0}.gauge-chart-container{position:absolute;top:-80%;left:50%;transform:translate(-50%);width:120%;max-width:600px;bottom:-20%;min-height:100px;overflow:visible;aspect-ratio:2 / 1;pointer-events:none}.gauge-value-overlay{position:absolute;top:75%;left:50%;transform:translate(-50%,-50%);font-size:clamp(2rem,16cqh,8rem);font-weight:700;line-height:1;text-align:center;white-space:nowrap;pointer-events:none;z-index:10}.gauge-value-overlay.animated{transition:color .3s ease}.gauge-max-label{position:absolute;bottom:-.25rem;left:50%;transform:translate(-50%);font-size:clamp(.7rem,4.5cqh,1.4rem);color:var(--text-secondary);text-align:center;white-space:nowrap;pointer-events:none;z-index:10}@container gauge (max-width: 150px){.gauge-chart-container{top:-75%;width:150%}.gauge-value-overlay{top:72%;font-size:clamp(1.5rem,14cqh,6rem);margin-bottom:.5rem}.gauge-max-label{bottom:0rem;font-size:clamp(.6rem,3.5cqh,1.2rem)}}@container gauge (min-width: 151px) and (max-width: 250px){.gauge-chart-container{top:-85%;width:140%}.gauge-value-overlay{top:72%;font-size:clamp(1.75rem,15cqh,7rem);margin-bottom:.5rem}.gauge-max-label{bottom:0rem}}@container gauge (max-width: 250px) and (max-height: 180px){.gauge-chart-container{top:-65%;width:155%}.gauge-value-overlay{top:72%;font-size:clamp(1.25rem,12cqh,5rem);margin-bottom:.5rem}.gauge-max-label{bottom:0rem;font-size:clamp(.55rem,3cqh,1rem)}}.table-widget{width:100%;overflow-y:auto}.widget-table{width:100%;border-collapse:collapse}.widget-table th{background-color:var(--bg-tertiary);padding:.75rem;text-align:left;font-weight:600;font-size:.85rem;color:var(--text-secondary);border-bottom:2px solid var(--border-color)}.widget-table td{padding:.75rem;border-bottom:1px solid var(--border-color);font-size:.9rem}.widget-table tr:hover{background-color:var(--bg-tertiary)}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600}.status-badge.running{background-color:#4caf5033;color:var(--accent-green)}.status-badge.stopped{background-color:#f4433633;color:var(--accent-red)}.status-badge.warning{background-color:#ffc10733;color:var(--accent-yellow)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.login-box{background-color:var(--bg-secondary);padding:3rem;border-radius:12px;box-shadow:0 10px 40px #00000080;width:100%;max-width:400px;border:1px solid var(--border-color)}.login-box h2{margin-bottom:2rem;color:var(--accent-blue);text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem;font-weight:500}.form-group input{width:100%;padding:.75rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent-blue)}.btn-primary{width:100%;padding:.75rem;background-color:var(--accent-blue);border:none;border-radius:4px;color:var(--text-primary);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#3a8eef}.btn-primary:disabled{background-color:var(--bg-tertiary);cursor:not-allowed}.error-message{background-color:#f4433633;color:var(--accent-red);padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center;border:1px solid var(--accent-red)}.react-grid-layout{position:relative}.react-grid-item{transition:all .2s ease}.react-grid-item.react-draggable-dragging{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;transition:none!important;z-index:100}.react-grid-item.react-grid-placeholder{background:var(--accent-blue);opacity:.2;transition-duration:.1s;z-index:2;border-radius:8px}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid var(--text-secondary);border-bottom:2px solid var(--text-secondary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-color)}.loading-spinner{display:inline-block;width:40px;height:40px;border:4px solid var(--bg-tertiary);border-radius:50%;border-top-color:var(--accent-blue);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;justify-content:center;align-items:center;min-height:400px}@media (max-width: 768px){body{overflow-x:hidden;width:100vw}.app{width:100%;overflow-x:hidden}.navbar{padding:.75rem 1rem;flex-wrap:wrap}.navbar-left{display:flex;justify-content:space-between;align-items:center;width:100%;order:1}.navbar h1{font-size:1.1rem}.mobile-menu-toggle{display:block}.navbar-center{display:none}.navbar-right{width:100%;justify-content:space-between;gap:1rem;order:2;margin-left:0}.desktop-menu{display:none}.navbar-status{flex-direction:row;gap:1rem;align-items:center;flex-wrap:wrap}.status-item{font-size:.75rem;flex-direction:column;align-items:flex-start;gap:.25rem}.status-label{font-size:.7rem}.status-value,.connection-status{font-size:.75rem}.navbar-menu{padding:1rem}.navbar-menu-actions button{font-size:.9rem;padding:.65rem 1rem}.main-content{padding:.5rem .5rem 2rem;width:100%;max-width:100vw;overflow-x:hidden}.dashboard-container{padding:.5rem .5rem 2rem;width:100%;max-width:100%}.grid-options-panel{margin:0 .5rem 1rem;padding:.75rem 1rem;flex-direction:column;gap:.75rem;align-items:flex-start}.grid-options-section{width:100%}.grid-option-buttons{flex:1}.grid-option-btn{flex:1;padding:.5rem .75rem;font-size:.75rem}.layout{width:100%!important;margin:0!important}.widget{margin:0;max-width:100%;padding:1rem!important}.widget-header{padding:.5rem;font-size:.85rem;margin-bottom:.5rem}.widget-body{padding:.5rem}.gauge-widget-content{padding:0 .25rem .25rem}.gauge-chart-container{top:-65%!important;width:115%!important;bottom:-10%!important}.gauge-value-overlay{font-size:clamp(1.5rem,8cqh,3rem)!important;top:65%!important}.gauge-max-label{font-size:clamp(.6rem,3cqh,.85rem)!important;bottom:.25rem!important;z-index:20!important}.table-widget table{font-size:.8rem}.table-widget th,.table-widget td{padding:.4rem}.login-container{padding:1rem}.login-box{padding:1.5rem;max-width:100%}.login-box h2{font-size:1.5rem}.btn-primary,.btn-secondary{padding:.6rem 1.2rem;font-size:.9rem}.form-group label{font-size:.9rem}.form-group input,.form-group select,.form-group textarea{font-size:.95rem;padding:.6rem}}.company-selector,.dashboard-selector{position:relative}.company-selector-button,.dashboard-selector-button{display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border:1.5px solid var(--border-color);color:var(--text-primary);padding:.7rem 1.25rem;border-radius:8px;cursor:pointer;transition:all .25s ease;font-size:.95rem;white-space:nowrap;min-width:180px;box-shadow:0 2px 4px #0003}.company-selector-button:hover,.dashboard-selector-button:hover{border-color:var(--accent-blue);box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.selector-icon{font-size:1.1rem;line-height:1}.company-name,.dashboard-name{font-weight:600;flex:1}.dropdown-arrow{font-size:.7rem;color:var(--text-secondary);transition:transform .2s;margin-left:auto}.company-selector-button:hover .dropdown-arrow,.dashboard-selector-button:hover .dropdown-arrow{color:var(--accent-blue)}.company-dropdown,.dashboard-dropdown{position:absolute;top:calc(100% + .75rem);left:0;min-width:100%;background-color:var(--bg-secondary);border:1.5px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:1000;overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.company-option,.dashboard-option{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.85rem 1.25rem;border:none;background:none;color:var(--text-primary);text-align:left;cursor:pointer;transition:all .2s;font-size:.95rem;border-bottom:1px solid rgba(255,255,255,.05)}.company-option:last-child,.dashboard-option:last-child{border-bottom:none}.company-option:hover,.dashboard-option:hover{background-color:var(--bg-tertiary);padding-left:1.5rem}.company-option.active,.dashboard-option.active{background:linear-gradient(90deg,var(--accent-blue) 0%,rgba(33,150,243,.8) 100%);color:#fff;font-weight:600}.company-option-name,.dashboard-option-name{flex:1}.checkmark{color:#fff;font-weight:700;font-size:1.1rem}.role-badge{display:inline-block;padding:.25rem .6rem;border-radius:4px;font-size:.85rem;font-weight:600;margin-left:.5rem}.role-badge.super-admin,.role-badge.super_admin{background-color:var(--accent-purple);color:#fff}.role-badge.admin{background-color:var(--accent-blue);color:#fff}.role-badge.user{background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}
