body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root,body{background-color:#282c34;background-color:var(--bg-primary,#282c34);min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.callback-container{align-items:center;background:var(--body-bg);display:flex;justify-content:center;min-height:100vh;padding:20px}.callback-content{background:var(--card-bg);border-radius:12px;box-shadow:0 4px 12px #0000001a;max-width:500px;padding:40px;text-align:center}.callback-content h2{color:var(--text-color);font-size:1.8rem;margin-bottom:20px}.callback-content p{color:var(--text-secondary);font-size:1.1rem;margin-bottom:10px}.callback-spinner{animation:spin 1s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top:4px solid #667eea;height:60px;margin:0 auto 30px;width:60px}.callback-error-icon{font-size:4rem;margin-bottom:20px}.callback-error-message{color:#f44;font-weight:500;margin-bottom:20px}.callback-redirect-message{color:var(--text-secondary);font-size:.9rem;font-style:italic}.login-container{align-items:center;background:linear-gradient(135deg,#282c34,#3c4049);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-content{animation:fadeIn .5s ease;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 8px 32px #0000004d;max-width:450px;overflow:hidden;width:100%}.login-header{background:linear-gradient(135deg,#3c4049,#4a4e56);color:#fff;padding:40px 30px 30px;text-align:center}.login-logo{align-items:center;display:flex;justify-content:center;margin-bottom:20px}.logo-image{animation:fadeInScale .6s ease;height:auto;max-width:200px}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.logo-icon{animation:pulse 2s ease-in-out infinite;font-size:4rem}.login-header h1{font-size:1.5rem;font-weight:600;line-height:1.3;margin:0 0 10px}.login-subtitle{font-size:1rem;margin:0;opacity:.9}.login-body{padding:40px 30px}.login-error{align-items:center;background:#ff44441a;border:1px solid #ff44444d;border-radius:8px;display:flex;gap:10px;margin:-10px 30px 20px;padding:15px}.login-error-icon{font-size:1.5rem}.login-error-message{color:#f44;flex:1 1;font-size:.9rem}.login-button{align-items:center;background:var(--accent-color);border:none;border-radius:12px;box-shadow:0 4px 12px #61dafb4d;color:var(--text-on-accent);cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:12px;justify-content:center;padding:16px 24px;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.login-button:hover{background:var(--accent-color-hover);box-shadow:0 6px 20px #61dafb66;transform:translateY(-2px)}.login-button:active{box-shadow:0 2px 8px #61dafb33;transform:translateY(0)}.login-button-icon{font-size:1.5rem}.login-button-text{font-size:1.1rem}.login-info{border-top:1px solid var(--border-color);margin-top:30px;padding-top:20px}.login-info p{color:var(--text-secondary);font-size:.85rem;line-height:1.5;margin:0;text-align:center}.login-info a{color:var(--text-secondary);text-decoration:underline;transition:opacity .2s ease}.login-info a:hover{opacity:.8}.login-footer{background:var(--bg-tertiary);border-top:1px solid var(--border-color);padding:20px 30px}.login-footer-text{color:var(--text-secondary);font-size:.8rem;margin:0;text-align:center}.login-footer-text a{color:var(--text-secondary);text-decoration:underline;transition:opacity .2s ease}.login-footer-text a:hover{opacity:.8}body.light-mode .login-container{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}body.light-mode .login-content{box-shadow:0 8px 32px #0000001a}body.light-mode .login-header{background:linear-gradient(135deg,#64b5f6,#42a5f5)}body.light-mode .login-error{background:#ff44441a;border-color:#ff44444d}.organization-selector-container{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:20px}.organization-selector-card{background:var(--bg-secondary);border-radius:12px;box-shadow:0 4px 6px var(--shadow-color);max-width:600px;padding:40px;width:100%}.organization-selector-card h2{color:var(--text-primary);font-size:28px;margin:0 0 10px;text-align:center}.organization-selector-card .error-message{color:var(--status-error);font-size:22px;line-height:1.6;margin:0 0 15px;text-align:center}.create-link-button{all:unset;border:none!important;box-shadow:none!important;color:var(--accent-color)!important;cursor:pointer;font-size:22px!important;line-height:1.6;margin:0!important;padding:0!important;text-decoration:underline;transition:color .2s ease}.create-link-button,.create-link-button:hover{background:#0000!important;background-color:initial!important}.create-link-button:hover{color:var(--primary-color)!important;text-decoration:none}.organization-list{display:flex;flex-direction:column;gap:12px;max-height:60vh;overflow-y:auto;padding-right:4px}.organization-item{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:20px;text-align:left;transition:all .2s ease}.organization-item:hover{background:var(--bg-input);border-color:var(--accent-color);box-shadow:0 4px 8px var(--shadow-color);transform:translateY(-2px)}.organization-name{color:var(--text-primary);font-size:24px;font-weight:600}.organization-id-row{align-items:center;display:flex;gap:8px;justify-content:space-between}.organization-id{color:var(--text-secondary);flex:1 1;font-family:monospace}.organization-installations{color:var(--text-secondary);font-size:16px;font-style:italic}.button-group{flex-wrap:wrap}.button-group .back-button,.button-group .manage-button{min-width:200px}.button-group .logout-button{align-items:center;background:#5a5e68;border:1px solid #6a6e78;border-radius:8px;color:#e8e8e8;cursor:pointer;display:flex;flex:1 1;font-size:20px;font-weight:700;justify-content:center;margin-top:0;min-width:200px;padding:12px;text-align:center;transition:all .2s ease}.button-group .logout-button:hover{background:#6a6e78;border-color:#7a7e88}body.light-mode .button-group .logout-button{background:#d0d4dc;border:1px solid #b0b4bc;color:#495057}body.light-mode .button-group .logout-button:hover{background:#c0c4cc;border-color:#a0a4ac}.organization-selector-card .back-button{background:#5a5e68;border:1px solid #6a6e78;border-radius:8px;color:#e8e8e8;cursor:pointer;font-size:20px;font-weight:700;margin-top:10px;padding:12px;transition:all .2s ease;width:100%}.organization-selector-card .back-button:hover{background:#6a6e78;border-color:#7a7e88}body.light-mode .organization-selector-card .back-button{background:#d0d4dc;border:1px solid #b0b4bc;color:#495057}body.light-mode .organization-selector-card .back-button:hover{background:#c0c4cc;border-color:#a0a4ac}.installation-selector-container{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:20px}.installation-selector-card{background:var(--bg-secondary);border-radius:12px;box-shadow:0 4px 6px var(--shadow-color);max-width:1000px;padding:40px;width:100%}.installation-selector-card h2{color:var(--text-primary);font-size:28px;margin:0 0 10px;text-align:center}.subtitle{color:var(--text-secondary);font-size:16px;margin:0 0 20px;text-align:center}.subtitle strong{color:var(--text-primary)}.search-container{margin-bottom:20px;margin-left:-40px;margin-right:-40px;padding-left:40px;padding-right:40px;position:relative}.search-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;box-sizing:border-box;font-size:14px;padding:12px 40px 12px 12px;transition:border-color .2s ease;width:100%}.search-input::placeholder{color:var(--text-muted)}.search-clear-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:24px;line-height:1;padding:4px 8px;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:color .2s ease}.search-clear-button:hover{color:var(--text-primary)}.installation-selector-card .error-message{background:var(--bg-tertiary);border-radius:8px;box-sizing:border-box;color:var(--status-error);display:block;font-size:18px;line-height:1.6;margin:0 0 20px;padding:15px 20px;text-align:center!important;width:100%}.support-link{color:var(--accent-color);cursor:pointer;text-decoration:underline;transition:color .2s ease}.support-link:hover{color:var(--primary-color);text-decoration:none}.installation-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;max-height:60vh;overflow-y:auto;padding-right:4px}.installation-item{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:20px;text-align:left;transition:all .2s ease}.installation-item:hover{background:var(--bg-input);border-color:var(--accent-color);box-shadow:0 4px 8px var(--shadow-color);transform:translateY(-2px)}.installation-name{color:var(--text-primary);font-size:24px;font-weight:600}.installation-id-row{align-items:center;display:flex;gap:8px;justify-content:space-between}.installation-id{color:var(--text-secondary);flex:1 1;font-family:monospace;font-size:16px}.copy-id-button{background:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;flex-shrink:0;font-size:16px;padding:4px 8px;transition:all .2s ease}.copy-id-button:hover{background:var(--bg-tertiary);border-color:var(--accent-color);transform:scale(1.1)}.back-button{background:#5a5e68;border:1px solid #6a6e78;border-radius:8px;color:#e8e8e8;cursor:pointer;font-size:20px;font-weight:700;margin-top:10px;padding:12px;transition:all .2s ease;width:100%}.back-button:hover{background:#6a6e78;border-color:#7a7e88}body.light-mode .back-button{background:#d0d4dc;border:1px solid #b0b4bc;color:#495057}body.light-mode .back-button:hover{background:#c0c4cc;border-color:#a0a4ac}.button-group{display:flex;gap:10px;margin-top:10px}.button-group .manage-button{background:#5a5e68;border:1px solid #6a6e78;border-radius:8px;color:#e8e8e8;cursor:pointer;flex:1 1;font-size:20px;font-weight:700;margin-top:0;min-width:250px;padding:12px;transition:all .2s ease}.button-group .manage-button:hover{background:#6a6e78;border-color:#7a7e88}body.light-mode .button-group .manage-button{background:#d0d4dc;border:1px solid #b0b4bc;color:#495057}body.light-mode .button-group .manage-button:hover{background:#c0c4cc;border-color:#a0a4ac}.button-group .back-button{flex:1 1;margin-top:0;min-width:250px}.installation-selector-card .logout-button{background:#5a5e68;border:1px solid #6a6e78;border-radius:8px;color:#e8e8e8;cursor:pointer;display:block;font-size:20px;font-weight:700;margin-top:60px;padding:12px;text-align:center;transition:all .2s ease;width:100%}.installation-selector-card .logout-button:hover{background:#6a6e78;border-color:#7a7e88}body.light-mode .installation-selector-card .logout-button{background:#d0d4dc;border:1px solid #b0b4bc;color:#495057}body.light-mode .installation-selector-card .logout-button:hover{background:#c0c4cc;border-color:#a0a4ac}:root{--bg-primary:#282c34;--bg-secondary:#3c4049;--bg-tertiary:#4a4e56;--bg-input:#444;--bg-button-disabled:#ccc;--bg-header-dark:#555;--text-primary:#fff;--text-secondary:#ccc;--text-muted:#888;--text-on-accent:#282c34;--text-on-disabled:#333;--accent-color:#61dafb;--accent-color-hover:#52b8d8;--accent-color-disabled:#61dafb;--border-color:#555;--border-color-light:#666;--border-color-subtle:#4a4e57;--hover-bg:#ffffff0d;--status-success:#4caf50;--status-error:#f44336;--status-warning:#f9a825;--status-info:#61dafb;--shadow-color:#00000080}body.light-mode{--bg-primary:#f0f2f5;--bg-secondary:#fff;--bg-tertiary:#f8f9fa;--bg-input:#e9ecef;--bg-button-disabled:#ccc;--bg-header-light:#dee2e6;--text-primary:#212529;--text-secondary:#495057;--text-muted:#6c757d;--text-on-accent:#fff;--text-on-disabled:#333;--accent-color:#007bff;--accent-color-hover:#0069d9;--accent-color-disabled:#007bff;--border-color:#dee2e6;--border-color-light:#ced4da;--border-color-subtle:#e9ecef;--hover-bg:#0000000d;--status-success:#28a745;--status-error:#dc3545;--status-warning:#ffc107;--status-info:#007bff;--shadow-color:#00000026}.edit-modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);height:100%;width:100%;z-index:2500}.edit-modal-dialog{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 5px 20px var(--shadow-color);color:var(--text-primary);max-width:450px;padding:30px 40px;text-align:left}.edit-modal-dialog h2{color:var(--accent-color);margin-bottom:20px;text-align:center}.edit-modal-dialog label{color:var(--text-secondary);font-weight:700;margin-bottom:8px}.edit-modal-dialog input[type=text]{background-color:var(--bg-input);border:1px solid var(--border-color-light);border-radius:5px;box-sizing:border-box;color:var(--text-primary);font-size:1rem;margin-bottom:20px;padding:10px 12px;width:100%}.edit-modal-actions{gap:15px;margin-top:25px}.edit-modal-button{border-radius:5px;font-size:.9rem;font-weight:700;padding:10px 20px;transition:background-color .2s,transform .1s,opacity .2s}.edit-modal-button.save{background-color:var(--accent-color);color:var(--text-on-accent)}.edit-modal-button.save:hover{background-color:var(--accent-color-hover)}.edit-modal-button.cancel{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary)}.edit-modal-button.cancel:hover{background-color:var(--border-color)}.edit-modal-button:active{transform:scale(.98)}.edit-modal-button:disabled{background-color:var(--bg-button-disabled);color:var(--text-on-disabled);opacity:.6}.save-spinner{animation:spin 1s linear infinite;border-left:2px solid var(--text-on-accent);margin-left:8px;vertical-align:middle}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;padding:0;transition:background-color .3s ease,color .3s ease}.App{box-sizing:border-box;min-height:100vh;padding:0 .5in 70px;text-align:center}.App-header{display:flex;flex-direction:column;gap:15px;margin-bottom:0;padding:20px 20px 5px;position:relative}.App-header h1{color:var(--accent-color);font-size:1.8rem;margin-bottom:1rem;margin-top:0}.header-logo-container{left:20px;z-index:10}.header-link-container{align-items:center;flex-wrap:wrap;justify-content:flex-end}.org-install-in-header{display:flex;justify-content:center;margin-top:10px}@media (max-width:1280px){.App-header{align-items:center;gap:10px;padding:15px;text-align:center}.header-logo-container{display:flex;justify-content:center;left:auto!important;margin-bottom:10px;position:static!important;top:auto!important;width:100%}.App-header h1{font-size:1.2rem;line-height:1.4;margin-bottom:.5rem;margin-top:0;padding:0 80px}.org-install-in-header{margin-top:5px;width:100%}}.context-bar{background-color:var(--bg-primary);border-top:2px solid #999;height:0;margin:0}[data-theme=dark-mode] .context-bar{border-top:2px solid #555}.app-layout-container{display:flex;flex-direction:row;height:100vh;overflow:hidden;width:100%}.main-content-wrapper{box-sizing:border-box;overflow-x:hidden;overflow-y:auto;padding:10px 0 20px;width:100%}.page-content{display:flex;flex-direction:column;gap:4px;padding:20px 0;position:relative}.device-selector-container{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:.25rem;justify-content:center;margin-bottom:.25rem;margin-top:.5rem}@media (max-width:768px){.device-selector-container{flex-direction:column}}.device-selector-container label{color:var(--accent-color);font-size:1.3rem;font-weight:700;margin-right:.5rem}.device-selector-container select{background-color:var(--bg-input);border:1px solid var(--border-color-light);border-radius:5px;color:var(--text-primary);cursor:pointer;font-size:1.1rem;padding:8px 12px;transition:background-color .3s ease,border-color .3s ease,color .3s ease;width:436px}.refresh-button{align-items:center;background:none;border:none;color:var(--accent-color);cursor:pointer;display:inline-flex;font-size:2.5rem;gap:6px;line-height:1;padding:8px 16px;transition:transform .2s,color .2s}.refresh-button:hover{color:var(--accent-color-hover);transform:scale(1.05)}.refresh-button:disabled{cursor:not-allowed;opacity:.7}.refresh-spinner{animation:spin 1s linear infinite;display:inline-block;font-size:3rem}.credential-container h2.draggable-header,.device-actions-container h2,.device-state-container h2,.last-action-header{cursor:grab}.credential-container h2.draggable-header:active,.device-actions-container h2:active,.device-state-container h2:active,.last-action-header:active{cursor:grabbing}.credential-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box;overflow:hidden;padding:0;position:relative;text-align:left;transition:background-color .3s ease,border-color .3s ease;width:100%}.credential-container h2.draggable-header{align-items:center;background-color:var(--bg-header-dark);border-bottom:1px solid var(--border-color);color:var(--accent-color);cursor:grab;display:flex;justify-content:space-between;margin:0;padding:10px 15px;transition:background-color .3s ease,border-color .3s ease;-webkit-user-select:none;user-select:none}body.light-mode .credential-container h2.draggable-header{background-color:var(--bg-header-light)}.credential-container h2 .collapse-icon{color:var(--text-secondary);cursor:pointer;font-size:1rem}.credential-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));padding:15px}.credential-loading-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#000000b3;border-radius:8px;bottom:0;display:flex;flex-direction:column;gap:12px;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.credential-loading-overlay .hourglass-flip{animation:spin 2s linear infinite;display:inline-block;font-size:32px}.credential-loading-overlay .loading-text{color:#fff;font-size:16px;font-weight:600;text-shadow:0 1px 2px #0000004d}.credential-card{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-left:5px solid var(--accent-color);border-radius:8px;box-shadow:0 2px 4px var(--shadow-color);padding:12px;text-align:left;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out,background-color .3s ease,border-color .3s ease}.credential-card:hover{box-shadow:0 4px 8px var(--shadow-color);transform:translateY(-3px)}.credential-card h3{color:var(--accent-color);font-size:1.1rem;margin-bottom:8px;margin-top:0}.credential-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.credential-card-header h3{margin:0}.credential-delete-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.3rem;opacity:.7;padding:4px 8px;transition:background-color .2s ease,transform .1s ease}.credential-delete-btn:hover{background-color:#ff00001a;opacity:1;transform:scale(1.1)}.credential-delete-btn:active{transform:scale(.95)}.credential-card p{word-break:break-all}.cred-wiegand-info,.credential-card p{color:var(--text-secondary);font-size:.85rem;margin:4px 0}.cred-wiegand-info{display:flex;flex-wrap:wrap;gap:12px}.cred-wiegand-field{white-space:nowrap}.cred-wiegand-field strong{color:var(--text-primary)}.cred-photo-container{display:flex;justify-content:center;margin:8px 0 10px}.cred-badge-photo{border:3px solid var(--accent-color);border-radius:50%;box-shadow:0 2px 8px #00000026;height:80px;object-fit:cover;width:80px}.cred-user{color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:8px}.cred-user>strong{color:var(--accent-color);font-weight:400;margin-right:5px}.cred-email{color:var(--text-secondary);font-size:.85rem;margin-bottom:5px}.cred-email>strong{color:var(--accent-color);font-weight:400;margin-right:5px}.cred-device-type{border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-size:.85rem;margin-bottom:10px;padding-bottom:10px}.cred-device-type>strong{color:var(--accent-color);font-weight:400;margin-right:5px}.cred-id{color:var(--text-muted);font-size:.8rem}.cred-id>strong,.cred-status>span,.cred-value>strong{color:var(--accent-color);font-weight:400}.cred-value>strong{margin-right:5px}.cred-status{align-items:center;border-top:1px solid var(--border-color);display:flex;font-size:.9rem;margin-top:15px;padding-top:10px}.cred-status span{color:var(--accent-color);margin-right:8px}.cred-status strong{font-weight:700}.credential-card.active{border-left-color:var(--status-success)}.credential-card.suspended{border-left-color:var(--status-warning)}.credential-card.active .cred-status strong{color:var(--status-success)}.credential-card.suspended .cred-status strong{color:var(--status-warning)}.credential-deletion-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:8px}.credential-deletion-message{animation:pulse 1.5s ease-in-out infinite;font-size:1.1rem;padding:20px;text-align:center}.credential-deletion-message strong{font-weight:700;text-shadow:0 2px 4px #00000080}.credential-card.pending-deletion{pointer-events:none}.credential-card.pending-deletion .credential-delete-btn{cursor:not-allowed;opacity:.3}.footer-status-bar{align-items:center;background-color:var(--bg-secondary);border-top:1px solid var(--border-color);bottom:0;box-sizing:border-box;display:flex;font-size:.9rem;justify-content:space-between;left:0;padding:8px 20px;position:fixed;transition:background-color .3s ease,border-color .3s ease;width:100%;z-index:100}.footer-status-bar.hidden{display:none}.connection-status-container{align-items:center;display:flex;gap:15px}.footer-status-bar p{color:var(--text-secondary);margin:0}.footer-status-bar span.connected{color:var(--status-success);font-weight:700}.footer-status-bar span.connection-error,.footer-status-bar span.disconnected{color:var(--status-error);font-weight:700}.footer-status-bar span.connecting{color:var(--status-warning);font-weight:700}.reconnect-button{background-color:var(--accent-color);border:none;border-radius:4px;color:var(--text-on-accent);cursor:pointer;font-size:.8rem;font-weight:700;margin-left:0;padding:4px 12px;transition:background-color .2s}.reconnect-button:hover{background-color:var(--accent-color-hover)}.footer-toggles-container{align-items:center;display:flex;gap:25px}.loading-container{align-items:center;background-color:#000c;color:var(--text-secondary);display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.loading-spinner{border:4px solid #fff3;border-left:4px solid var(--accent-color);margin-bottom:1rem}.notification-popup{animation:toast-in-out 3s ease-in-out forwards;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);font-size:1rem;font-weight:700;padding:15px 25px;position:fixed;right:20px;top:20px;transition:background-color .3s ease,border-color .3s ease,color .3s ease;z-index:2000}.notification-success{border-left:5px solid var(--status-success);color:var(--status-success)}.notification-error{border-left:5px solid var(--status-error);color:var(--status-error)}@keyframes toast-in-out{0%{opacity:0;transform:translateX(110%)}15%,85%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(110%)}}.header-logo-container{left:30px;position:absolute;top:20px}.header-link-container{display:flex;gap:15px;position:absolute;right:30px;top:30px}.external-link{border:1px solid var(--accent-color);border-radius:5px;color:var(--accent-color);font-size:.9rem;font-weight:700;padding:8px 15px;text-decoration:none;transition:all .3s ease;white-space:nowrap}.external-link:hover{background-color:var(--accent-color);box-shadow:0 0 10px var(--accent-color);color:var(--text-on-accent)}.error-overlay{align-items:center;background-color:#282c34f2;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:3000}.error-message-box{background-color:var(--bg-secondary);border:1px solid var(--status-error);border-radius:8px;box-shadow:0 5px 15px var(--shadow-color);max-width:500px;padding:2rem 3rem;text-align:center}.error-message-box h2{color:var(--status-error);margin-bottom:1rem;margin-top:0}.error-message-box p{color:var(--text-secondary);line-height:1.6}.no-devices-message{color:var(--text-secondary);margin-top:40px}.no-devices-message p{margin-bottom:20px}.no-devices-message h1{color:var(--accent-color);margin-bottom:10px}.content-divider{border:none;border-top:1px solid var(--border-color-subtle);margin:0}.view-switcher{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1rem 0;text-align:center}.view-switch-button{background-color:var(--accent-color);border:1px solid var(--border-color);border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.view-switch-button:hover{background-color:var(--accent-color-hover);box-shadow:0 2px 8px #0003;transform:translateY(-1px)}.device-selector-container.simplified-view{margin-bottom:.5rem;margin-top:.75rem}.device-selector-container.simplified-view label{font-size:2rem;font-weight:700;margin-right:1rem}.device-selector-container.simplified-view select{border-radius:8px;border-width:2px;font-size:1.6rem;font-weight:600;padding:16px 20px;width:600px}@media (max-width:768px){.main-content-wrapper{padding:10px 20px 20px}.device-selector-container{align-items:stretch!important;display:flex!important;flex-direction:column!important;flex-wrap:nowrap!important;gap:.75rem!important;justify-content:flex-start!important;margin:0!important;padding:0!important;width:100%!important}.device-selector-container label{display:block!important;font-size:1.3rem!important;margin:0!important;order:0!important;text-align:center!important;width:100%!important}.device-selector-container select{display:block!important;margin:0!important;max-width:100%!important;order:1!important;width:100%!important}.device-selector-container .refresh-button{align-self:center!important;margin:0!important;order:2!important}.device-selector-container.simplified-view{gap:1rem!important}.device-selector-container.simplified-view label{font-size:1.5rem!important}.device-selector-container.simplified-view select{font-size:1.3rem!important;max-width:100%!important;padding:14px 18px!important;width:100%!important}}@media (max-width:480px){.device-selector-container.simplified-view label{font-size:1.3rem!important}.device-selector-container.simplified-view select{font-size:1.2rem!important;padding:12px 16px!important}}.auto-reconnect-toggle-container,.auto-reconnect-toggle-label{align-items:center;display:flex}.auto-reconnect-toggle-label{color:var(--text-secondary);cursor:pointer;font-size:.9rem;gap:10px;position:relative;-webkit-user-select:none;user-select:none}.auto-reconnect-toggle-checkbox{height:0;opacity:0;position:absolute;width:0}.auto-reconnect-toggle-slider{background-color:#555;border-radius:20px;display:inline-block;height:20px;position:relative;transition:background-color .3s ease;width:40px}.auto-reconnect-toggle-slider:before{background-color:#fff;border-radius:50%;bottom:2px;content:"";height:16px;left:2px;position:absolute;transition:transform .3s ease;width:16px}.auto-reconnect-toggle-checkbox:checked+.auto-reconnect-toggle-slider{background-color:var(--accent-color)}.auto-reconnect-toggle-checkbox:checked+.auto-reconnect-toggle-slider:before{transform:translateX(20px)}.auto-reconnect-toggle-label.disabled{cursor:not-allowed;opacity:.5}.auto-reconnect-toggle-label.disabled .auto-reconnect-toggle-slider{cursor:not-allowed}.auto-reconnect-toggle-checkbox:disabled+.auto-reconnect-toggle-slider{cursor:not-allowed;opacity:.6}.auto-reconnect-toggle-container:has(.auto-reconnect-toggle-checkbox:disabled){cursor:help}.modal-toggle-container{align-items:center;display:flex;transition:opacity .3s ease}.modal-toggle-label{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;gap:10px;position:relative;transition:color .3s ease;-webkit-user-select:none;user-select:none}.modal-toggle-checkbox{height:0;opacity:0;position:absolute;width:0}.modal-toggle-slider{background-color:#555;border-radius:20px;display:inline-block;height:20px;position:relative;transition:background-color .3s ease;width:40px}.modal-toggle-slider:before{background-color:#fff;border-radius:50%;bottom:2px;content:"";height:16px;left:2px;position:absolute;transition:transform .3s ease,background-color .3s ease;width:16px}.modal-toggle-checkbox:checked+.modal-toggle-slider{background-color:var(--accent-color)}.modal-toggle-checkbox:checked+.modal-toggle-slider:before{transform:translateX(20px)}.modal-toggle-container.disabled{opacity:.5}.modal-toggle-container.disabled .modal-toggle-label{color:var(--text-muted);cursor:not-allowed}.modal-toggle-container.disabled .modal-toggle-slider{background-color:var(--border-color)}.modal-toggle-container.disabled .modal-toggle-checkbox:checked+.modal-toggle-slider{background-color:var(--border-color);background-color:var(--accent-color-disabled,var(--border-color))}.modal-toggle-container.disabled .modal-toggle-slider:before{background-color:#aaa}.theme-toggle-container,.theme-toggle-label{align-items:center;display:flex}.theme-toggle-label{color:var(--text-secondary);cursor:pointer;font-size:.9rem;gap:10px;-webkit-user-select:none;user-select:none}.toggle-switch{height:26px}.slider{background-color:#555;border-radius:26px;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{align-items:center;background-color:#fff;border-radius:50%;bottom:4px;content:"🌙";display:flex;font-size:12px;height:18px;justify-content:center;left:5px;width:18px}input:checked+.slider{background-color:var(--accent-color)}input:checked+.slider:before{content:"☀️";transform:translateX(22px)}.reset-layout-button{background:none;border:1px solid #fff3;border:1px solid var(--border-color,#fff3);border-radius:4px;color:#999;color:var(--text-secondary,#999);cursor:pointer;font-size:.75rem;padding:3px 8px;transition:color .2s,border-color .2s;white-space:nowrap}.reset-layout-button:hover{border-color:#667eea;border-color:var(--accent-color,#667eea);color:#667eea;color:var(--accent-color,#667eea)}.footer-links-container{align-items:center;border-top:1px solid #ffffff1a;border-top:1px solid var(--border-color,#ffffff1a);display:flex;justify-content:center;margin-top:8px;padding:8px 0}.privacy-policy-link{color:#667eea;color:var(--accent-color,#667eea);font-size:.85rem;text-decoration:none;transition:opacity .2s ease}.privacy-policy-link:hover{opacity:.8;text-decoration:underline}.edit-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.edit-modal-dialog{background:#1a1a1a;background:var(--bg-color,#1a1a1a);border-radius:8px;box-shadow:0 4px 20px #00000080;max-width:500px;padding:2rem;width:90%}.edit-modal-dialog h2{color:#e0e0e0;color:var(--text-color,#e0e0e0);margin-bottom:1.5rem;margin-top:0}.edit-modal-dialog label{color:#e0e0e0;color:var(--text-color,#e0e0e0);display:block;font-weight:500;margin-bottom:.5rem}.edit-modal-dialog input{background:#2a2a2a;background:var(--card-bg,#2a2a2a);border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:4px;box-sizing:border-box;color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:1rem;margin-bottom:1.5rem;padding:.75rem;width:100%}.edit-modal-dialog input:focus{border-color:#667eea;border-color:var(--accent-color,#667eea);outline:none}.edit-modal-dialog input:disabled{cursor:not-allowed;opacity:.6}.edit-modal-actions{display:flex;gap:1rem;justify-content:flex-end}.edit-modal-button{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:1rem;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.edit-modal-button.cancel{background:#2a2a2a;background:var(--card-bg,#2a2a2a);border:1px solid #444;border:1px solid var(--border-color,#444);color:#e0e0e0;color:var(--text-color,#e0e0e0)}.edit-modal-button.cancel:hover:not(:disabled){background:#333;background:var(--hover-bg,#333)}.edit-modal-button.save{background:#667eea;background:var(--accent-color,#667eea);color:#fff}.edit-modal-button.save:hover:not(:disabled){background:#5568d3;background:var(--accent-hover,#5568d3)}.edit-modal-button:disabled{cursor:not-allowed;opacity:.5}.edit-modal-radio-group{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.edit-modal-radio-label{align-items:center!important;color:#e0e0e0;color:var(--text-color,#e0e0e0);cursor:pointer;display:flex!important;flex-direction:row!important;font-weight:400!important;gap:.5rem;margin-bottom:0!important}.edit-modal-radio-label input[type=radio]{accent-color:#667eea;accent-color:var(--accent-color,#667eea);cursor:pointer;margin:0;margin-bottom:0!important;padding:0;width:auto}.edit-modal-slider-group{align-items:center;display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.edit-modal-slider-value{color:#667eea;color:var(--accent-color,#667eea);font-size:1.75rem;font-weight:700}.edit-modal-slider{accent-color:#667eea;accent-color:var(--accent-color,#667eea);cursor:pointer;height:6px;width:100%}.edit-modal-slider:disabled{cursor:not-allowed;opacity:.5}.edit-modal-slider-range{color:#888;color:var(--text-secondary,#888);display:flex;font-size:.8rem;justify-content:space-between;width:100%}.save-spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;width:14px}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background-color:#000000b3;height:100%;width:100%;z-index:2500}.modal-dialog{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 5px 20px var(--shadow-color);color:var(--text-primary);max-width:450px;padding:30px 40px;text-align:center;width:90%}.modal-dialog h2{color:var(--status-error);margin-bottom:15px;margin-top:0}.modal-dialog p{color:var(--text-secondary);line-height:1.5;margin-bottom:10px}.modal-dialog p:last-of-type{font-weight:700;margin-bottom:25px}.modal-status-connection-error,.modal-status-disconnected{color:var(--status-error);font-weight:700}.modal-reconnect-button{background-color:var(--accent-color);border:none;border-radius:5px;color:var(--text-on-accent);cursor:pointer;font-size:1rem;font-weight:700;padding:12px 25px;transition:background-color .2s,transform .1s}.modal-reconnect-button:hover{background-color:var(--accent-color-hover)}.modal-reconnect-button:active{transform:scale(.98)}.forced-entry-modal{background-color:var(--background-color);border:2px solid var(--error-color);border-radius:8px;box-shadow:0 4px 6px #0000004d;color:var(--text-color);left:50%;max-width:500px;padding:1.5rem;position:fixed;text-align:center;top:50%;transform:translate(-50%,-50%);width:500px;z-index:10550}body.light-mode .forced-entry-modal{background-color:#fff;border:2px solid #dc3545;color:#1a1a1a}body:not(.light-mode) .forced-entry-modal{background-color:#1a1a1a;border:2px solid #ff6b6b;color:#e0e0e0}.forced-entry-modal h2{color:#dc3545;font-size:1.5rem;font-weight:700;margin-bottom:.5rem;text-align:center}body:not(.light-mode) .forced-entry-modal h2{color:#ff6b6b}.forced-entry-modal h3{color:#dc3545;font-size:1.3rem;font-weight:700;margin-bottom:1rem;text-align:center}body:not(.light-mode) .forced-entry-modal h3{color:#ff6b6b}.forced-entry-modal p{color:inherit;font-size:1rem;line-height:1.5;margin-bottom:1rem}body.light-mode .forced-entry-modal p{color:#1a1a1a}body:not(.light-mode) .forced-entry-modal p{color:#e0e0e0}.forced-entry-modal p.centered{text-align:center}.forced-entry-modal .device-details{border-spacing:0 .3rem;display:inline-block;margin:1rem auto}.forced-entry-modal .device-details td{font-size:.95rem;padding:.25rem .5rem;text-align:left}body.light-mode .forced-entry-modal .device-details td{color:#1a1a1a}body:not(.light-mode) .forced-entry-modal .device-details td{color:#e0e0e0}.forced-entry-modal .device-details td:first-child{font-weight:600;padding-right:1rem;text-align:right;white-space:nowrap}body.light-mode .forced-entry-modal .device-details td:first-child{color:#666}body:not(.light-mode) .forced-entry-modal .device-details td:first-child{color:#999}.forced-entry-modal button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.forced-entry-modal button:hover{background-color:#c82333}.forced-entry-modal-overlay{background-color:#000000b3;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.forced-entry-modal{animation:flash 1s infinite}.propped-door-modal-overlay{background-color:#000000b3;bottom:0;left:0;position:fixed;right:0;top:0;z-index:10549}.propped-door-modal{background-color:var(--background-color);border:2px solid #06c;border-radius:8px;box-shadow:0 4px 6px #0000004d;color:var(--text-color);left:50%;max-width:500px;padding:1.5rem;position:fixed;text-align:center;top:50%;transform:translate(-50%,-50%);width:500px;z-index:10550}body.light-mode .propped-door-modal{background-color:#fff;border:2px solid #06c;color:#1a1a1a}body:not(.light-mode) .propped-door-modal{background-color:#1a1a1a;border:2px solid #4da6ff;color:#e0e0e0}.propped-door-modal h2{color:#06c;font-size:1.5rem;font-weight:700;margin-bottom:.5rem;text-align:center}body:not(.light-mode) .propped-door-modal h2{color:#4da6ff}.propped-door-modal h3{color:#06c;font-size:1.3rem;font-weight:700;margin-bottom:1rem;text-align:center}body:not(.light-mode) .propped-door-modal h3{color:#4da6ff}.propped-door-modal p{color:inherit;font-size:1rem;line-height:1.5;margin-bottom:1rem}body.light-mode .propped-door-modal p{color:#1a1a1a}body:not(.light-mode) .propped-door-modal p{color:#e0e0e0}.propped-door-modal p.centered{text-align:center}.propped-door-modal .device-details{border-spacing:0 .3rem;display:inline-block;margin:1rem auto}.propped-door-modal .device-details td{font-size:.95rem;padding:.25rem .5rem;text-align:left}body.light-mode .propped-door-modal .device-details td{color:#1a1a1a}body:not(.light-mode) .propped-door-modal .device-details td{color:#e0e0e0}.propped-door-modal .device-details td:first-child{font-weight:600;padding-right:1rem;text-align:right;white-space:nowrap}body.light-mode .propped-door-modal .device-details td:first-child{color:#666}body:not(.light-mode) .propped-door-modal .device-details td:first-child{color:#999}.propped-door-modal button{background-color:#06c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;margin-top:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.propped-door-modal button:hover{background-color:#0052a3}body:not(.light-mode) .propped-door-modal button{background-color:#4da6ff}body:not(.light-mode) .propped-door-modal button:hover{background-color:#3d8fd9}@keyframes flash-blue{0%,to{box-shadow:0 4px 6px #0000004d}50%{box-shadow:0 0 30px #06cc}}.propped-door-modal{animation:flash-blue 1s ease-in-out infinite}.event-denied-modal{background-color:var(--background-color);border:2px solid orange;border:2px solid var(--warning-color,orange);border-radius:8px;box-shadow:0 4px 6px #0000004d;color:var(--text-color);left:50%;max-width:500px;padding:1.5rem;position:fixed;text-align:center;top:50%;transform:translate(-50%,-50%);width:500px;z-index:1000}body.light-mode .event-denied-modal{background-color:#fff;border:2px solid #ff8c00;color:#1a1a1a}body:not(.light-mode) .event-denied-modal{background-color:#1a1a1a;border:2px solid orange;color:#e0e0e0}.event-denied-modal h2{color:#ff8c00;font-size:1.5rem;font-weight:700;margin-bottom:.5rem;text-align:center}body:not(.light-mode) .event-denied-modal h2{color:orange}.event-denied-modal h3{color:#ff8c00;font-size:1.2rem;font-weight:600;margin-bottom:1rem;text-align:center}body:not(.light-mode) .event-denied-modal h3{color:orange}.event-denied-modal p{color:inherit;font-size:1rem;line-height:1.5;margin-bottom:1rem}body.light-mode .event-denied-modal p{color:#1a1a1a}body:not(.light-mode) .event-denied-modal p{color:#e0e0e0}.event-denied-modal p.centered{text-align:center}.event-denied-modal .device-details{border-spacing:0 .3rem;display:inline-block;margin:1rem auto}.event-denied-modal .device-details td{font-size:.95rem;padding:.25rem .5rem;text-align:left}body.light-mode .event-denied-modal .device-details td{color:#1a1a1a}body:not(.light-mode) .event-denied-modal .device-details td{color:#e0e0e0}.event-denied-modal .device-details td:first-child{font-weight:600;padding-right:1rem;text-align:right;white-space:nowrap}.event-denied-modal button{background-color:#ff8c00;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.event-denied-modal button:hover{background-color:#e67e00}body:not(.light-mode) .event-denied-modal button{background-color:orange}body:not(.light-mode) .event-denied-modal button:hover{background-color:#ff8c00}.event-denied-modal-overlay{background-color:#00000080;height:100%;left:0;position:fixed;top:0;width:100%;z-index:999}.advanced-settings-overlay{align-items:center;animation:fadeIn .2s ease;background:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.advanced-settings-modal{animation:slideIn .3s ease;background:#fff;background:var(--modal-background,#fff);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:80vh;max-width:500px;overflow-y:auto;padding:30px;position:relative;width:90%}.advanced-settings-modal h2{color:#333;color:var(--text-color,#333);font-size:24px;margin:0 0 10px}.advanced-settings-modal .subtitle{color:#666;color:var(--text-secondary-color,#666);font-size:14px;margin-bottom:25px}.advanced-settings-modal .close-button{align-items:center;background:none;border:none;border-radius:4px;color:#666;color:var(--text-secondary-color,#666);cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;position:absolute;right:15px;top:15px;transition:background-color .2s ease,color .2s ease;width:32px}.advanced-settings-modal .close-button:hover{background-color:#f0f0f0;background-color:var(--hover-background,#f0f0f0);color:#333;color:var(--text-color,#333)}.settings-section{margin-bottom:20px}.setting-item{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;justify-content:space-between;padding:15px 0}.setting-item:last-child{border-bottom:none}.setting-info{flex:1 1}.setting-info h3{color:#333;color:var(--text-color,#333);font-size:16px;font-weight:600;margin:0 0 5px}.setting-info p{color:#666;color:var(--text-secondary-color,#666);font-size:13px;line-height:1.4;margin:0}.setting-control{margin-left:20px}.setting-restriction-notice{color:#666;color:var(--text-secondary,#666);font-size:.9em;font-style:italic;margin-top:8px}.advanced-settings-modal .action-buttons{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color,#e0e0e0);display:flex;gap:10px;justify-content:flex-end;margin-top:25px;padding-top:20px}.advanced-settings-modal .btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.advanced-settings-modal .btn-secondary{background-color:#e0e0e0;background-color:var(--button-secondary-bg,#e0e0e0);color:#333;color:var(--button-secondary-text,#333)}.advanced-settings-modal .btn-secondary:hover{background-color:#d0d0d0;background-color:var(--button-secondary-hover-bg,#d0d0d0)}.advanced-settings-modal .btn-primary{background-color:#007bff;background-color:var(--button-primary-bg,#007bff);color:#fff}.advanced-settings-modal .btn-primary:hover{background-color:#0056b3;background-color:var(--button-primary-hover-bg,#0056b3)}.advanced-settings-modal .btn-primary:disabled{background-color:#ccc;background-color:var(--button-disabled-bg,#ccc);cursor:not-allowed}.loading-state{color:#666;color:var(--text-secondary-color,#666);padding:40px 20px;text-align:center}.error-state{background-color:#ffebee;background-color:var(--error-background,#ffebee);border-radius:6px;color:#d32f2f;color:var(--error-color,#d32f2f);margin-bottom:20px;padding:20px;text-align:center}.dark-theme .advanced-settings-modal{background:#2d2d2d;background:var(--modal-background-dark,#2d2d2d)}.dark-theme .advanced-settings-modal h2,.dark-theme .setting-info h3{color:#f0f0f0;color:var(--text-color-dark,#f0f0f0)}.dark-theme .advanced-settings-modal .subtitle,.dark-theme .setting-info p{color:#b0b0b0;color:var(--text-secondary-color-dark,#b0b0b0)}.dark-theme .setting-item{border-bottom-color:#444;border-bottom-color:var(--border-color-dark,#444)}.dark-theme .advanced-settings-modal .action-buttons{border-top-color:#444;border-top-color:var(--border-color-dark,#444)}.dark-theme .advanced-settings-modal .close-button{color:#b0b0b0;color:var(--text-secondary-color-dark,#b0b0b0)}.dark-theme .advanced-settings-modal .close-button:hover{background-color:#3d3d3d;background-color:var(--hover-background-dark,#3d3d3d);color:#f0f0f0;color:var(--text-color-dark,#f0f0f0)}.toggle-switch{display:inline-block;height:24px;position:relative;width:50px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#ccc;border-radius:24px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;position:absolute;transition:.3s;width:18px}.toggle-switch input:checked+.toggle-slider{background-color:#007bff}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(26px)}.toggle-switch input:disabled+.toggle-slider{cursor:not-allowed;opacity:.5}.dark-theme .toggle-slider{background-color:#555}.dark-theme .toggle-switch input:checked+.toggle-slider{background-color:#0056b3}.unsaved-changes-overlay{align-items:center;animation:fadeIn .2s ease;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.unsaved-changes-modal{animation:slideUp .3s ease;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 10px 40px #0006;color:var(--text-primary);max-width:500px;padding:24px 32px;width:90%}.unsaved-changes-header{border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:12px}.unsaved-changes-header h3{color:var(--text-primary);font-size:22px;font-weight:600;margin:0}.unsaved-changes-body{margin-bottom:24px}.unsaved-changes-body p{color:var(--text-primary);font-size:16px;line-height:1.5;margin:0}.unsaved-changes-actions{display:flex;gap:12px;justify-content:flex-end}.unsaved-changes-actions .btn-cancel{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:15px;font-weight:500;padding:10px 20px;transition:all .2s ease}.unsaved-changes-actions .btn-cancel:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.unsaved-changes-actions .btn-confirm{background:#d32f2f;border:1px solid #b71c1c;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;padding:10px 20px;transition:all .2s ease}.unsaved-changes-actions .btn-confirm:hover:not(:disabled){background:#c62828;transform:translateY(-1px)}@media (max-width:768px){.unsaved-changes-modal{padding:20px 24px;width:95%}.unsaved-changes-actions{flex-direction:column}.unsaved-changes-actions button{width:100%}}.device-claiming-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 5px 20px var(--shadow-color);color:var(--text-primary);max-height:90vh;max-width:700px;overflow-y:auto;padding:30px 40px;width:90%}.device-claiming-modal h2{color:var(--text-primary);font-size:24px;margin-bottom:20px;margin-top:0;text-align:center}.choice-buttons{display:flex;gap:20px;justify-content:center;margin:30px 0}.choice-buttons button{background-color:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;flex:1 1;font-size:18px;font-weight:600;padding:20px;transition:all .2s ease}.choice-buttons button:hover:not(:disabled){background-color:var(--accent-color);border-color:var(--accent-color);color:var(--text-on-accent);transform:translateY(-2px)}.choice-buttons button:disabled{cursor:not-allowed;opacity:.5}.claim-form{margin:20px 0}.claim-form label{color:var(--text-primary);display:block;font-weight:600;margin-bottom:8px}.claim-token-input{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;color:var(--text-primary);font-family:Courier New,monospace;font-size:14px;min-height:100px;padding:12px;resize:vertical;width:100%}.claim-token-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #61dafb1a;outline:none}.claim-token-input:disabled{background-color:var(--bg-button-disabled);cursor:not-allowed;opacity:.6}.decoded-token-section{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;margin-top:20px;padding:16px}.decoded-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.decoded-header label{color:var(--text-primary);font-weight:600;margin:0}.copy-button{background-color:var(--accent-color);border:none;color:var(--text-on-accent);font-size:14px;padding:6px 12px;transition:background-color .2s ease}.copy-button:hover{background-color:var(--accent-color-hover)}.decode-error{background-color:var(--bg-tertiary);border:1px solid var(--status-error);border-radius:4px;color:var(--status-error);font-weight:500;padding:12px}.decoded-token-display{max-height:400px;overflow-y:auto}.token-section{margin-bottom:16px}.token-section:last-child{margin-bottom:0}.token-section strong{color:var(--text-primary);display:block;margin-bottom:8px}.unclaim-form{margin:20px 0}.unclaim-form label{color:var(--text-primary);display:block;font-weight:600;margin-bottom:8px}.device-select{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;color:var(--text-primary);cursor:pointer;font-size:14px;padding:12px;width:100%}.device-select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #61dafb1a;outline:none}.device-select:disabled{background-color:var(--bg-button-disabled);cursor:not-allowed;opacity:.6}.confirmation-message{background-color:var(--bg-tertiary);border:1px solid var(--status-warning);border-radius:4px;margin:20px 0;padding:20px}.confirmation-message p{color:var(--text-primary);margin:0 0 12px}.confirmation-message p:last-child{margin-bottom:0}.typed-confirmation-section{margin-bottom:20px}.typed-confirmation-section label{color:var(--text-primary);display:block;font-size:14px;font-weight:600;margin-bottom:8px}.typed-confirmation-input{border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;font-family:Courier New,Courier,monospace;font-size:14px;padding:10px 12px}.typed-confirmation-input:focus{box-shadow:0 0 0 3px #61dafb1a}.typed-confirmation-input:disabled{background-color:var(--bg-button-disabled);opacity:.6}.typed-confirmation-input::placeholder{opacity:.7}.device-info{background-color:var(--bg-input);border-left:4px solid var(--accent-color);color:var(--text-primary);margin:12px 0;padding:12px}.warning-text{color:var(--status-warning);line-height:1.6}.result-message{border-radius:4px;font-size:16px;line-height:1.5;margin:20px 0;padding:20px}.result-message.success{background-color:var(--bg-tertiary);border:1px solid var(--status-success);color:var(--status-success)}.result-message.error{background-color:var(--bg-tertiary);border:1px solid var(--status-error);color:var(--status-error)}.auto-close-notice{color:var(--text-muted);font-size:14px;font-style:italic;margin-top:16px;text-align:center}.modal-actions{border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px}.modal-actions button{border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:600;padding:10px 24px;transition:all .2s ease}.modal-actions .cancel-button{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.modal-actions .cancel-button:hover:not(:disabled){background-color:var(--bg-input)}.device-claiming-modal .modal-actions .confirm-button,.device-claiming-modal .modal-actions .confirm-button:disabled{background:#4caf50!important;background-color:#4caf50!important;color:#fff!important}.device-claiming-modal .modal-actions .confirm-button:disabled{cursor:not-allowed;opacity:.5}.device-claiming-modal .modal-actions .confirm-button:hover:not(:disabled){background:#43a047!important;background-color:#43a047!important}.device-claiming-modal .modal-actions .confirm-button.unclaim-button,.device-claiming-modal .modal-actions .confirm-button.unclaim-button:disabled{background:#ef5350!important;background-color:#ef5350!important;color:#fff!important}.device-claiming-modal .modal-actions .confirm-button.unclaim-button:disabled{cursor:not-allowed;opacity:.5}.device-claiming-modal .modal-actions .confirm-button.unclaim-button:hover:not(:disabled){background:#d32f2f!important;background-color:#d32f2f!important}.modal-actions .confirm-button.warning{background-color:var(--status-error)!important;color:#fff!important}.modal-actions .confirm-button.warning:hover:not(:disabled){background-color:#c62828}.device-claiming-modal .modal-actions .confirm-button.success:not(:disabled){background-color:var(--status-success)!important;color:#fff!important}.device-claiming-modal .modal-actions .confirm-button.success:hover:not(:disabled){background-color:#43a047!important}.device-claiming-modal .modal-actions .confirm-button.success:disabled{background-color:var(--status-success)!important;color:#fff!important;cursor:not-allowed;opacity:.5}.modal-actions button:disabled{cursor:not-allowed;opacity:.5}.delete-cred-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;left:0;position:fixed;right:0;top:0;z-index:9998}.delete-cred-modal{animation:slideIn .2s ease-out;background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0000004d;left:50%;max-width:500px;padding:30px;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:9999}.delete-cred-modal h2{border-bottom:2px solid var(--border-color);color:var(--accent-color);font-size:1.5rem;margin:0 0 20px;padding-bottom:15px;text-align:center}.delete-cred-modal-content{margin-bottom:25px}.delete-cred-warning{color:var(--text-primary);font-size:1.1rem;line-height:1.5;margin-bottom:20px;text-align:center}.delete-cred-warning strong{color:var(--accent-color);font-weight:600}.delete-cred-details{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:15px;padding:15px}.delete-cred-details p{color:var(--text-secondary);font-size:.95rem;margin:8px 0}.delete-cred-details strong{color:var(--accent-color);margin-right:8px}.delete-cred-id{color:var(--text-muted)!important;font-size:.85rem!important;word-break:break-all}.delete-cred-notice{background-color:#ffa5001a;border:1px solid #ffa5004d;border-radius:6px;padding:12px}.delete-cred-notice p{color:var(--text-secondary);font-size:.9rem;margin:5px 0;text-align:center}.delete-cred-modal-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:25px}.delete-cred-cancel-btn,.delete-cred-confirm-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 24px;transition:all .2s ease}.delete-cred-cancel-btn{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.delete-cred-cancel-btn:hover:not(:disabled){background-color:var(--bg-primary);transform:translateY(-1px)}.delete-cred-confirm-btn{background-color:#dc3545;border:1px solid #c82333;color:#fff}.delete-cred-confirm-btn:hover:not(:disabled){background-color:#c82333;box-shadow:0 4px 12px #dc354566;transform:translateY(-1px)}.delete-cred-cancel-btn:disabled,.delete-cred-confirm-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.delete-cred-confirm-btn:active:not(:disabled){transform:translateY(0)}.installation-actions-overlay{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:2000}.installation-actions-modal{animation:slideUp .3s ease;background:var(--bg-secondary);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.installation-actions-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;justify-content:space-between;padding:24px}.installation-actions-header h2{color:var(--text-color);font-size:1.5rem;margin:0}.installation-actions-header .close-button{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-color);cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;transition:all .2s ease;width:40px}.installation-actions-header .close-button:hover{background:var(--button-bg);transform:scale(1.1)}.installation-actions-content{padding:24px}.installation-actions-info{margin-bottom:32px;text-align:center}.installation-name{color:var(--text-color);font-size:1.2rem;margin-bottom:8px}.device-count-info{color:#888;color:var(--text-muted,#888);font-size:.95rem}.installation-actions-buttons{display:flex;flex-direction:column;gap:16px}.lockdown-action-button{align-items:center;background:var(--button-bg);border:2px solid var(--border-color);border-radius:8px;color:var(--text-color);cursor:pointer;display:flex;font-size:1.1rem;font-weight:500;gap:16px;padding:20px 24px;transition:all .2s ease}.lockdown-action-button:hover:not(:disabled){box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.lockdown-action-button.lockdown{border-color:#f44}.lockdown-action-button.lockdown:hover:not(:disabled){background:#f44;border-color:#f44;color:#fff}.lockdown-action-button.release{border-color:#4a4}.lockdown-action-button.release:hover:not(:disabled){background:#4a4;border-color:#4a4;color:#fff}.lockdown-action-button.firmware{border-color:#48f}.lockdown-action-button.firmware:hover:not(:disabled){background:#48f;border-color:#48f;color:#fff}.lockdown-action-button:disabled{cursor:not-allowed;opacity:.5}.lockdown-action-button .action-icon{font-size:1.8rem;min-width:32px;text-align:center}.lockdown-action-button .action-text{flex:1 1;text-align:left}.no-devices-warning{color:#f80;font-style:italic;margin-top:16px;text-align:center}.confirmation-dialog{text-align:center}.confirmation-icon{font-size:12rem;margin-bottom:16px}.confirmation-dialog h3{color:var(--text-color);font-size:1.3rem;margin-bottom:16px}.confirmation-message{color:var(--text-color);font-size:1.05rem;line-height:1.6;margin-bottom:12px}.confirmation-note{color:#888;color:var(--text-muted,#888);font-size:.95rem;font-style:italic;line-height:1.5;margin-bottom:24px}.confirmation-buttons{display:flex;gap:12px;justify-content:center}.confirm-button{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 32px;transition:all .2s ease}.confirm-button.cancel{background:var(--button-bg);color:var(--text-color)}.confirm-button.cancel:hover:not(:disabled){background:var(--border-color)}.confirm-button.execute{color:#fff}.confirm-button.execute.lockdown{background:#f44}.confirm-button.execute.lockdown:hover:not(:disabled){background:#c00}.confirm-button.execute.release{background:#4a4}.confirm-button.execute.release:hover:not(:disabled){background:#383}.confirm-button.execute:not(.lockdown):not(.release){background:#48f}.confirm-button.execute:not(.lockdown):not(.release):hover:not(:disabled){background:#36c}.confirm-button:disabled{opacity:.6}.device-selection-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin:20px 0;overflow:hidden}.device-selection-header{align-items:center;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:12px 16px}.device-selection-controls{display:flex;gap:8px}.device-select-button{background:var(--button-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);cursor:pointer;font-size:.85rem;font-weight:500;padding:6px 14px;transition:all .2s ease}.device-select-button:hover:not(:disabled){background:var(--border-color);transform:translateY(-1px)}.device-select-button:disabled{cursor:not-allowed;opacity:.5}.device-selection-count{color:var(--text-color);font-size:.9rem}.device-selection-count strong{color:var(--accent-color);font-weight:600}.device-list-scroll{max-height:300px;overflow-y:auto;padding:8px}.device-list-scroll::-webkit-scrollbar{width:8px}.device-list-scroll::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.device-list-scroll::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.device-list-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.device-item{padding:4px 0}.device-item-label{align-items:flex-start;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:10px 12px;transition:background .2s ease}.device-item-label:hover{background:var(--bg-tertiary)}.device-item-checkbox{accent-color:var(--accent-color);cursor:pointer;flex-shrink:0;height:18px;margin-top:2px;width:18px}.device-item-checkbox:disabled{cursor:not-allowed}.device-item-info{flex:1 1;min-width:0}.device-name{word-wrap:break-word;color:var(--text-color);font-size:.95rem;font-weight:500;margin-bottom:4px}.device-id{word-wrap:break-word;color:#888;color:var(--text-muted,#888);font-family:monospace;font-size:.8rem}.device-item--unsupported .device-item-label{cursor:default;opacity:.5}.device-item--unsupported .device-item-label:hover{background:#0000}.device-unsupported-note{font-size:.75rem;margin-top:3px}.device-unsupported-note,.lockdown-disclaimer{color:#888;color:var(--text-muted,#888);font-style:italic}.lockdown-disclaimer{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;font-size:.85rem;line-height:1.5;margin:0 0 20px;padding:10px 12px;text-align:center}.confirmation-icon .hourglass-flip{animation:spin 2s linear infinite;display:inline-block;font-size:inherit!important}@media (max-width:600px){.installation-actions-modal{width:95%}.lockdown-action-button{flex-direction:column;gap:12px;text-align:center}.lockdown-action-button .action-text{text-align:center}.confirmation-buttons{flex-direction:column}.confirm-button{width:100%}.device-selection-header{align-items:stretch;flex-direction:column}.device-selection-controls{width:100%}.device-select-button{flex:1 1}.device-selection-count{text-align:center}.device-list-scroll{max-height:250px}}.installation-management-modal-overlay{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:2000}.installation-management-modal{animation:slideUp .3s ease;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 10px 40px #0000004d;color:var(--text-primary);max-height:90vh;max-width:1800px;overflow-y:auto;padding:0;width:98%}.installation-management-modal .modal-header{align-items:center;background:var(--bg-tertiary);border-bottom:2px solid var(--border-color);display:flex;justify-content:center;padding:20px 40px;position:relative}.installation-management-modal h2{color:var(--text-primary);font-size:36px;font-weight:600;margin:0;text-align:center}.installation-management-modal .modal-body{padding:30px 40px}.installation-management-modal h3{color:var(--text-primary);font-size:27px;font-weight:600;margin-bottom:24px;margin-top:0}.installation-management-modal .modal-body{margin-bottom:24px}.installation-management-modal .message-banner{border-radius:6px;font-size:21px;font-weight:500;line-height:1.5;margin-bottom:24px;padding:18px 24px}.installation-management-modal .message-banner.success{background-color:var(--bg-tertiary);border:2px solid var(--status-success);color:var(--status-success)}.installation-management-modal .message-banner.error{background-color:var(--bg-tertiary);border:2px solid var(--status-error);color:var(--status-error)}.installation-management-modal .message-banner.info{background-color:var(--bg-tertiary);border:2px solid var(--accent-color);color:var(--accent-color)}.installation-management-modal .deleting-current-installation-message{align-items:center;background-color:var(--bg-tertiary);border:2px solid var(--accent-color);border-radius:8px;display:flex;flex-direction:column;gap:16px;margin-bottom:20px;margin-left:auto;margin-right:auto;max-width:450px;padding:30px 40px;text-align:center}.installation-management-modal .deleting-current-installation-message .loading-spinner{animation:spin 1s linear infinite;border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-color);height:40px;width:40px}.installation-management-modal .deleting-current-installation-message p{color:var(--text-primary);font-size:16px;font-weight:600;line-height:1.4;margin:0}.installation-management-modal .installation-form{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:24px;padding:30px}.installation-management-modal .installation-form h3{text-align:center;width:100%}.installation-management-modal .form-group{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:24px}.installation-management-modal .form-group label{color:var(--text-primary);flex-shrink:0;font-size:21px;font-weight:600;margin-bottom:0;text-align:right;width:200px}.installation-management-modal .form-group input,.installation-management-modal .form-group select{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;box-sizing:border-box;color:var(--text-primary);font-size:21px;padding:12px 18px;transition:border-color .2s ease,box-shadow .2s ease;width:33%}.installation-management-modal .form-group input:focus,.installation-management-modal .form-group select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #61dafb1a;outline:none}.installation-management-modal .form-group input:disabled,.installation-management-modal .form-group select:disabled{background-color:var(--bg-button-disabled);cursor:not-allowed;opacity:.6}.installation-management-modal .form-buttons{display:flex;gap:18px;justify-content:center;margin-top:30px}.installation-management-modal .btn-cancel,.installation-management-modal .btn-submit{border:none;border-radius:6px;cursor:pointer;font-size:21px;font-weight:600;padding:15px 36px;transition:all .2s ease}.installation-management-modal .btn-submit{background-color:var(--accent-color);color:var(--text-on-accent)}.installation-management-modal .btn-submit:hover:not(:disabled){background-color:var(--accent-color-hover);transform:translateY(-2px)}.installation-management-modal .btn-cancel{background-color:var(--bg-tertiary);border:2px solid var(--border-color);color:var(--text-primary)}.installation-management-modal .btn-cancel:hover:not(:disabled){background-color:var(--bg-input)}.installation-management-modal .btn-cancel:disabled,.installation-management-modal .btn-submit:disabled{cursor:not-allowed;opacity:.5}.installation-management-modal .installations-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.installation-management-modal .search-container{margin-bottom:20px;position:relative}.installation-management-modal .search-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;padding:12px 40px 12px 12px;transition:border-color .2s ease;width:100%}.installation-management-modal .search-input:focus{border-color:var(--accent-color);outline:none}.installation-management-modal .search-input::placeholder{color:var(--text-muted)}.installation-management-modal .search-clear-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:24px;line-height:1;padding:4px 8px;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:color .2s ease}.installation-management-modal .search-clear-button:hover{color:var(--text-primary)}.installation-management-modal .btn-create{background-color:var(--accent-color);border:none;border-radius:6px;color:var(--text-on-accent);cursor:pointer;font-size:21px;font-weight:600;padding:15px 30px;transition:all .2s ease}.installation-management-modal .btn-create:hover:not(:disabled){background-color:var(--accent-color-hover);transform:translateY(-2px)}.installation-management-modal .btn-create:disabled{cursor:not-allowed;opacity:.5}.installation-management-modal .empty-state{color:var(--text-muted);font-size:21px;padding:60px 30px;text-align:center}.installation-management-modal .installations-table-container{margin-bottom:24px;overflow-x:auto}.installation-management-modal .installations-table{border-collapse:collapse;font-size:21px;table-layout:fixed;width:100%}.installation-management-modal .installations-table thead{background-color:var(--bg-tertiary)}.installation-management-modal .installations-table th{border-bottom:3px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:18px 12px;text-align:center;white-space:nowrap}.installation-management-modal .installations-table th:first-child{width:300px}.installation-management-modal .installations-table th:nth-child(2){width:350px}.installation-management-modal .installations-table th:nth-child(3){width:160px}.installation-management-modal .installations-table th:nth-child(4){width:100px}.installation-management-modal .installations-table th:nth-child(5){width:140px}.installation-management-modal .installations-table th:nth-child(6){width:300px}.installation-management-modal .installations-table td{word-wrap:break-word;border-bottom:3px solid var(--border-color);color:var(--text-primary);padding:18px 12px;vertical-align:middle}.installation-management-modal .installations-table tbody tr{cursor:pointer;transition:background-color .2s ease}.installation-management-modal .installations-table tbody tr:hover{background-color:var(--hover-bg)}.installation-management-modal .installations-table tr.current-installation{background-color:#ffffff0d;border-left:6px solid var(--accent-color)}.installation-management-modal .installations-table tr.current-installation:hover{background-color:var(--bg-tertiary)}.installation-management-modal .installation-name-container{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.installation-management-modal .installation-badges-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:15px}.installation-management-modal .installation-name-link{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:16px;font-weight:600;padding:0;text-align:left;text-decoration:underline;transition:color .2s ease}.installation-management-modal .installation-name-link:hover{color:var(--accent-color-hover)}.installation-management-modal .installation-name-link:disabled{color:var(--text-primary);cursor:default;opacity:1;text-decoration:none}.installation-management-modal .current-badge{background-color:var(--accent-color);color:var(--text-on-accent)}.installation-management-modal .current-badge,.installation-management-modal .subscription-badge{border-radius:12px;display:inline-block;font-size:14px;font-weight:600;margin:0;padding:3px 12px;vertical-align:middle}.installation-management-modal .subscription-badge.subscribed{background-color:#2196f326;border:1px solid #2196f3;color:#2196f3}.installation-management-modal .subscription-badge.not-subscribed{background-color:#9e9e9e26;border:1px solid #9e9e9e;color:#9e9e9e}.installation-management-modal .installation-id{color:var(--text-muted);font-family:Courier New,monospace;font-size:18px}.installation-management-modal .installation-id-container{align-items:center;display:flex;gap:8px}.installation-management-modal .installation-id-text{flex:1 1;word-break:break-all}.installation-management-modal .btn-copy-installation-id{background:none;border:none;cursor:pointer;flex-shrink:0;font-size:20px;opacity:.7;padding:4px;transition:transform .2s ease}.installation-management-modal .btn-copy-installation-id:hover:not(:disabled){opacity:1;transform:scale(1.2)}.installation-management-modal .btn-copy-installation-id:disabled{cursor:not-allowed;opacity:.3}.installation-management-modal .actions-cell{padding:18px 12px!important;text-align:left;vertical-align:top}.installation-management-modal .actions-container{align-items:flex-start;display:flex;flex-direction:column;width:100%}.installation-management-modal .action-buttons-wrapper{align-items:center;display:flex;gap:8px;margin-bottom:0;min-width:198px;width:198px}.installation-management-modal .btn-delete,.installation-management-modal .btn-edit{align-items:center;border:none;border-radius:6px;box-sizing:border-box;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:19px;font-weight:600;height:44px;justify-content:center;max-width:95px;min-width:95px;padding:9px 18px;transition:all .2s ease;width:95px}.installation-management-modal .btn-edit{background-color:#ffc107;color:#333}.installation-management-modal .btn-edit:hover:not(:disabled){background-color:#e0a800;transform:translateY(-2px)}.installation-management-modal .btn-delete{background-color:var(--status-error);color:#fff}.installation-management-modal .btn-delete:hover:not(:disabled){background-color:#c62828;transform:translateY(-2px)}.installation-management-modal .btn-delete:disabled,.installation-management-modal .btn-edit:disabled{background-color:#666!important;color:#999!important;cursor:not-allowed;opacity:1;pointer-events:none}.installation-management-modal .delete-disabled-note{color:var(--text-muted);display:block;font-size:16px;font-style:italic;line-height:1.3;margin-top:8px;text-align:left;white-space:nowrap}.installation-management-modal .modal-actions{border-top:2px solid var(--border-color);display:flex;gap:18px;justify-content:flex-end;margin-top:30px;padding-bottom:30px;padding-right:40px;padding-top:24px}.installation-management-modal .modal-actions button{border:none;border-radius:6px;cursor:pointer;font-size:21px;font-weight:600;padding:15px 36px;transition:all .2s ease}.installation-management-modal .modal-actions .cancel-button{background-color:var(--bg-tertiary);border:2px solid var(--border-color);color:var(--text-primary)}.installation-management-modal .modal-actions .cancel-button:hover:not(:disabled){background-color:var(--bg-input)}.installation-management-modal .modal-actions button:disabled{cursor:not-allowed;opacity:.5}@media (max-width:1200px){.installation-management-modal{max-width:95%}.installation-management-modal .installations-table{font-size:18px}.installation-management-modal .btn-delete,.installation-management-modal .btn-edit{font-size:16px;padding:6px 12px}}@media (max-width:768px){.installation-management-modal{margin:10px;max-width:none;padding:20px 24px;width:100%}.installation-management-modal h2{font-size:27px}.installation-management-modal h3{font-size:21px}.installation-management-modal .installations-table{font-size:16px}.installation-management-modal .installations-table td,.installation-management-modal .installations-table th{padding:12px 6px}.installation-management-modal .btn-delete,.installation-management-modal .btn-edit{font-size:14px;margin-right:4px;padding:6px 12px}.installation-management-modal .installations-header{align-items:flex-start;flex-direction:column;gap:12px}.installation-management-modal .modal-actions{flex-direction:column}.installation-management-modal .modal-actions button{width:100%}}.switch-installation-overlay{align-items:center;animation:fadeIn .2s ease;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2100}.switch-installation-modal{animation:slideUp .3s ease;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 10px 40px #0006;color:var(--text-primary);max-width:500px;padding:24px 32px;width:90%}.switch-installation-header{border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:12px}.switch-installation-header h3{color:var(--text-primary);font-size:22px;font-weight:600;margin:0}.switch-installation-body{margin-bottom:24px}.switch-installation-body p{color:var(--text-primary);font-size:16px;line-height:1.5;margin:0 0 12px}.switch-installation-body p:last-child{font-weight:500;margin-bottom:0}.switch-installation-body strong{color:var(--accent-color);font-weight:600}.switch-installation-actions{display:flex;gap:12px;justify-content:flex-end}.switch-installation-actions .cancel-button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:15px;font-weight:500;padding:10px 20px;transition:all .2s ease}.switch-installation-actions .cancel-button:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}@media (max-width:768px){.switch-installation-modal{padding:20px 24px;width:95%}.switch-installation-actions{flex-direction:column}.switch-installation-actions button{width:100%}}.delete-confirmation-overlay{align-items:center;animation:fadeIn .2s ease;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2100}.delete-confirmation-modal{animation:slideUp .3s ease;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 10px 40px #0006;color:var(--text-primary);max-width:500px;padding:24px 32px;width:90%}.delete-confirmation-header{border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:12px}.delete-confirmation-header h3{color:var(--text-primary);font-size:22px;font-weight:600;margin:0}.delete-confirmation-body{margin-bottom:24px}.delete-confirmation-body p{color:var(--text-primary);font-size:16px;line-height:1.5;margin:0 0 12px}.delete-confirmation-body strong{color:var(--text-primary);font-weight:600}.delete-warning{background-color:#ff980026;border:1px solid #ff980066;border-radius:6px;color:var(--text-primary);font-size:15px;line-height:1.4;margin:12px 0}.delete-note{color:var(--text-secondary);font-size:14px;font-style:italic;margin-top:12px}.delete-confirmation-actions{display:flex;gap:12px;justify-content:flex-end}.delete-confirmation-actions .cancel-button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:15px;font-weight:500;padding:10px 20px;transition:all .2s ease}.delete-confirmation-actions .cancel-button:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.delete-confirm-button{background:#d32f2f;border:1px solid #b71c1c;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;padding:10px 20px;transition:all .2s ease}.delete-confirm-button:hover:not(:disabled){background:#c62828;transform:translateY(-1px)}.delete-confirm-button:disabled{background:#555;border-color:#444;cursor:not-allowed;opacity:.5}.creation-modal-overlay{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:3000}.creation-modal-content{animation:slideUp .3s ease;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:500px;min-width:400px;padding:40px;text-align:center}.creation-spinner{animation:spin .8s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-color);height:60px;margin:0 auto 20px;width:60px}.creation-message{color:var(--text-primary);font-size:16px;line-height:1.5;margin:20px 0}.creation-icon{align-items:center;border-radius:50%;display:flex;font-size:36px;font-weight:700;height:60px;justify-content:center;margin:0 auto 20px;width:60px}.creation-icon.success{background-color:#4caf5033;border:3px solid #4caf50;color:#4caf50}.creation-icon.error{background-color:#f4433633;border:3px solid #f44336;color:#f44336}.creation-message.success{color:#4caf50}.creation-message.error{color:#f44336}.creation-close-button{background-color:var(--accent-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:12px 32px;transition:all .2s ease}.creation-close-button:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.creation-close-button:active{transform:translateY(0)}.deletion-modal-overlay{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:3000}.deletion-modal-content{animation:slideUp .3s ease;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:500px;min-width:400px;padding:40px;text-align:center}.deletion-spinner{animation:spin .8s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-color);height:60px;margin:0 auto 20px;width:60px}.deletion-message{color:var(--text-primary);font-size:16px;line-height:1.5;margin:20px 0}.deletion-submessage{color:var(--text-secondary)}.deletion-icon{align-items:center;border-radius:50%;display:flex;font-size:36px;font-weight:700;height:60px;justify-content:center;margin:0 auto 20px;width:60px}.deletion-icon.success{background-color:#4caf5033;border:3px solid #4caf50;color:#4caf50}.deletion-icon.error{background-color:#f4433633;border:3px solid #f44336;color:#f44336}.deletion-message.success{color:#4caf50}.deletion-message.error{color:#f44336}.deletion-close-button{background-color:var(--accent-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:12px 32px;transition:all .2s ease}.deletion-close-button:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.deletion-close-button:active{transform:translateY(0)}@media (max-width:768px){.delete-confirmation-modal{padding:20px 24px;width:95%}.delete-confirmation-actions{flex-direction:column}.delete-confirmation-actions button{width:100%}.creation-modal-content,.deletion-modal-content{max-width:90%;min-width:90%;padding:30px 20px}}.organization-management-modal-overlay{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:2000}.organization-management-modal{animation:slideUp .3s ease;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 10px 40px #0000004d;color:var(--text-primary);max-height:90vh;max-width:1800px;overflow-y:auto;padding:0;width:98%}.organization-management-modal .modal-header{align-items:center;background:var(--bg-tertiary);border-bottom:2px solid var(--border-color);display:flex;justify-content:center;padding:20px 40px;position:relative}.organization-management-modal h2{color:var(--text-primary);font-size:36px;font-weight:600;margin:0;text-align:center}.organization-management-modal .modal-body{padding:30px 40px}.close-x-button{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;line-height:1;padding:0;position:absolute;right:20px;top:50%;transform:translateY(-50%);transition:color .2s ease;width:32px}.close-x-button:hover:not(:disabled){color:var(--text-primary)}.close-x-button:disabled{cursor:not-allowed;opacity:.5}.organization-management-modal h3{color:var(--text-primary);font-size:27px;font-weight:600;margin-bottom:24px;margin-top:0}.organization-management-modal .modal-body{margin-bottom:24px}.organization-management-modal .message-banner{border-radius:6px;font-size:21px;font-weight:500;line-height:1.5;margin-bottom:24px;padding:18px 24px}.organization-management-modal .message-banner.success{background-color:var(--bg-tertiary);border:2px solid var(--status-success);color:var(--status-success)}.organization-management-modal .message-banner.error{background-color:var(--bg-tertiary);border:2px solid var(--status-error);color:var(--status-error)}.organization-management-modal .message-banner.info{align-items:center;background-color:var(--bg-tertiary);border:2px solid var(--accent-color);color:var(--accent-color);display:flex;gap:12px;justify-content:center}.organization-management-modal .deleting-current-organization-message{align-items:center;background-color:var(--bg-tertiary);border:2px solid var(--accent-color);border-radius:8px;display:flex;flex-direction:column;gap:16px;margin-bottom:20px;margin-left:auto;margin-right:auto;max-width:450px;padding:30px 40px;text-align:center}.organization-management-modal .deleting-current-organization-message .loading-spinner{animation:spin 1s linear infinite;border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-color);height:40px;width:40px}.organization-management-modal .deleting-current-organization-message p{color:var(--text-primary);font-size:16px;font-weight:600;line-height:1.4;margin:0}.organization-management-modal .organization-form{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:24px;padding:30px}.organization-management-modal .organization-form h3{text-align:center;width:100%}.organization-management-modal .form-group{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:12px}.organization-management-modal .form-group label{color:var(--text-primary);flex-shrink:0;font-size:21px;font-weight:600;margin-bottom:0;text-align:right;width:200px}.organization-management-modal .form-group input{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;box-sizing:border-box;color:var(--text-primary);font-size:21px;padding:12px 18px;transition:border-color .2s ease,box-shadow .2s ease;width:33%}.organization-management-modal .form-group input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #61dafb1a;outline:none}.organization-management-modal .form-group input:disabled{background-color:var(--bg-button-disabled);cursor:not-allowed;opacity:.6}.organization-management-modal .character-counter{color:var(--text-muted);font-size:16px;font-style:italic;margin-bottom:12px;text-align:center}.organization-management-modal .organization-settings-section{align-items:center;background-color:#ffffff05;border:1px solid #ffffff1a;border-radius:12px;display:flex;flex-direction:column;margin:30px auto;max-width:800px;padding:36px;width:50%}.organization-management-modal .settings-section-title{border-bottom:1px solid #ffffff1a;color:var(--text-primary);font-size:28px;font-weight:600;margin:0 0 30px;padding-bottom:18px;text-align:center;width:100%}.organization-management-modal .org-setting-item{grid-gap:36px;align-items:center;background-color:#ffffff03;border-radius:8px;display:grid;gap:36px;grid-template-columns:1fr auto;margin-bottom:18px;padding:24px;width:100%}.organization-management-modal .org-setting-item:last-child{margin-bottom:0}.organization-management-modal .org-setting-info{display:flex;flex-direction:column;gap:8px}.organization-management-modal .org-setting-info h3{color:var(--text-primary);font-size:24px;font-weight:600;margin:0}.organization-management-modal .org-setting-info p{color:var(--text-secondary);font-size:18px;line-height:1.5;margin:0}.organization-management-modal .org-setting-control{align-items:center;display:flex;justify-content:flex-start}.organization-management-modal .org-setting-control .modal-toggle-slider{border-radius:45px;height:45px;width:90px}.organization-management-modal .org-setting-control .modal-toggle-slider:before{bottom:4.5px;height:36px;left:4.5px;width:36px}.organization-management-modal .org-setting-control .modal-toggle-checkbox:checked+.modal-toggle-slider:before{transform:translateX(45px)}.organization-management-modal .form-buttons{display:flex;gap:18px;justify-content:center;margin-top:30px}.organization-management-modal .btn-cancel,.organization-management-modal .btn-submit{border:none;border-radius:6px;cursor:pointer;font-size:21px;font-weight:600;padding:15px 36px;transition:all .2s ease}.organization-management-modal .btn-submit{background-color:var(--accent-color);color:var(--text-on-accent)}.organization-management-modal .btn-submit:hover:not(:disabled){background-color:var(--accent-color-hover);transform:translateY(-2px)}.organization-management-modal .btn-cancel{background-color:var(--bg-tertiary);border:2px solid var(--border-color);color:var(--text-primary)}.organization-management-modal .btn-cancel:hover:not(:disabled){background-color:var(--bg-input)}.organization-management-modal .btn-cancel:disabled,.organization-management-modal .btn-submit:disabled{cursor:not-allowed;opacity:.5}.organization-management-modal .organizations-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.organization-management-modal .search-container{margin-bottom:20px;position:relative}.organization-management-modal .search-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;padding:12px 40px 12px 12px;transition:border-color .2s ease;width:100%}.organization-management-modal .search-input:focus{border-color:var(--accent-color);outline:none}.organization-management-modal .search-input::placeholder{color:var(--text-muted)}.organization-management-modal .search-clear-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:24px;line-height:1;padding:4px 8px;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:color .2s ease}.organization-management-modal .search-clear-button:hover{color:var(--text-primary)}.organization-management-modal .btn-create{background-color:var(--accent-color);border:none;border-radius:6px;color:var(--text-on-accent);cursor:pointer;font-size:21px;font-weight:600;padding:15px 30px;transition:all .2s ease}.organization-management-modal .btn-create:hover:not(:disabled){background-color:var(--accent-color-hover);transform:translateY(-2px)}.organization-management-modal .btn-create:disabled{cursor:not-allowed;opacity:.5}.organization-management-modal .empty-state{color:var(--text-muted);font-size:21px;padding:60px 30px;text-align:center}.organization-management-modal .organizations-table-container{margin-bottom:24px;overflow-x:auto}.organization-management-modal .organizations-table{border-collapse:collapse;font-size:21px;table-layout:fixed;width:100%}.organization-management-modal .organizations-table thead{background-color:var(--bg-tertiary)}.organization-management-modal .organizations-table th{border-bottom:3px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:18px 12px;text-align:center;white-space:nowrap}.organization-management-modal .organizations-table th:first-child{width:220px}.organization-management-modal .organizations-table th:nth-child(2){width:60px}.organization-management-modal .organizations-table th:nth-child(3){width:320px}.organization-management-modal .organizations-table th:nth-child(4){width:100px}.organization-management-modal .organizations-table th:nth-child(5){width:140px}.organization-management-modal .organizations-table th:nth-child(6){width:270px}.organization-management-modal .organizations-table td{word-wrap:break-word;border-bottom:none;color:var(--text-primary);padding:18px 12px;position:relative;vertical-align:middle}.organization-management-modal .organizations-table tbody tr{border-bottom:3px solid var(--border-color);cursor:pointer;transition:background-color .2s ease}.organization-management-modal .organizations-table tbody tr:hover{background-color:var(--hover-bg)}.organization-management-modal .organizations-table tr.current-organization{background-color:#ffffff0d;border-left:6px solid var(--accent-color)}.organization-management-modal .organizations-table tr.current-organization:hover{background-color:var(--bg-tertiary)}.organization-management-modal .org-name-container{display:flex;flex-direction:column;gap:8px}.organization-management-modal .org-name-link{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:20px;font-weight:700;padding:0;text-align:left;text-decoration:underline;transition:color .2s ease}.organization-management-modal .org-name-link:hover{color:var(--accent-color-hover)}.organization-management-modal .org-name-link:disabled{cursor:not-allowed;opacity:.6}.organization-management-modal .users-column{text-align:center;vertical-align:middle}.organization-management-modal .btn-view-org-users{align-items:center;background:none;border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:36px;justify-content:center;padding:6px 10px;transition:all .2s ease}.organization-management-modal .btn-view-org-users:hover:not(:disabled){background-color:var(--input-bg);border-color:var(--accent-color);transform:scale(1.05)}.organization-management-modal .btn-view-org-users:disabled{cursor:not-allowed;opacity:.5}.organization-management-modal .manage-installations-link{transition:transform .2s ease,opacity .2s ease;vertical-align:middle}.organization-management-modal .manage-installations-link:disabled{opacity:.4;transform:none}.organization-management-modal .organization-id{color:var(--text-muted);font-family:Courier New,monospace;font-size:18px;word-break:break-all}.organization-management-modal .org-id-container{align-items:center;display:flex;gap:8px}.organization-management-modal .org-id-text{flex:1 1;min-width:0}.organization-management-modal .btn-copy-org-id{align-items:center;background:none;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:18px;height:28px;justify-content:center;min-width:32px;padding:4px 8px;transition:all .2s ease}.organization-management-modal .btn-copy-org-id:hover:not(:disabled){background-color:var(--input-bg);border-color:var(--accent-color);color:var(--accent-color);transform:scale(1.05)}.organization-management-modal .btn-copy-org-id:disabled{cursor:not-allowed;opacity:.5}.organization-management-modal .actions-cell{padding:15px 12px!important;text-align:left;vertical-align:top}.organization-management-modal .actions-container{align-items:flex-start;display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;width:100%}.organization-management-modal .action-buttons-wrapper{align-items:center;display:flex;flex-direction:row;flex-wrap:nowrap;gap:8px;margin-bottom:0}.organization-management-modal .button-wrapper-with-tooltip{cursor:not-allowed;display:inline-flex}.organization-management-modal .button-wrapper-with-tooltip button:disabled{pointer-events:none}.organization-management-modal .btn-authorize,.organization-management-modal .btn-delete,.organization-management-modal .btn-edit{max-width:116px;min-width:116px;width:116px}.organization-management-modal .btn-authorize,.organization-management-modal .btn-delete,.organization-management-modal .btn-edit,.organization-management-modal .btn-unauthorize{align-items:center;border:none;border-radius:6px;box-sizing:border-box;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:19px;font-weight:600;height:44px;justify-content:center;padding:9px 18px;transition:all .2s ease}.organization-management-modal .btn-unauthorize{max-width:122px;min-width:122px;width:122px}.organization-management-modal .btn-edit{background-color:#ffc107;color:#333}.organization-management-modal .btn-edit:hover:not(:disabled){background-color:#e0a800;transform:translateY(-2px)}.organization-management-modal .btn-authorize{background-color:#4caf50;color:#fff}.organization-management-modal .btn-authorize:hover:not(:disabled){background-color:#45a049;transform:translateY(-2px)}.organization-management-modal .btn-unauthorize{background-color:#ff9800;color:#fff}.organization-management-modal .btn-unauthorize:hover:not(:disabled){background-color:#e68900;transform:translateY(-2px)}.organization-management-modal .btn-delete{background-color:var(--status-error);color:#fff}.organization-management-modal .btn-delete:hover:not(:disabled){background-color:#c62828;transform:translateY(-2px)}.organization-management-modal .btn-authorize:disabled,.organization-management-modal .btn-delete:disabled,.organization-management-modal .btn-edit:disabled,.organization-management-modal .btn-unauthorize:disabled{background-color:#666!important;color:#999!important;cursor:not-allowed;opacity:1;pointer-events:none}.organization-management-modal .delete-disabled-note{color:var(--text-muted);display:block;font-size:16px;font-style:italic;line-height:1.3;margin-top:8px;text-align:center;white-space:nowrap;width:100%}.organization-management-modal .modal-actions{border-top:2px solid var(--border-color);display:flex;gap:18px;justify-content:flex-end;margin-top:30px;padding-bottom:30px;padding-right:40px;padding-top:24px}.organization-management-modal .modal-actions button{border:none;border-radius:6px;cursor:pointer;font-size:21px;font-weight:600;padding:15px 36px;transition:all .2s ease}.organization-management-modal .modal-actions .cancel-button{background-color:var(--bg-tertiary);border:2px solid var(--border-color);color:var(--text-primary)}.organization-management-modal .modal-actions .cancel-button:hover:not(:disabled){background-color:var(--bg-input)}.organization-management-modal .modal-actions button:disabled{cursor:not-allowed;opacity:.5}@media (max-width:1200px){.organization-management-modal{max-width:95%}.organization-management-modal .organizations-table{font-size:18px}.organization-management-modal .btn-delete,.organization-management-modal .btn-edit{font-size:16px;padding:6px 12px}}@media (max-width:768px){.organization-management-modal{margin:10px;max-width:none;padding:20px 24px;width:100%}.organization-management-modal h2{font-size:27px}.organization-management-modal h3{font-size:21px}.organization-management-modal .organizations-table{font-size:16px}.organization-management-modal .organizations-table td,.organization-management-modal .organizations-table th{padding:12px 6px}.organization-management-modal .btn-delete,.organization-management-modal .btn-edit{font-size:14px;margin-right:4px;padding:6px 12px}.organization-management-modal .organizations-header{align-items:flex-start;flex-direction:column;gap:12px}.organization-management-modal .modal-actions{flex-direction:column}.organization-management-modal .modal-actions button{width:100%}}.switch-organization-overlay{align-items:center;animation:fadeIn .2s ease;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2100}.switch-organization-modal{animation:slideUp .3s ease;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 10px 40px #0006;color:var(--text-primary);max-width:500px;padding:24px 32px;width:90%}.switch-organization-header{border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:12px}.switch-organization-header h3{color:var(--text-primary);font-size:22px;font-weight:600;margin:0}.switch-organization-body{margin-bottom:24px}.switch-organization-body p{color:var(--text-primary);font-size:16px;line-height:1.5;margin:0 0 12px}.switch-organization-body p:last-child{font-weight:500;margin-bottom:0}.switch-organization-body strong{color:var(--accent-color);font-weight:600}.switch-organization-actions{display:flex;gap:12px;justify-content:flex-end}.switch-organization-actions .cancel-button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:15px;font-weight:500;padding:10px 20px;transition:all .2s ease}.switch-organization-actions .cancel-button:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.switch-confirm-button{background:var(--accent-color);border:1px solid var(--accent-color);border-radius:6px;color:var(--text-on-accent);cursor:pointer;font-size:15px;font-weight:500;padding:10px 20px;transition:all .2s ease}.switch-confirm-button:hover:not(:disabled){background:var(--accent-color-hover);transform:translateY(-1px)}.switch-confirm-button:disabled{background:#555;border-color:#444;cursor:not-allowed;opacity:.5}@media (max-width:768px){.switch-organization-modal{padding:20px 24px;width:95%}.switch-organization-actions{flex-direction:column}.switch-organization-actions button{width:100%}}.organization-management-modal .manage-installations-link{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:1.2em;padding:0 4px;transition:all .2s ease}.organization-management-modal .manage-installations-link:hover{opacity:.8;transform:scale(1.2)}.organization-management-modal .manage-installations-link:disabled{cursor:not-allowed;opacity:.5}.self-revoke-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1200}.self-revoke-modal{background-color:var(--bg-secondary);border:2px solid #dc3545;border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);box-sizing:border-box;color:var(--text-primary);max-width:500px;padding:24px;width:90%}.self-revoke-modal-header{border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:12px}.self-revoke-modal-header h3{color:#dc3545;font-size:18px;font-weight:600;margin:0}.self-revoke-modal-content{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.warning-text{color:var(--text-primary);font-size:15px;line-height:1.5;margin:0}.warning-text strong{color:#dc3545;font-weight:600}.redirect-warning{background-color:#dc35451a;border-left:4px solid #dc3545;border-radius:4px;padding:12px}.redirect-warning p{color:var(--text-primary);font-size:14px;line-height:1.5;margin:0}.redirect-warning p:first-child{font-weight:600;margin-bottom:8px}.confirm-text{color:var(--text-primary);font-size:15px;font-weight:500;margin:0}.self-revoke-modal-actions{display:flex;gap:12px;justify-content:flex-end}.cancel-button,.confirm-revoke-button{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.cancel-button{background-color:var(--bg-input)}.cancel-button:hover:not(:disabled){border-color:var(--text-secondary)}.confirm-revoke-button{background-color:#dc3545;border:1px solid #c82333;color:#fff}.confirm-revoke-button:hover:not(:disabled){background-color:#c82333;border-color:#bd2130;box-shadow:0 2px 4px #dc35454d}.confirm-revoke-button:disabled{cursor:not-allowed;opacity:.6}.email-confirmation-section{border-top:1px solid #495057;margin-top:20px;padding-top:15px}.email-confirmation-input{background-color:#2d3238;border:2px solid #495057;border-radius:4px;box-sizing:border-box;color:#e0e0e0;font-size:14px;margin-top:10px;padding:10px;transition:border-color .2s;width:100%}.email-confirmation-input:focus{border-color:#6c757d;outline:none}.email-confirmation-input.error{border-color:#dc3545}.email-confirmation-input:disabled{cursor:not-allowed;opacity:.6}.email-error-text{color:#dc3545;font-size:13px;margin-bottom:0;margin-top:5px}@media (prefers-color-scheme:dark){.redirect-warning{background-color:#dc354526}}.user-selector-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1300}.user-selector-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);color:var(--text-primary);display:flex;flex-direction:column;max-height:70vh;max-width:600px;padding:24px;width:90%}.user-selector-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.user-selector-header h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.user-selector-header .close-btn{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:background-color .2s,color .2s;width:30px}.user-selector-header .close-btn:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.user-selector-header .close-btn:disabled{cursor:not-allowed;opacity:.5}.user-selector-message{border-radius:4px;font-size:14px;margin-bottom:16px;padding:12px}.user-selector-message.success{background-color:#4caf501a;border:1px solid #4caf50;color:#4caf50}.user-selector-message.error{background-color:#f443361a;border:1px solid #f44336;color:#f44336}.user-selector-message.info{background-color:#2196f31a;border:1px solid #2196f3;color:#2196f3}.user-selector-controls{display:flex;gap:12px;margin-bottom:16px}.user-selector-search{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);flex:1 1;font-size:14px;padding:10px 14px;transition:border-color .2s}.user-selector-search:focus{border-color:var(--accent-color);outline:none}.user-selector-role-filter{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;font-size:14px;min-width:180px;padding:10px 14px;transition:border-color .2s}.user-selector-role-filter:focus{border-color:var(--accent-color);outline:none}.user-selector-body{flex:1 1;margin-bottom:16px;min-height:200px;overflow-y:auto}.user-selector-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:12px;justify-content:center;padding:40px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-color);height:40px;width:40px}.user-selector-empty{color:var(--text-secondary);font-size:14px;padding:40px 20px;text-align:center}.user-selector-list{display:flex;flex-direction:column;gap:8px}.user-selector-item{align-items:center;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:12px 16px;position:relative;transition:all .2s}.user-selector-item:hover:not(.authorized){background-color:var(--bg-hover);border-color:var(--accent-color);transform:translateY(-1px)}.user-selector-item.authorized{background-color:var(--bg-input);cursor:not-allowed;opacity:.5}.user-selector-item-info{display:flex;flex:1 1;flex-direction:column;gap:4px;text-align:center}.user-selector-item-name{color:var(--text-primary);font-size:15px;font-weight:600}.user-selector-item-email{color:var(--text-secondary);font-size:13px}.user-selector-item-role{color:var(--text-muted);font-size:12px;font-style:italic}.user-selector-authorized-badge{background-color:#4caf5033;border-radius:12px;color:#4caf50;font-size:12px;font-weight:500;margin-left:auto;padding:4px 10px;position:absolute;right:16px;white-space:nowrap}.user-selector-pagination{align-items:center;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;padding-top:16px}.pagination-btn{background-color:var(--bg-button);border:1px solid var(--border-color);color:var(--text-primary);padding:8px 16px;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--accent-color)}.pagination-btn:disabled{opacity:.5}.user-selector-confirm{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:20px}.user-selector-confirm h4{color:var(--text-primary);font-size:18px;margin:0 0 16px}.user-selector-confirm p{color:var(--text-primary);font-size:14px;line-height:1.5;margin:0 0 12px}.user-selector-confirm-note{color:var(--text-secondary);font-size:13px;font-style:italic;margin-bottom:16px}.user-selector-error{background-color:#f443361a;border:1px solid #f44336;border-radius:4px;color:#f44336;font-size:13px;margin-bottom:16px;padding:12px}.user-selector-confirm-actions{display:flex;gap:12px;justify-content:flex-end}.user-selector-confirm-actions .cancel-btn{background-color:var(--bg-button);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;font-size:14px;padding:10px 20px;transition:all .2s}.user-selector-confirm-actions .cancel-btn:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--text-secondary)}.user-selector-confirm-actions .cancel-btn:disabled{cursor:not-allowed;opacity:.5}.user-selector-confirm-actions .confirm-btn{background-color:var(--accent-color);border:1px solid var(--accent-color);border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.user-selector-confirm-actions .confirm-btn:hover:not(:disabled){background-color:var(--accent-color-hover);box-shadow:0 2px 4px #0003}.user-selector-confirm-actions .confirm-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.user-selector-modal{max-height:80vh;padding:16px;width:95%}.user-selector-controls{flex-direction:column}.user-selector-role-filter{min-width:auto}.user-selector-pagination{flex-direction:column;gap:12px}.pagination-info{order:-1}}.modal-content.org-users-modal{background:var(--bg-secondary);display:flex;flex-direction:column;max-height:80vh;max-width:1050px!important}.org-users-search{box-sizing:border-box;margin-bottom:16px;padding:0 24px}.org-users-search .search-input{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;box-sizing:border-box;color:var(--text-primary);font-size:14px;padding:10px 14px;transition:border-color .2s;width:100%}.org-users-search .search-input::placeholder{color:var(--text-muted)}.org-users-authorize-section{display:flex;justify-content:center;margin-bottom:16px;padding:0 24px}.btn-authorize-users{background-color:#4a90e2;background-color:var(--primary-color,#4a90e2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background-color .2s,transform .1s}.btn-authorize-users:hover{background-color:#357abd;background-color:var(--primary-hover,#357abd);transform:translateY(-1px)}.btn-authorize-users:active{transform:translateY(0)}.org-users-search .search-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a;outline:none}.org-users-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;padding-right:8px}.org-user-item{align-items:center;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;display:flex;justify-content:center;padding:16px;position:relative;transition:all .2s}.org-user-item:hover{background-color:var(--hover-bg);border-color:var(--border-color-light);box-shadow:0 2px 4px var(--shadow-color)}.org-user-info{display:flex;flex-direction:column;gap:4px;text-align:center}.org-user-name{color:var(--text-primary);font-size:15px;font-weight:600}.org-user-email{color:var(--text-secondary);font-size:13px}.org-user-role{color:var(--accent-color);font-size:12px;font-weight:500;margin-top:4px}.btn-revoke-user{background-color:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;position:absolute;right:16px;top:50%;transform:translateY(-50%);transition:background-color .2s;white-space:nowrap}.btn-revoke-user:hover{background-color:#dc2626}.btn-revoke-user:active{background-color:#b91c1c}.btn-revoke-user:disabled{background-color:#9ca3af;cursor:not-allowed}.empty-state,.loading-state{color:var(--text-secondary);font-size:14px;padding:40px;text-align:center}.empty-state{background-color:var(--bg-tertiary);border:1px dashed var(--border-color);border-radius:8px}.confirm-modal{background:var(--bg-secondary);max-width:500px}.confirm-modal .modal-body{padding:24px}.confirm-modal .modal-body p{color:var(--text-primary);line-height:1.5;margin-bottom:16px}.warning-text{color:var(--status-error);margin-top:20px}.email-confirm-input{background-color:var(--bg-input);border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary)}.email-confirm-input:focus{border-color:var(--status-error);box-shadow:0 0 0 3px #ef44441a}.btn-danger{background-color:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .2s}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-danger:active:not(:disabled){background-color:#b91c1c}.btn-danger:disabled{background-color:#9ca3af;cursor:not-allowed;opacity:.6}.org-users-list::-webkit-scrollbar{width:8px}.org-users-list::-webkit-scrollbar-track{background:var(--bg-primary);border-radius:4px}.org-users-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.org-users-list::-webkit-scrollbar-thumb:hover{background:var(--border-color-light)}.modal-message{border-radius:6px;font-size:14px;line-height:1.5;margin:0 24px 16px;padding:12px 16px}.modal-message.success{background-color:#4caf5026;border:1px solid var(--status-success);color:var(--status-success)}.modal-message.error{background-color:#f4433626;border:1px solid var(--status-error);color:var(--status-error)}@media (max-width:768px){.modal-content.org-users-modal{max-height:90vh;max-width:95%!important}.org-user-item{align-items:flex-start;flex-direction:column;gap:12px;padding-right:16px}.org-user-info{align-items:center;text-align:center;width:100%}.btn-revoke-user{margin-left:0;max-width:100%;position:static;transform:none;width:100%}}.org-users-modal .modal-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#666;color:var(--text-secondary-color,#666);cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;position:absolute;right:8px;top:8px;transition:background-color .2s ease,color .2s ease;width:32px}.org-users-modal .modal-close-btn:hover{background-color:#f0f0f0;background-color:var(--hover-background,#f0f0f0);color:#333;color:var(--text-color,#333)}.dark-mode .org-users-modal .modal-close-btn{color:#b0b0b0;color:var(--text-secondary-color-dark,#b0b0b0)}.dark-mode .org-users-modal .modal-close-btn:hover{background-color:#3d3d3d;background-color:var(--hover-background-dark,#3d3d3d);color:#f0f0f0;color:var(--text-color-dark,#f0f0f0)}.org-users-modal .btn-secondary{background-color:#e0e0e0!important;border:none;border-radius:6px;color:#333!important;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.org-users-modal .btn-secondary:hover{background-color:#d0d0d0!important}.dark-mode .modal-content.org-users-modal .btn-secondary,.dark-mode .org-users-modal .btn-secondary,body.dark-mode .org-users-modal .btn-secondary{background-color:#3d3d3d!important;color:#f0f0f0!important}.dark-mode .modal-content.org-users-modal .btn-secondary:hover,.dark-mode .org-users-modal .btn-secondary:hover,body.dark-mode .org-users-modal .btn-secondary:hover{background-color:#4d4d4d!important}.add-user-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.add-user-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);color:var(--text-primary);max-width:500px;padding:24px;width:90%}.add-user-modal h3{color:var(--text-primary);margin-bottom:20px;margin-top:0}.add-user-form{gap:16px}.add-user-form,.form-group{display:flex;flex-direction:column}.form-group{gap:6px}.form-group label{font-size:14px}.form-group label .required{color:#dc3545;margin-left:2px}.form-group input,.form-group select{background-color:var(--bg-input);color:var(--text-primary);padding:10px}.country-code-select,.form-group input,.form-group select{border:1px solid var(--border-color);border-radius:4px;font-size:14px}.country-code-select{padding:10px 8px}.phone-number-input{border:1px solid var(--border-color);border-radius:4px;font-size:14px;padding:10px}.country-code-select:focus,.form-group input:focus,.form-group select:focus,.phone-number-input:focus{border-color:#007bff;outline:none}.form-group input::placeholder{color:#888;opacity:.7}.form-helper-text{color:var(--text-secondary);font-size:12px;margin-top:4px}.add-user-message{border-radius:4px;font-size:14px;margin-bottom:16px;padding:10px}.add-user-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.add-user-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.submit-btn{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .2s}.submit-btn:hover:not(:disabled){background-color:#218838}.submit-btn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.cancel-btn{background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .2s}.cancel-btn:hover{background-color:#5a6268}.status-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:10001}.status-modal-content{animation:modalSlideIn .3s ease-out;background:linear-gradient(145deg,#2a2a2a,#1f1f1f);border-radius:16px;box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff1a;max-width:500px;min-width:400px;padding:40px;text-align:center}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.status-modal-spinner{animation:spin 1s linear infinite;border:4px solid #667eea33;border-radius:50%;border-top-color:#667eea;height:60px;margin:0 auto 20px;width:60px}.status-modal-icon{align-items:center;animation:iconPop .4s cubic-bezier(.68,-.55,.265,1.55);border-radius:50%;display:flex;font-size:48px;font-weight:700;height:80px;justify-content:center;margin:0 auto 20px;width:80px}@keyframes iconPop{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.status-modal-icon.success{background:linear-gradient(135deg,#4caf5033,#4caf500d);box-shadow:0 0 20px #4caf504d;color:#4caf50}.status-modal-icon.error{background:linear-gradient(135deg,#f4433633,#f443360d);box-shadow:0 0 20px #f443364d;color:#f44336}.status-modal-icon.warning{background:linear-gradient(135deg,#ff980033,#ff98000d);box-shadow:0 0 20px #ff98004d;color:#ff9800}.status-modal-message{color:#e0e0e0;font-size:16px;font-weight:400;line-height:1.6;margin:0 0 30px}.status-modal-message.success{color:#81c784}.status-modal-message.error{color:#ef5350}.status-modal-message.warning{color:#ffb74d}.deletion-submessage{color:#9e9e9e;font-size:14px;line-height:1.4;margin:10px 0 20px}.status-modal-close-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;min-width:120px;padding:12px 32px;transition:all .2s ease}.status-modal-close-button:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.status-modal-close-button:active{box-shadow:0 2px 8px #667eea4d;transform:translateY(0)}.light-mode .status-modal-content{background:linear-gradient(145deg,#fff,#f5f5f5);box-shadow:0 20px 60px #00000026,0 0 0 1px #0000001a}.light-mode .status-modal-message{color:#424242}.light-mode .status-modal-message.success{color:#388e3c}.light-mode .status-modal-message.error{color:#d32f2f}.light-mode .status-modal-message.warning{color:#f57c00}.light-mode .deletion-submessage{color:#616161}.confirmation-dialog-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:10002}.confirmation-dialog-modal{animation:slideUp .3s ease-out;background:linear-gradient(145deg,#2a2a2a,#1f1f1f);border-radius:16px;box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff1a;max-width:550px;overflow:hidden;width:90%}.confirmation-dialog-header{background:linear-gradient(135deg,#667eea1a,#764ba20d);border-bottom:1px solid #ffffff1a;padding:24px 32px}.confirmation-dialog-header h3{color:#e0e0e0;font-size:20px;font-weight:600;margin:0}.confirmation-dialog-body{color:#b0b0b0;line-height:1.6;padding:32px}.confirmation-dialog-body p{font-size:15px;margin:0 0 16px}.confirmation-dialog-body p:last-child{margin-bottom:0}.confirmation-dialog-body strong{color:#667eea;font-weight:600}.confirmation-dialog-warning{background:linear-gradient(135deg,#ff980026,#ff98000d);border-left:4px solid #ff9800;border-radius:8px;color:#ffb74d;font-size:14px;line-height:1.6;margin:20px 0;padding:16px}.confirmation-dialog-note{color:#9e9e9e!important;font-size:14px!important;font-style:italic;margin-top:20px!important}.typed-confirmation-section{margin-top:24px}.typed-confirmation-instruction{color:#b0b0b0;font-size:14px;margin-bottom:12px!important}.typed-confirmation-input{background:#0000004d;border:2px solid #667eea4d;border-radius:8px;color:#e0e0e0;font-family:SF Mono,Monaco,Consolas,monospace;font-size:15px;padding:12px 16px;transition:all .2s ease}.typed-confirmation-input:focus{background:#0006;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.typed-confirmation-input::placeholder{color:#666;font-family:inherit}.typed-confirmation-input:disabled{cursor:not-allowed;opacity:.5}.confirmation-dialog-actions{background:#0003;border-top:1px solid #ffffff1a;display:flex;gap:12px;justify-content:flex-end;padding:20px 32px}.confirmation-dialog-actions button{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;min-width:100px;padding:10px 24px;transition:all .2s ease}.cancel-button{background:#ffffff1a;border:1px solid #fff3;color:#b0b0b0}.cancel-button:hover:not(:disabled){background:#ffffff26;color:#e0e0e0;transform:translateY(-1px)}.cancel-button:active:not(:disabled){transform:translateY(0)}.cancel-button:disabled{cursor:not-allowed;opacity:.5}.confirm-button{background:linear-gradient(135deg,#ef5350,#d32f2f);box-shadow:0 4px 12px #ef53504d;color:#fff}.confirm-button:hover:not(:disabled){background:linear-gradient(135deg,#f44336,#c62828);box-shadow:0 6px 20px #ef535066;transform:translateY(-2px)}.confirm-button:active:not(:disabled){box-shadow:0 2px 8px #ef53504d;transform:translateY(0)}.confirm-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.light-mode .confirmation-dialog-modal{background:linear-gradient(145deg,#fff,#f5f5f5);box-shadow:0 20px 60px #00000026,0 0 0 1px #0000001a}.light-mode .confirmation-dialog-header{background:linear-gradient(135deg,#667eea14,#764ba208);border-bottom:1px solid #0000001a}.light-mode .confirmation-dialog-header h3{color:#212121}.light-mode .confirmation-dialog-body{color:#424242}.light-mode .confirmation-dialog-body strong{color:#5568d3}.light-mode .confirmation-dialog-warning{background:linear-gradient(135deg,#ff98001a,#ff980008);color:#f57c00}.light-mode .confirmation-dialog-note{color:#757575!important}.light-mode .typed-confirmation-instruction{color:#616161}.light-mode .typed-confirmation-input{background:#667eea0d;border-color:#667eea4d;color:#212121}.light-mode .typed-confirmation-input:focus{background:#667eea14;border-color:#667eea}.light-mode .typed-confirmation-input::placeholder{color:#9e9e9e}.light-mode .confirmation-dialog-actions{background:#00000005;border-top:1px solid #0000001a}.light-mode .cancel-button{background:#0000000d;border-color:#00000026;color:#616161}.light-mode .cancel-button:hover:not(:disabled){background:#00000014;color:#424242}.organization-form{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:24px;padding:30px}.organization-form h3{color:var(--text-primary);font-size:27px;font-weight:600;margin-bottom:24px;margin-top:0;text-align:center;width:100%}.organization-form .form-group{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:12px}.organization-form .form-group label{color:var(--text-primary);flex-shrink:0;font-size:21px;font-weight:600;margin-bottom:0;text-align:right;width:200px}.organization-form .form-group input{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;box-sizing:border-box;color:var(--text-primary);font-size:21px;padding:12px 18px;transition:border-color .2s ease,box-shadow .2s ease;width:33%}.organization-form .form-group input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #61dafb1a;outline:none}.organization-form .form-group input:disabled{background-color:var(--bg-button-disabled);cursor:not-allowed;opacity:.6}.organization-form .character-counter{color:var(--text-muted);font-size:16px;font-style:italic;margin-bottom:12px;text-align:center}.organization-form .organization-settings-section{align-items:center;background-color:#ffffff05;border:1px solid #ffffff1a;border-radius:12px;display:flex;flex-direction:column;margin:30px auto;max-width:800px;padding:36px;width:50%}.organization-form .settings-section-title{border-bottom:1px solid #ffffff1a;color:var(--text-primary);font-size:28px;font-weight:600;margin:0 0 30px;padding-bottom:18px;text-align:center;width:100%}.organization-form .org-setting-item{grid-gap:36px;align-items:center;background-color:#ffffff03;border-radius:8px;display:grid;gap:36px;grid-template-columns:1fr auto;margin-bottom:18px;padding:24px;width:100%}.organization-form .org-setting-item:last-child{margin-bottom:0}.organization-form .org-setting-info{display:flex;flex-direction:column;gap:8px}.organization-form .org-setting-info h3{color:var(--text-primary);font-size:24px;font-weight:600;margin:0;text-align:left}.organization-form .org-setting-info p{color:var(--text-secondary);font-size:18px;line-height:1.5;margin:0}.organization-form .org-setting-control{align-items:center;display:flex;justify-content:flex-start}.organization-form .org-setting-control .modal-toggle-slider{border-radius:45px;height:45px;width:90px}.organization-form .org-setting-control .modal-toggle-slider:before{bottom:4.5px;height:36px;left:4.5px;width:36px}.organization-form .org-setting-control .modal-toggle-checkbox:checked+.modal-toggle-slider:before{transform:translateX(45px)}.organization-form .form-buttons{display:flex;gap:18px;justify-content:center;margin-top:30px}.organization-form .btn-cancel,.organization-form .btn-submit{border:none;border-radius:6px;cursor:pointer;font-size:21px;font-weight:600;padding:15px 36px;transition:all .2s ease}.organization-form .btn-submit{background-color:var(--accent-color);color:var(--text-on-accent)}.organization-form .btn-submit:hover:not(:disabled){background-color:var(--accent-color-hover);transform:translateY(-2px)}.organization-form .btn-cancel{background-color:var(--bg-tertiary);border:2px solid var(--border-color);color:var(--text-primary)}.organization-form .btn-cancel:hover:not(:disabled){background-color:var(--bg-input)}.organization-form .btn-cancel:disabled,.organization-form .btn-submit:disabled{cursor:not-allowed;opacity:.5}.light-mode .organization-form{background-color:#f5f5f5;border-color:#ddd}.light-mode .organization-form .form-group label,.light-mode .organization-form h3{color:#333}.light-mode .organization-form .form-group input{background-color:#fff;border-color:#ccc;color:#333}.light-mode .organization-form .form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.light-mode .organization-form .character-counter{color:#666}.light-mode .organization-form .organization-settings-section{background-color:#00000005;border-color:#0000001a}.light-mode .organization-form .settings-section-title{border-bottom-color:#0000001a;color:#333}.light-mode .organization-form .org-setting-item{background-color:#00000003}.light-mode .organization-form .org-setting-info h3{color:#333}.light-mode .organization-form .org-setting-info p{color:#666}.light-mode .organization-form .btn-submit{background-color:#667eea;color:#fff}.light-mode .organization-form .btn-submit:hover:not(:disabled){background-color:#5568d3}.light-mode .organization-form .btn-cancel{background-color:#fff;border-color:#ccc;color:#333}.light-mode .organization-form .btn-cancel:hover:not(:disabled){background-color:#f9f9f9}.org-badges-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.authz-badge{align-items:center;border-radius:12px;cursor:help;display:inline-flex;font-size:13px;font-weight:500;padding:4px 10px;transition:all .2s ease}.authz-badge.authorized{background:linear-gradient(135deg,#4caf5026,#4caf500d);border:1px solid #4caf504d;color:#4caf50}.authz-badge.authorized:hover{background:linear-gradient(135deg,#4caf5033,#4caf5014);border-color:#4caf5066}.authz-badge.not-authorized{background:linear-gradient(135deg,#ff980026,#ff98000d);border:1px solid #ff98004d;color:#ff9800}.authz-badge.not-authorized:hover{background:linear-gradient(135deg,#ff980033,#ff980014);border-color:#ff980066}.current-badge{align-items:center;background:linear-gradient(135deg,#667eea33,#667eea1a);border:1px solid #667eea4d;border-radius:12px;color:#667eea;display:inline-flex;font-size:13px;font-weight:600;padding:4px 10px}.light-mode .authz-badge.authorized{background:linear-gradient(135deg,#4caf501f,#4caf500a);border-color:#4caf5066;color:#2e7d32}.light-mode .authz-badge.authorized:hover{background:linear-gradient(135deg,#4caf502e,#4caf500f)}.light-mode .authz-badge.not-authorized{background:linear-gradient(135deg,#ff98001f,#ff98000a);border-color:#ff980066;color:#e65100}.light-mode .authz-badge.not-authorized:hover{background:linear-gradient(135deg,#ff98002e,#ff98000f)}.light-mode .current-badge{background:linear-gradient(135deg,#667eea26,#667eea14);border-color:#667eea66;color:#5568d3}.actions-container{align-items:flex-start;display:flex;flex-direction:column;gap:0;line-height:1}.action-buttons-wrapper{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-start;line-height:1;margin:0}.button-wrapper-with-tooltip{display:inline-block;position:relative}.btn-authorize,.btn-delete,.btn-edit,.btn-unauthorize{border:none;border-radius:6px;cursor:pointer;font-size:18px;font-weight:600;padding:10px 18px;transition:all .2s ease}.btn-edit{background-color:var(--accent-color);color:var(--text-on-accent)}.btn-edit:hover:not(:disabled){background-color:var(--accent-color-hover);transform:translateY(-2px)}.btn-authorize{background-color:var(--status-success);color:#fff}.btn-authorize:hover:not(:disabled){background-color:#43a047;transform:translateY(-2px)}.btn-unauthorize{background-color:var(--status-warning);color:#fff}.btn-unauthorize:hover:not(:disabled){background-color:#f57c00;transform:translateY(-2px)}.btn-delete{background-color:var(--status-error);color:#fff}.btn-delete:hover:not(:disabled){background-color:#d32f2f;transform:translateY(-2px)}.btn-authorize:disabled,.btn-delete:disabled,.btn-edit:disabled,.btn-unauthorize:disabled{cursor:not-allowed;opacity:.5;transform:none}.delete-disabled-note{color:var(--text-muted);display:block;font-size:14px;font-style:italic;line-height:1.2;margin-top:4px;width:100%}.organization-management-modal .delete-disabled-note{transform:translateY(-20px)}.light-mode .btn-edit{background-color:#667eea;color:#fff}.light-mode .btn-edit:hover:not(:disabled){background-color:#5568d3}.light-mode .btn-authorize{background-color:#4caf50}.light-mode .btn-authorize:hover:not(:disabled){background-color:#43a047}.light-mode .btn-unauthorize{background-color:#ff9800}.light-mode .btn-unauthorize:hover:not(:disabled){background-color:#f57c00}.light-mode .btn-delete{background-color:#ef4444}.light-mode .btn-delete:hover:not(:disabled){background-color:#d32f2f}.light-mode .delete-disabled-note{color:#666}.current-organization{background-color:#ffffff0d!important;border-left:6px solid var(--accent-color)!important}.org-name-container{margin-bottom:8px}.org-name-link{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:21px;font-weight:600;padding:0;text-decoration:none;transition:color .2s ease}.org-name-link:hover:not(:disabled){color:var(--accent-color-hover);text-decoration:underline}.org-name-link:disabled{cursor:not-allowed;opacity:.5}.users-column{text-align:center}.btn-view-org-users{background:none;background-color:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:24px;padding:8px 12px;transition:all .2s ease}.btn-view-org-users:hover:not(:disabled){background-color:var(--accent-color);border-color:var(--accent-color);transform:scale(1.1)}.btn-view-org-users:disabled{cursor:not-allowed;opacity:.5}.organization-id{font-family:Courier New,monospace;font-size:16px}.org-id-container{align-items:center;display:flex;gap:8px}.org-id-text{flex:1 1;word-break:break-all}.btn-copy-org-id{background:none;border:none;cursor:pointer;font-size:20px;opacity:.7;padding:4px;transition:transform .2s ease}.btn-copy-org-id:hover:not(:disabled){opacity:1;transform:scale(1.2)}.btn-copy-org-id:disabled{cursor:not-allowed;opacity:.3}.manage-installations-link{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:18px;padding:0 4px;text-decoration:none;transition:all .2s ease}.manage-installations-link:hover:not(:disabled){filter:brightness(1.2);transform:scale(1.2)}.manage-installations-link:disabled{cursor:not-allowed;opacity:.5}.actions-cell{min-width:350px}.light-mode .current-organization{background-color:#0000000d!important;border-left:6px solid var(--accent-color)!important}.light-mode .org-name-link{color:#667eea}.light-mode .org-name-link:hover:not(:disabled){color:#5568d3}.light-mode .btn-view-org-users{background-color:#f5f5f5;border-color:#ddd}.light-mode .btn-view-org-users:hover:not(:disabled){background-color:#667eea;border-color:#667eea}.light-mode .manage-installations-link{color:#667eea}.light-mode .manage-installations-link:hover:not(:disabled){color:#5568d3}.organizations-table-container{background-color:initial;border:none;border-radius:0;overflow-x:auto}.organizations-table{border-collapse:collapse;font-size:18px;width:100%}.organizations-table thead{background-color:var(--bg-tertiary);position:-webkit-sticky;position:sticky;top:0;z-index:10}.organizations-table th{border-bottom:3px solid var(--border-color);color:var(--text-primary);font-size:21px;font-weight:600;padding:18px 12px;text-align:left}.organizations-table tbody tr{border-bottom:3px solid var(--border-color);transition:background-color .2s ease}.organizations-table tbody tr:hover{background-color:var(--hover-bg)}.organizations-table td{color:var(--text-primary);padding:18px 12px;vertical-align:top}.organizations-table tbody tr:last-child{border-bottom:none}.light-mode .organizations-table-container{background-color:initial;border:none}.light-mode .organizations-table thead{background-color:var(--bg-tertiary)}.light-mode .organizations-table th{border-bottom-color:#ddd;color:#333}.light-mode .organizations-table tbody tr{border-bottom-color:#eee}.light-mode .organizations-table tbody tr:hover{background-color:var(--hover-bg)}.light-mode .organizations-table td{color:#333}.bulk-action-status-overlay{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:2100}.bulk-action-status-modal{animation:slideUp .3s ease;background:var(--bg-secondary);border-radius:12px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:1800px;width:95%}.bulk-action-status-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;justify-content:space-between;padding:24px}.header-title-section h2{color:var(--text-color);font-size:1.5rem;margin:0 0 4px}.installation-subtitle{color:#888;color:var(--text-muted,#888);font-size:.9rem;margin:0}.bulk-action-status-header .close-button{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-color);cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;transition:all .2s ease;width:40px}.bulk-action-status-header .close-button:hover{background:var(--button-bg);transform:scale(1.1)}.bulk-action-status-content{flex:1 1;overflow-y:auto;padding:24px}.progress-section{margin-bottom:24px}.progress-label{display:none}.progress-bar-container{align-items:center;background:var(--button-bg);border:1px solid var(--border-color);border-radius:12px;display:flex;height:50px;justify-content:center;margin-bottom:12px;overflow:visible;position:relative;width:100%}.progress-bar-fill{background:linear-gradient(90deg,#60a5fa,#93c5fd);border-radius:12px;height:100%;left:0;position:absolute;top:0;transition:width .5s ease;z-index:1}.progress-bar-fill.device-progress{background:linear-gradient(90deg,#c084fc,#e9d5ff)}.progress-bar-label{color:var(--text-color);font-size:1.3rem;font-weight:700;letter-spacing:.5px;pointer-events:none;position:relative;text-shadow:-1px -1px 0 #000c,1px -1px 0 #000c,-1px 1px 0 #000c,1px 1px 0 #000c,0 0 3px #000000e6;text-transform:uppercase;z-index:2}.progress-text{color:#fff;font-size:1.7rem;font-weight:700;text-shadow:0 1px 2px #0000004d}.progress-stats{flex-wrap:wrap;gap:12px;justify-content:space-between}.progress-left,.progress-stats{align-items:center;display:flex}.progress-left{gap:16px}.progress-percentage{color:var(--text-color);font-size:1.1rem;font-weight:700}.progress-timer{align-items:center;color:var(--text-secondary);display:flex;font-size:1.5rem;font-weight:500;gap:6px;transition:all .3s ease}.progress-timer.timer-complete{color:#10b981;font-weight:700}.progress-timer.timer-complete .timer-icon{color:#10b981}.progress-timer.timer-complete .timer-value{color:#10b981;font-weight:700}.timer-icon{font-size:1.8rem}.timer-value{color:var(--text-primary);font-family:Courier New,monospace}.progress-counts{display:flex;flex-wrap:wrap;gap:16px}.progress-counts .stat{font-size:.9rem;font-weight:500}.progress-counts .stat.resolved{color:#4a4}.progress-counts .stat.pending{color:#f80}.progress-counts .stat.rejected{color:#f44}.status-table-container{overflow-x:auto}.status-table{border-collapse:collapse;font-size:1.05rem;width:100%}.status-table thead{background:var(--button-bg);position:-webkit-sticky;position:sticky;top:0;z-index:1}.status-table th{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:1.1rem;font-weight:600;padding:12px;text-align:left}.status-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .2s ease}.status-table tbody tr:hover{background:var(--button-bg)}.status-table td{color:var(--text-primary);font-size:1rem;padding:12px}.status-table td:nth-child(7),.status-table th:nth-child(7){color:#60a5fa}.status-table td:nth-child(8),.status-table th:nth-child(8){color:#c084fc}.timer-cell{font-family:Courier New,monospace;padding:8px 12px!important;text-align:center}.timer-cell.cloud-timer,.timer-cell.cloud-timer .timer-timestamp,.timer-cell.cloud-timer .timer-value{color:#60a5fa}.timer-cell.device-timer,.timer-cell.device-timer .timer-timestamp,.timer-cell.device-timer .timer-value{color:#c084fc}.timer-cell .timer-value{font-size:1.1rem;font-weight:600;margin-bottom:4px}.timer-cell .timer-timestamp{font-size:.75rem;font-weight:400;opacity:.8}.average-row{background:var(--button-bg);border-top:2px solid var(--border-color);font-weight:700}.average-row .average-label{color:var(--text-primary);font-size:1.1rem;padding-right:20px;text-align:right}.average-row .timer-cell{font-size:1.2rem}.average-row .timer-cell.cloud-timer,.average-row .timer-cell.cloud-timer .timer-value{color:#60a5fa}.average-row .timer-cell.device-timer,.average-row .timer-cell.device-timer .timer-value{color:#c084fc}.average-row .timer-value{font-size:1.3rem!important;font-weight:700}.status-table .device-name{color:var(--text-primary);font-weight:500;white-space:nowrap}.status-table .action-id,.status-table .device-id{color:var(--text-secondary);font-family:Courier New,monospace;font-size:.9rem}.id-cell-wrapper{align-items:center;display:flex;gap:8px;justify-content:space-between}.id-cell-wrapper .id-text{flex:1 1;min-width:0}.copy-button{align-items:center;background:var(--button-bg);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;justify-content:center;opacity:.7;padding:4px 8px;transition:all .2s ease}.copy-button:hover{background:var(--accent-color);border-color:var(--accent-color);opacity:1;transform:scale(1.1)}.copy-button:active{transform:scale(.95)}.status-badge{font-size:.85rem;padding:4px 12px}.status-badge.pending{background:#f80;color:#fff}.status-badge.resolved{background:#4a4;color:#fff}.status-badge.rejected{background:#f44;color:#fff}.lockdown-state-cell{font-weight:500}.lockdown-state.lockdown-on{animation:blink 1s infinite;color:red;font-weight:700}.lockdown-state.lockdown-off{color:#4a4;font-weight:700}.lock-state-cell{font-weight:500}.lock-state.frozen-secured{color:red;font-weight:700}.lock-state.frozen-passage{color:#4a4;font-weight:700}.lock-state.secured{color:red;font-weight:700}.lock-state.passage{color:#4a4;font-weight:700}.no-results{color:#888;color:var(--text-muted,#888);font-style:italic;padding:40px 20px;text-align:center}.bulk-action-status-footer{border-top:2px solid var(--border-color);display:flex;justify-content:center;padding:16px 24px}.close-footer-button{background:var(--button-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);cursor:pointer;font-size:1rem;padding:10px 32px;transition:all .2s ease}.close-footer-button:hover{background:var(--border-color);transform:translateY(-1px)}@media (max-width:768px){.bulk-action-status-modal{max-height:95vh;width:98%}.status-table{font-size:.85rem}.status-table td,.status-table th{padding:8px}.status-table .action-id,.status-table .device-id{font-size:.75rem}.progress-stats{align-items:flex-start;flex-direction:column}}@media (max-width:480px){.status-table td:nth-child(2),.status-table th:nth-child(2){display:none}}.bulk-results-list{font-size:1.275rem;margin-top:20px}.results-header{grid-gap:8px;background:var(--button-bg);border-bottom:2px solid var(--border-color);border-radius:8px 8px 0 0;display:grid;font-size:1.275rem;font-weight:600;gap:8px;grid-template-columns:1.2fr .8fr .8fr 1fr 1fr 1fr 1.2fr 1.2fr;letter-spacing:.5px;padding:12px;text-transform:uppercase}.results-header span{color:var(--text-color)}.header-action-id,.header-action-status,.header-device-id,.header-device-name,.header-lock-state,.header-lockdown-state{text-transform:none}.header-cloud-time,.header-device-time{align-items:center;display:flex;flex-direction:column;gap:2px;justify-content:center;text-transform:none}.header-icon{font-size:1.275rem;font-weight:700}.header-label{font-size:.75rem;font-weight:500;text-transform:uppercase}.results-body{max-height:400px;overflow-y:auto}.bulk-device-result{grid-gap:8px;align-items:center;border-bottom:1px solid var(--border-color);display:grid;gap:8px;grid-template-columns:1.2fr .8fr .8fr 1fr 1fr 1fr 1.2fr 1.2fr;padding:12px;transition:background .2s ease}.bulk-device-result:hover{background:var(--button-bg)}.bulk-device-result>div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-device-name{color:var(--text-color);font-weight:500}.cell-action-id,.cell-device-id{align-items:center;color:var(--text-secondary);display:flex;font-family:Courier New,monospace;font-size:1.275rem;gap:4px}.copy-btn{background:#0000;border:none;cursor:pointer;font-size:.9rem;opacity:.5;padding:2px 4px;transition:all .2s ease}.copy-btn:hover{opacity:1;transform:scale(1.2)}.cell-action-status{align-items:center;display:flex;justify-content:center}.status-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;padding:4px 10px;text-transform:uppercase}.status-badge.status-resolved{background:#10b981;color:#fff}.status-badge.status-rejected{background:#ef4444;color:#fff}.status-badge.status-pending{background:#f59e0b;color:#fff}.cell-lock-state,.cell-lockdown-state{color:var(--text-color);font-weight:500}.cell-cloud-time,.cell-device-time{font-family:Courier New,monospace;font-size:.85rem}.cell-cloud-time{color:#60a5fa}.cell-device-time{color:#c084fc}.time-display{display:flex;flex-direction:column;gap:2px}.time-value{font-size:.9rem;font-weight:600}.time-timestamp{font-size:.65rem;opacity:.7}.average-response-row{grid-gap:8px;background:#667eea1a;border-radius:4px;border-top:2px solid var(--accent-color);display:grid;font-weight:600;gap:8px;grid-template-columns:1.2fr .8fr .8fr 1fr 1fr 1fr 1.2fr 1.2fr;margin-top:8px;padding:16px 12px}.avg-label{color:var(--text-color);justify-content:flex-start}.avg-cloud-time,.avg-device-time,.avg-label{align-items:center;display:flex;font-size:.95rem}.avg-cloud-time,.avg-device-time{color:var(--accent-color);font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;gap:6px;justify-content:center}.avg-cloud-time .time-icon,.avg-device-time .time-icon{font-size:.9rem}.session-expiration-warning{align-items:center;animation:slideInFromRight .4s ease-out;background-color:#060101;border:1px solid #ff9800;border-left-width:5px;border-radius:8px;bottom:40px;box-shadow:0 4px 12px var(--shadow-color);color:#fff;display:flex;gap:12px;max-width:400px;min-width:320px;padding:16px 20px;position:fixed;right:20px;z-index:10600}.dark-theme .session-expiration-warning{background-color:#060101;border:1px solid #ff9800;border-left-width:5px;color:#fff}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(100%)}to{opacity:.95;transform:translateX(0)}}.warning-content{align-items:center;display:flex;flex:1 1;gap:12px}.warning-icon{color:#ff9800;flex-shrink:0;font-size:24px;line-height:1}.warning-text{display:flex;flex-direction:column;gap:4px}.warning-title{font-size:14px;font-weight:600;line-height:1.2}.warning-message{font-size:13px;line-height:1.3}.warning-message strong{background:#060101;border-radius:4px;color:#ff9800;font-family:Monaco,Courier New,monospace;font-size:14px;font-weight:700;padding:2px 6px}.warning-refresh{align-items:center;background:#060101;border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;display:flex;flex-shrink:0;font-size:18px;justify-content:center;line-height:1;padding:6px 10px;transition:all .2s}.warning-refresh:hover:not(:disabled){background:var(--bg-input);border-color:var(--accent-color);transform:scale(1.05)}.warning-refresh:active:not(:disabled){background:var(--bg-input);transform:scale(.98)}.warning-refresh:disabled{animation:spin 1s linear infinite;cursor:not-allowed;opacity:.6}.warning-close{background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-size:20px;line-height:1;padding:4px 8px;transition:background-color .2s}.warning-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.warning-close:active{background:var(--bg-input)}#session-warning-portal{height:0;left:0;pointer-events:none;position:fixed;top:0;width:0;z-index:10600}#session-warning-portal>*{pointer-events:auto}.password-prompt-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;left:0;position:fixed;right:0;top:0;z-index:9998}.password-prompt-modal{animation:slideIn .2s ease-out;background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0000004d;left:50%;max-width:450px;padding:30px;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:9999}.password-prompt-modal h2{border-bottom:2px solid var(--border-color);color:var(--accent-color);font-size:1.5rem;margin:0 0 20px;padding-bottom:15px;text-align:center}.password-prompt-content{margin-bottom:0}.password-prompt-message{color:var(--text-secondary);font-size:1rem;line-height:1.5;margin-bottom:20px;text-align:center}.password-input-group{margin-bottom:25px}.password-input-group label{color:var(--text-primary);display:block;font-size:.95rem;font-weight:500;margin-bottom:8px}.password-input-group input{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:1rem;padding:10px 12px;transition:border-color .2s;width:100%}.password-input-group input:focus{border-color:var(--accent-color);outline:none}.password-input-group input.error{border-color:#ff3b30}.password-error{color:#ff3b30;display:block;font-size:.85rem;margin-top:5px}.password-prompt-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:25px}.password-cancel-btn,.password-confirm-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 24px;transition:all .2s ease}.password-cancel-btn{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.password-cancel-btn:hover{background-color:var(--bg-secondary);border-color:var(--accent-color)}.password-confirm-btn{background:linear-gradient(135deg,#6a11cb,#2575fc);color:#fff;font-weight:600}.password-confirm-btn:hover{background:linear-gradient(135deg,#2575fc,#6a11cb);box-shadow:0 4px 12px #2575fc66;transform:translateY(-1px)}.password-cancel-btn:active,.password-confirm-btn:active{transform:scale(.98)}@media (max-width:600px){.password-prompt-modal{padding:20px;width:95%}.password-prompt-modal h2{font-size:1.3rem}.password-prompt-actions{flex-direction:column}.password-cancel-btn,.password-confirm-btn{width:100%}}.device-update-banner{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-left:4px solid var(--status-info);border-radius:10px;bottom:24px;box-shadow:0 8px 24px var(--shadow-color);font-size:.875rem;max-width:calc(100vw - 48px);overflow:hidden;position:fixed;right:24px;width:340px;z-index:1800}.device-update-banner.banner-complete{border-left-color:var(--status-success)}.device-update-banner.banner-enter{animation:banner-slide-in .35s ease-out forwards}.device-update-banner.banner-exit{animation:banner-slide-out .3s ease-in forwards}@keyframes banner-slide-in{0%{opacity:0;transform:translateX(110%)}to{opacity:1;transform:translateX(0)}}@keyframes banner-slide-out{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(110%)}}.banner-header{align-items:center;display:flex;gap:8px;padding:10px 12px 6px}.banner-emoji{font-size:1.1rem;line-height:1}.banner-title{color:var(--text-primary);flex:1 1;font-weight:600}.banner-dismiss{background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:1.25rem;line-height:1;padding:0 2px;transition:color .15s,background-color .15s}.banner-dismiss:hover{background-color:var(--hover-bg);color:var(--text-primary)}.banner-body{align-items:center;color:var(--text-secondary);display:flex;gap:8px;padding:4px 12px 10px}.banner-spinner{animation:banner-spin .8s linear infinite;border:2px solid var(--border-color-light);border-left-color:var(--status-info);border-radius:50%;display:inline-block;flex-shrink:0;height:14px;width:14px}@keyframes banner-spin{to{transform:rotate(1turn)}}.banner-check{color:var(--status-success);flex-shrink:0;font-size:1rem;font-weight:700}.banner-message{line-height:1.35}.banner-actions{padding:0 12px 10px}.banner-refresh-btn{background-color:var(--accent-color);border:none;border-radius:6px;color:var(--text-on-accent);cursor:pointer;font-size:.8125rem;font-weight:600;padding:5px 14px;transition:background-color .15s}.banner-refresh-btn:hover{background-color:var(--accent-color-hover)}.token-expiration-timer{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border:1px solid var(--border-color-subtle,#ffffff1a);border-radius:9px;color:#e0e0e0;color:var(--text-primary,#e0e0e0);display:flex;flex-shrink:0;font-family:Courier New,monospace;font-size:13px;gap:6px;line-height:1;padding:14px 20px;transition:all .3s ease}.token-expiration-timer .timer-icon{font-size:16px}.token-expiration-timer .timer-text{font-weight:600;letter-spacing:.5px}.token-expiration-timer.expiring-soon{animation:pulse-warning 2s ease-in-out infinite;background:#ff98001a;border-color:#ff9800;color:#ff9800}.token-expiration-timer.expiring-soon .timer-icon{animation:shake .5s ease-in-out infinite}.token-expiration-timer.clickable:hover{background:#ff980033;border-color:#ffa726;box-shadow:0 2px 8px #ff98004d;transform:scale(1.05)}.token-expiration-timer.clickable:active{transform:scale(.98)}.token-expiration-timer.refreshing{opacity:.7;pointer-events:none}.token-expiration-timer.refreshing .timer-icon{animation:spin 1s linear infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.7}}@keyframes shake{0%,to{transform:rotate(0deg)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}body.light-mode .token-expiration-timer{background:#f5f5f5;border-color:#ddd;color:#333}body.light-mode .token-expiration-timer.expiring-soon{background:#ff980026;border-color:#ff9800;color:#d47400}body.light-mode .token-expiration-timer.clickable:hover{background:#ff980040;border-color:#ffa726}:root{--PhoneInput-color--focus:#03b2cb;--PhoneInputInternationalIconPhone-opacity:0.8;--PhoneInputInternationalIconGlobe-opacity:0.65;--PhoneInputCountrySelect-marginRight:0.35em;--PhoneInputCountrySelectArrow-width:0.3em;--PhoneInputCountrySelectArrow-marginLeft:var(--PhoneInputCountrySelect-marginRight);--PhoneInputCountrySelectArrow-borderWidth:1px;--PhoneInputCountrySelectArrow-opacity:0.45;--PhoneInputCountrySelectArrow-color:currentColor;--PhoneInputCountrySelectArrow-color--focus:var(--PhoneInput-color--focus);--PhoneInputCountrySelectArrow-transform:rotate(45deg);--PhoneInputCountryFlag-aspectRatio:1.5;--PhoneInputCountryFlag-height:1em;--PhoneInputCountryFlag-borderWidth:1px;--PhoneInputCountryFlag-borderColor:#00000080;--PhoneInputCountryFlag-borderColor--focus:var(--PhoneInput-color--focus);--PhoneInputCountryFlag-backgroundColor--loading:#0000001a}.PhoneInput{align-items:center;display:flex}.PhoneInputInput{flex:1 1;min-width:0}.PhoneInputCountryIcon{height:1em;height:var(--PhoneInputCountryFlag-height);width:1.5em;width:calc(var(--PhoneInputCountryFlag-height)*var(--PhoneInputCountryFlag-aspectRatio))}.PhoneInputCountryIcon--square{width:1em;width:var(--PhoneInputCountryFlag-height)}.PhoneInputCountryIcon--border{background-color:#0000001a;background-color:var(--PhoneInputCountryFlag-backgroundColor--loading);box-shadow:0 0 0 1px #00000080,inset 0 0 0 1px #00000080;box-shadow:0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor),inset 0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor)}.PhoneInputCountryIconImg{display:block;height:100%;width:100%}.PhoneInputInternationalIconPhone{opacity:.8;opacity:var(--PhoneInputInternationalIconPhone-opacity)}.PhoneInputInternationalIconGlobe{opacity:.65;opacity:var(--PhoneInputInternationalIconGlobe-opacity)}.PhoneInputCountry{align-items:center;align-self:stretch;display:flex;margin-right:.35em;margin-right:var(--PhoneInputCountrySelect-marginRight);position:relative}.PhoneInputCountrySelect{border:0;cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%;z-index:1}.PhoneInputCountrySelect[disabled],.PhoneInputCountrySelect[readonly]{cursor:default}.PhoneInputCountrySelectArrow{border-bottom-width:1px;border-bottom-width:var(--PhoneInputCountrySelectArrow-borderWidth);border-color:currentColor;border-color:var(--PhoneInputCountrySelectArrow-color);border-left-width:0;border-right-width:1px;border-right-width:var(--PhoneInputCountrySelectArrow-borderWidth);border-style:solid;border-top-width:0;content:"";display:block;height:.3em;height:var(--PhoneInputCountrySelectArrow-width);margin-left:.35em;margin-left:var(--PhoneInputCountrySelectArrow-marginLeft);opacity:.45;opacity:var(--PhoneInputCountrySelectArrow-opacity);transform:rotate(45deg);transform:var(--PhoneInputCountrySelectArrow-transform);width:.3em;width:var(--PhoneInputCountrySelectArrow-width)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon+.PhoneInputCountrySelectArrow{color:#03b2cb;color:var(--PhoneInputCountrySelectArrow-color--focus);opacity:1}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon--border{box-shadow:0 0 0 1px #03b2cb,inset 0 0 0 1px #03b2cb;box-shadow:0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor--focus),inset 0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor--focus)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon .PhoneInputInternationalIconGlobe{color:#03b2cb;color:var(--PhoneInputCountrySelectArrow-color--focus);opacity:1}.modal-overlay{align-items:center;animation:fadeIn .2s ease-in;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideUp .3s ease-out;background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 6px var(--shadow-color);max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{border-bottom:1px solid var(--border-color);flex-direction:row;justify-content:space-between;padding:20px}.modal-header h2{color:var(--text-primary);flex:1 1;font-size:1.5rem;font-weight:600;order:1}.close-button{color:var(--text-secondary);flex-shrink:0;height:32px;line-height:1;margin-left:auto;order:2;padding:0;transition:background-color .2s,color .2s;width:32px}.close-button:hover:not(:disabled){background-color:var(--bg-tertiary);color:var(--text-primary)}.close-button:disabled{cursor:not-allowed;opacity:.5}.modal-body{padding:20px}.form-group{margin-bottom:20px}.form-group label{font-size:.875rem;font-weight:500;margin-bottom:6px}.required{color:var(--status-error)}.readonly-label{color:var(--text-secondary);font-size:.75rem;font-weight:400}.form-group input[type=email],.form-group input[type=text]{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;box-sizing:border-box;color:var(--text-primary);font-size:.875rem;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input[type=email]:focus,.form-group input[type=text]:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #61dafb1a;outline:none}.readonly-input{background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed}.input-error{border-color:var(--status-error)!important}.input-error:focus{box-shadow:0 0 0 3px #dc26261a!important}.PhoneInput{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;padding:4px 8px;transition:border-color .2s,box-shadow .2s}.PhoneInput:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 3px #61dafb1a}.phone-input-error .PhoneInput{border-color:var(--status-error)}.phone-input-error .PhoneInput:focus-within{box-shadow:0 0 0 3px #dc26261a}.PhoneInputInput{background-color:initial;border:none;color:var(--text-primary);font-size:.875rem;outline:none;padding:6px 4px}.field-error{color:var(--status-error)}.field-error,.field-hint{display:block;font-size:.75rem;margin-top:4px}.field-hint{color:var(--text-secondary)}.error-message{align-items:center;background-color:var(--bg-error);border:1px solid var(--status-error);border-radius:6px;color:var(--status-error);display:flex;gap:8px;margin-bottom:16px;padding:12px}.error-icon{font-size:1.25rem}.success-message{align-items:center;background-color:var(--bg-success);border:1px solid var(--status-success);border-radius:6px;color:var(--status-success);display:flex;gap:8px;margin-bottom:16px;padding:12px}.success-icon{font-size:1.25rem;font-weight:700}.modal-footer{border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end;padding:20px}.button{border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:10px 20px;transition:all .2s}.button:disabled{cursor:not-allowed;opacity:.6}.button-secondary{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.button-secondary:hover:not(:disabled){background-color:var(--bg-input);border-color:var(--accent-color)}.button-primary{background-color:#3b82f6;border:1px solid #3b82f6;color:#fff}.button-primary:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb;color:#fff}.form-section{border-top:2px solid var(--border-color);margin-top:30px;padding-top:20px}.password-section{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;display:flex;flex-direction:column;gap:20px;padding:20px}.toggle-password-button{align-self:center;background-color:#3b82f6;border:1px solid #3b82f6;border-radius:6px;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:500;padding:12px 24px;transition:all .2s}.toggle-password-button:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb;color:#fff}.toggle-password-button:disabled{cursor:not-allowed;opacity:.5}.password-requirements{margin-bottom:16px;padding:12px 16px}.requirements-title{font-weight:500;margin:0 0 8px}.requirements-list li{color:var(--text-secondary);font-size:.8125rem;padding:4px 0}.requirements-list li.met{color:var(--status-success)}.requirements-list li.unmet{color:var(--text-muted)}.requirement-icon{font-size:1rem}.form-group input[type=password]{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;box-sizing:border-box;color:var(--text-primary);font-size:.875rem;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input[type=password]:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #61dafb1a;outline:none}.password-strength{border-radius:4px;display:inline-block;font-size:.75rem;font-weight:500;margin-top:6px;padding:4px 8px}.password-strength.strength-weak{background-color:#dc26261a;color:var(--status-error)}.password-strength.strength-medium{background-color:#eab3081a;color:#eab308}.password-strength.strength-strong{background-color:#22c55e1a;color:var(--status-success)}.success-hint{color:var(--status-success)!important}.error-hint{color:var(--status-error)!important}.change-password-button{margin-top:16px;width:100%}.profile-footer{margin-top:20px}@media (max-width:640px){.modal-content{max-height:95vh;width:95%}.modal-body,.modal-footer,.modal-header{padding:16px}.modal-header h2{font-size:1.25rem}.toggle-password-button{align-self:stretch;width:100%}}.change-password-modal{max-width:500px}.change-password-modal .modal-body{padding:20px}.password-requirements{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;margin-bottom:20px;padding:16px}.requirements-title{color:var(--text-primary);font-size:.875rem;font-weight:600;margin:0 0 12px}.requirements-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.requirements-list li{align-items:center;display:flex;font-size:.875rem;gap:8px;transition:color .2s}.requirement-met{color:var(--success-color)}.requirement-unmet{color:var(--text-secondary)}.requirement-icon{display:inline-block;font-weight:700;text-align:center;width:16px}.password-strength{align-items:center;background-color:var(--bg-tertiary);border-radius:6px;display:flex;gap:12px;margin-bottom:20px;padding:12px}.strength-label{color:var(--text-secondary);font-size:.875rem;font-weight:500;white-space:nowrap}.strength-bar{background-color:var(--bg-input);border-radius:4px;flex:1 1;height:8px;overflow:hidden}.strength-fill{border-radius:4px;height:100%;transition:width .3s ease,background-color .3s ease}.strength-fill.strength-weak{background-color:#ef4444;width:33%}.strength-fill.strength-medium{background-color:#f59e0b;width:66%}.strength-fill.strength-strong{background-color:#10b981;width:100%}.strength-text{font-size:.875rem;font-weight:600;white-space:nowrap}.strength-text.strength-weak{color:#ef4444}.strength-text.strength-medium{color:#f59e0b}.strength-text.strength-strong{color:#10b981}.success-hint{color:var(--success-color)!important}.error-hint{color:var(--error-color)!important}.loading-overlay{background-color:#000000b3;border-radius:12px;flex-direction:column;z-index:1000}.loading-overlay p{color:#fff;font-size:1rem;font-weight:500;margin-top:16px}.spinner{animation:spin .8s linear infinite;border:4px solid #ffffff4d;border-top:4px solid var(--primary-color);height:50px;width:50px}@media (max-width:768px){.change-password-modal{max-width:none;width:95%}.password-strength{flex-wrap:wrap}.strength-label{margin-bottom:8px;width:100%}.strength-bar{flex:1 1;min-width:100px}}.edit-user-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.edit-user-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);color:var(--text-primary);max-width:500px;padding:24px;width:90%}.edit-user-modal h3{color:var(--text-primary);margin-bottom:20px;margin-top:0}.edit-user-form{display:flex;flex-direction:column;gap:16px}.edit-user-message{border-radius:4px;font-size:14px;margin-bottom:16px;padding:10px}.edit-user-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.edit-user-message.warning{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404}.role-confirmation-input{font-family:Courier New,Courier,monospace}.edit-user-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.delete-user-confirm-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.delete-user-confirm-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);color:var(--text-primary);max-width:450px;padding:24px;width:90%}.delete-user-confirm-modal h3{color:#dc3545;margin-bottom:16px;margin-top:0}.delete-user-info{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;margin-bottom:16px;padding:12px}.delete-user-info p{font-size:14px;margin:6px 0}.delete-user-info strong{color:var(--text-primary);font-weight:600}.delete-warning{background-color:#fff3cd;border:1px solid #ffeeba;border-radius:4px;color:#856404;font-size:14px;line-height:1.5;margin-bottom:16px;padding:12px}.delete-warning strong{display:block;margin-bottom:6px}.delete-user-message{border-radius:4px;font-size:14px;margin-bottom:16px;padding:10px}.delete-user-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.delete-user-confirm-text{color:var(--text-primary);font-size:14px;margin-bottom:20px}.delete-user-typed-confirmation{margin-bottom:20px}.delete-user-typed-confirmation label{color:var(--text-primary);display:block;font-size:14px;font-weight:600;margin-bottom:8px}.delete-user-typed-input{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;color:var(--text-primary);font-family:Courier New,Courier,monospace;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.delete-user-typed-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #61dafb1a;outline:none}.delete-user-typed-input:disabled{background-color:var(--bg-button-disabled);cursor:not-allowed;opacity:.6}.delete-user-typed-input::placeholder{color:var(--text-muted);opacity:.7}.delete-user-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.delete-confirm-btn{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .2s}.delete-confirm-btn:hover:not(:disabled){background-color:#c82333}.delete-confirm-btn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.user-org-access-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.user-org-access-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 6px var(--shadow-color);color:var(--text-primary);max-height:90vh;max-width:600px;overflow-y:auto;padding:20px;width:90%}.user-org-access-modal h3{color:var(--text-primary);margin-bottom:16px;margin-top:0}.user-org-header{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;margin-bottom:20px;padding:12px}.user-org-header p{font-size:14px;margin:4px 0}.user-org-header strong{font-weight:600}.org-access-message{border-radius:4px;font-size:14px;margin-bottom:16px;padding:10px}.org-access-message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.org-access-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.org-access-message.info{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.org-access-controls{align-items:center;display:flex;gap:10px;margin-bottom:20px}.org-search-input{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);flex:1 1;font-size:14px;padding:8px 12px}.add-org-btn{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background-color .2s}.add-org-btn:hover:not(:disabled){background-color:#218838}.add-org-btn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.org-access-loading{align-items:center;color:var(--text-secondary);display:flex;gap:10px;justify-content:center;padding:40px;text-align:center}.org-access-loading:before{animation:spin .8s linear infinite;border:3px solid var(--border-color);border-radius:50%;border-top:3px solid #4a9eff;content:"";height:20px;width:20px}.org-access-empty{color:var(--text-secondary);padding:40px;text-align:center}.org-access-list{background-color:#00000005;border:1px solid var(--border-color);border-radius:4px;margin-bottom:20px;max-height:400px;overflow-y:auto;padding:12px}.org-access-item{align-items:center;background-color:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;box-shadow:0 1px 3px #0000000d;display:flex;justify-content:space-between;margin-bottom:12px;padding:14px;transition:all .2s}.org-access-item:last-child{margin-bottom:0}.org-access-item:hover{background-color:var(--row-hover-bg);border-color:#4a9eff;box-shadow:0 2px 4px #0000001a}.org-access-info{flex:1 1}.org-access-name{color:var(--text-primary);font-size:15px;font-weight:600;margin-bottom:6px}.org-access-id{color:var(--text-secondary);font-family:monospace;font-size:11px;opacity:.7}.revoke-org-btn{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:background-color .2s}.revoke-org-btn:hover:not(:disabled){background-color:#c82333}.revoke-org-btn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.org-access-actions{display:flex;justify-content:flex-end;margin-top:20px}.org-selector-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1200}.org-selector-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);color:var(--text-primary);max-height:90vh;max-width:500px;overflow-y:auto;padding:20px;width:90%}.org-selector-modal h4{margin-bottom:16px;margin-top:0}.org-selector-search{background-color:var(--input-bg);box-sizing:border-box;color:var(--text-primary);padding:8px 12px;width:calc(100% - 24px)}.org-selector-list,.org-selector-search{border:1px solid var(--border-color);border-radius:4px;margin-bottom:16px}.org-selector-list{background-color:var(--bg-primary);max-height:600px;overflow-y:auto;padding:16px}.org-selector-item{background-color:var(--input-bg);border:2px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;margin-bottom:16px;padding:16px;transition:all .2s}.org-selector-item:last-child{margin-bottom:0}.org-selector-item:hover{background-color:var(--row-hover-bg);border-color:#28a745;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.org-selector-item.disabled{border-color:var(--border-color);cursor:not-allowed;opacity:.5}.org-selector-item.disabled:hover{background-color:var(--input-bg);border-color:var(--border-color);box-shadow:0 2px 4px #0000001a;transform:none}.org-selector-item .org-access-info{flex:1 1}.org-authorized-badge{background-color:#28a745;border-radius:4px;color:#fff;font-size:12px;font-weight:700;padding:4px 12px;white-space:nowrap}.org-selector-actions{display:flex;gap:10px;justify-content:flex-end}.confirm-action-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1300}.confirm-action-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);color:var(--text-primary);max-width:450px;padding:24px;width:90%}.confirm-action-modal h3{color:var(--text-primary);font-size:18px;margin-bottom:16px;margin-top:0}.confirm-action-modal p{font-size:14px;line-height:1.5;margin:12px 0}.confirm-action-modal .confirm-details{background-color:var(--input-bg);border-left:3px solid #ffc107;border-radius:4px;color:var(--text-secondary);font-size:13px;margin-top:8px;padding:10px}.confirm-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.confirm-actions .cancel-btn{background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 20px;transition:background-color .2s}.confirm-actions .cancel-btn:hover:not(:disabled){background-color:#5a6268}.confirm-actions .cancel-btn:disabled{cursor:not-allowed;opacity:.6}.confirm-actions .confirm-btn{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 20px;transition:background-color .2s}.confirm-actions .confirm-btn:hover:not(:disabled){background-color:#218838}.confirm-actions .confirm-btn:disabled{cursor:not-allowed;opacity:.6}.confirm-actions .confirm-btn.revoke{background-color:#dc3545}.confirm-actions .confirm-btn.revoke:hover:not(:disabled){background-color:#c82333}.warning-text{color:#dc3545;font-size:14px;font-weight:600;margin-bottom:8px;margin-top:16px}.email-confirm-input{border:2px solid #ced4da;border-radius:4px;box-sizing:border-box;font-family:monospace;font-size:14px;margin-bottom:8px;max-width:100%;padding:10px 14px;transition:border-color .2s;width:100%}.email-confirm-input:focus{border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a;outline:none}.reenable-user-overlay{align-items:center;animation:fadeIn .2s ease;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.reenable-user-modal{animation:slideUp .3s ease;background-color:var(--bg-secondary);border:2px solid #ff9800;border-radius:12px;box-shadow:0 10px 40px #0000004d;color:var(--text-primary);max-width:500px;min-width:400px;padding:32px}.reenable-user-header{border-bottom:2px solid #ff9800;margin-bottom:20px;padding-bottom:12px}.reenable-user-header h3{color:#ff9800;font-size:22px;font-weight:600;margin:0}.reenable-user-body{margin-bottom:24px}.reenable-user-body p{color:var(--text-primary);font-size:16px;line-height:1.5;margin:0 0 12px}.reenable-user-info{background-color:var(--bg-tertiary);border-radius:6px;margin-bottom:16px;padding:12px;text-align:center}.reenable-user-info strong{color:var(--text-primary);display:block;font-size:18px;font-weight:600;margin-bottom:4px}.reenable-user-email{color:var(--text-secondary);font-size:14px}.reenable-warning{background-color:#ff980026;border:1px solid #ff980066;border-radius:6px;color:#ff9800;font-size:15px;line-height:1.4;margin:12px 0;padding:12px}.reenable-confirmation{display:flex;flex-direction:column;gap:8px;margin-top:20px}.reenable-confirmation label{color:var(--text-primary);font-size:14px;font-weight:500}.reenable-confirmation label strong{color:var(--accent-color);font-family:monospace}.reenable-email-input{background-color:var(--bg-input);border:2px solid var(--border-color);border-radius:6px;box-sizing:border-box;color:var(--text-primary);font-family:monospace;font-size:14px;max-width:100%;padding:10px 14px;transition:border-color .2s;width:100%}.reenable-email-input:focus{border-color:#ff9800;box-shadow:0 0 0 3px #ff98001a;outline:none}.reenable-error{background-color:#f443361a;border:1px solid #f44336;border-radius:4px;color:#f44336;font-size:13px;margin-top:12px;padding:8px 12px}.reenable-user-footer{display:flex;gap:12px;justify-content:flex-end}.reenable-cancel-btn,.reenable-confirm-btn{border:none;border-radius:6px;cursor:pointer;font-size:15px;font-weight:500;padding:10px 20px;transition:all .2s ease}.reenable-cancel-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.reenable-cancel-btn:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.reenable-confirm-btn{background:#ff9800;border:1px solid #ff9800;color:#fff}.reenable-confirm-btn:hover:not(:disabled){background:#e68900;transform:translateY(-1px)}.reenable-confirm-btn:disabled{background:#555;border-color:#444;cursor:not-allowed;opacity:.5}.reenable-confirm-btn .spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;margin-right:8px;vertical-align:middle;width:14px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.reenable-user-modal{min-width:auto;padding:20px 24px;width:95%}.reenable-user-footer{flex-direction:column}.reenable-user-footer button{width:100%}}.user-management-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.user-management-modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 6px var(--shadow-color);color:var(--text-primary);max-height:90vh;max-width:1200px;overflow-y:auto;padding:20px;width:90%}.user-management-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.user-management-modal h2{color:var(--text-primary);margin:0}.user-management-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:24px;line-height:1;padding:5px 10px;transition:color .2s ease}.user-management-close-btn:hover{color:var(--text-primary)}.user-management-controls{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:20px}.user-management-filters{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:10px}.user-management-search-wrapper{display:flex;flex:1 1;flex-direction:column;min-width:200px}.user-management-search{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);padding:8px 12px}.search-hint{color:var(--text-muted);font-size:11px;font-style:italic;margin-top:2px}.user-management-role-filter{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);min-width:150px;padding:8px 12px}.add-user-btn{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s}.add-user-btn:hover{background-color:#0056b3}.add-user-btn:disabled{background-color:#6c757d;cursor:not-allowed}.user-table-container{margin-bottom:20px;overflow-x:auto}.user-table{border-collapse:collapse;font-size:14px;width:100%}.user-table th{background-color:var(--bg-tertiary);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:12px;text-align:left}.user-table td{border-bottom:1px solid var(--border-color);padding:12px}.user-table tbody tr:hover{background-color:var(--bg-tertiary)}.user-role-badge{border-radius:4px;display:inline-block;font-size:12px;font-weight:600;padding:4px 8px}.user-role-badge.full-admin{background-color:#dc3545;color:#fff}.user-role-badge.org-admin{background-color:#ffc107;color:#000}.user-role-badge.site-admin{background-color:#17a2b8;color:#fff}.user-actions{display:flex;gap:8px}.user-action-btn{border:none;border-radius:4px;cursor:pointer;font-size:12px;padding:4px 8px;transition:opacity .2s}.user-action-btn:hover{opacity:.8}.user-action-btn:disabled{cursor:not-allowed;opacity:.5}.user-action-btn.edit{background-color:#007bff;color:#fff}.user-action-btn.delete{background-color:#dc3545;color:#fff}.user-action-btn.orgs{background-color:#28a745;color:#fff}.unusable-user-row{background-color:#dc35450d;opacity:.7}.unusable-badge{background-color:#dc3545;border-radius:12px;color:#fff;display:inline-block;font-size:.7em;font-weight:600;letter-spacing:.5px;margin-left:8px;padding:2px 8px;text-transform:uppercase;vertical-align:middle}.unusable-badge.clickable{cursor:pointer;transition:background-color .2s,transform .1s}.unusable-badge.clickable:hover{background-color:#28a745;transform:scale(1.05)}.unusable-badge.clickable:active{transform:scale(.98)}.user-pagination{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:20px}.pagination-btn{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:6px 12px}.pagination-btn:disabled{background-color:#6c757d;cursor:not-allowed}.pagination-info{color:var(--text-secondary);font-size:14px}.user-management-message{border-radius:4px;font-size:14px;margin-bottom:20px;padding:12px}.user-management-message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.user-management-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.user-management-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:60px 40px;text-align:center}.user-management-loading:before{animation:spin 1s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top:4px solid #007bff;content:"";height:50px;margin-bottom:20px;width:50px}.user-management-loading:after{color:var(--text-primary);content:"Loading users...";display:block;font-size:18px;font-weight:600}.user-management-empty{color:var(--text-secondary);padding:40px;text-align:center}.close-btn{background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px}.close-btn:hover{background-color:#5a6268}.hamburger-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea66,0 2px 4px #0003;cursor:pointer;display:flex;flex-direction:column;gap:5px;height:56px;justify-content:center;left:20px;padding:8px;position:fixed;top:20px;transition:all .3s cubic-bezier(.4,0,.2,1);width:56px;z-index:1001}.hamburger-button:hover{background:linear-gradient(135deg,#7c94f5,#8b5dc7);box-shadow:0 6px 16px #667eea80,0 4px 8px #0000004d;transform:translateY(-2px) scale(1.05)}.hamburger-button:active{box-shadow:0 2px 8px #667eea4d;transform:translateY(0) scale(.98)}.hamburger-line{background-color:#fff;border-radius:3px;box-shadow:0 1px 2px #0003;height:3px;transition:all .3s cubic-bezier(.4,0,.2,1);width:32px}.hamburger-button.open{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 12px #f5576c66,0 2px 4px #0003}.hamburger-button.open .hamburger-line:first-child{transform:rotate(45deg) translate(8px,8px)}.hamburger-button.open .hamburger-line:nth-child(2){opacity:0;transform:scale(0)}.hamburger-button.open .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}.hamburger-overlay{animation:fadeIn .3s ease;background:#00000080;height:100%;left:0;position:fixed;top:0;width:100%;z-index:999}.hamburger-menu,.hamburger-menu-container{position:fixed;z-index:1000}.hamburger-menu{background:var(--body-bg);border-right:2px solid var(--border-color);box-shadow:4px 0 12px #0000004d;display:flex;flex-direction:column;height:100vh;left:-405px;top:0;transition:left .3s ease;width:385px}.hamburger-menu.open{left:0}.menu-header{align-items:center;background:var(--header-bg);border-bottom:2px solid var(--border-color);display:flex;justify-content:space-between;padding:20px 20px 20px 90px}.menu-header h2{color:var(--text-color);font-size:1.5rem;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-color);cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;transition:all .2s ease;width:40px}.close-button:hover{background:var(--button-bg);transform:scale(1.1)}.menu-body{flex:1 1;overflow-x:hidden;overflow-y:auto}.menu-links{list-style:none;margin:0;padding:0}.menu-links li{border-bottom:1px solid var(--border-color)}.menu-links li.menu-divider{background:var(--border-color);border-bottom:none;height:1px;margin:8px 0}.menu-links li:last-child{border-bottom:none}.menu-links .menu-button,.menu-links a{align-items:center;background:none;border:none;color:var(--text-color);cursor:pointer;display:flex;font-family:inherit;font-size:1rem;gap:15px;min-height:64px;padding:20px;text-align:left;text-decoration:none;transition:all .2s ease;width:100%}.menu-links .menu-button:hover,.menu-links a:hover{background:var(--button-bg);padding-left:25px}.menu-links .menu-button:active,.menu-links a:active{background:var(--border-color)}.link-icon{font-size:1.5rem;min-width:30px;text-align:center}.link-text{word-wrap:break-word;align-items:center;display:flex;flex:1 1;font-size:1rem;gap:8px;line-height:1.2}.menu-links>li>a[href*="developersupport.allegion.com"]{min-height:44px;padding:12px 20px}.device-count-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:inline-flex;font-size:.75rem;font-weight:700;height:20px;justify-content:center;min-width:20px;padding:2px 8px}.menu-button:disabled{cursor:not-allowed;opacity:.5}.menu-button:disabled:hover{background:none;padding-left:20px}.menu-footer{background:var(--body-bg);border-top:2px solid var(--border-color);box-shadow:0 -4px 8px #00000026;flex-shrink:0;padding:0}.submenu-container,.submenu-toggle{position:relative}.submenu-toggle{justify-content:space-between}.submenu-arrow{font-size:.75rem;margin-left:auto;transition:transform .3s ease}.submenu-arrow.open{transform:rotate(90deg)}.submenu{background:var(--bg-secondary);list-style:none;margin:0;max-height:0;overflow:hidden;padding:0;transition:max-height .3s ease}.submenu.open{max-height:500px}.submenu li{border-bottom:1px solid var(--border-color-subtle)}.submenu li:last-child{border-bottom:none}.submenu .menu-button,.submenu a{font-size:.95rem;min-height:56px;padding:16px 20px 16px 60px}.submenu .menu-button:hover,.submenu a:hover{background:var(--button-bg);padding-left:65px}.submenu .link-icon{font-size:1.25rem}body.light-mode .submenu{background:#f5f5f5}body.light-mode .submenu a:hover{background:#e0e0e0}.user-email{background:var(--body-bg);border-bottom:1px solid var(--border-color);color:#888;color:var(--text-muted,#888);font-size:.9rem;gap:10px;padding:16px 20px 16px 10px}.user-details,.user-email{align-items:flex-start;display:flex}.user-details{flex:1 1;flex-direction:column;gap:8px;min-width:0}.badges-row{align-items:center;display:flex;gap:10px;justify-content:space-between;width:100%}.email-icon{flex-shrink:0;font-size:2rem;line-height:1;min-width:32px;opacity:.8;text-align:center}.email-button{word-wrap:break-word;background:none;border:none;color:var(--text-color);cursor:pointer;font-family:inherit;font-size:.95rem;line-height:1.5;overflow-wrap:break-word;padding:0;text-align:left;text-decoration:underline;-webkit-text-decoration-color:#0000;text-decoration-color:#0000;transition:all .2s ease}.email-button:hover{opacity:.8;-webkit-text-decoration-color:var(--text-color);text-decoration-color:var(--text-color)}.user-role{align-items:center;align-self:flex-start;background:#ffffff0d;border:1px solid #ffffff1a;border:1px solid var(--border-color-subtle,#ffffff1a);border-radius:9px;color:#888;color:var(--text-muted,#888);display:inline-flex;font-size:1.2rem;height:-webkit-fit-content;height:fit-content;line-height:1;padding:11px 20px}.logout-button{align-items:center;background:none;border:none;color:var(--text-color);cursor:pointer;display:flex;font-size:1rem;gap:15px;padding:20px;text-align:left;transition:all .2s ease;width:100%}.logout-button:hover{background:#f44;color:#fff;padding-left:25px}.logout-button:active{background:#c00}.logout-button .link-icon{font-size:1.5rem;min-width:30px;text-align:center}.logout-button .link-text{font-size:1rem;line-height:1.4}@media (max-width:768px){.hamburger-button{height:50px;left:15px;top:15px;width:50px}.hamburger-line{width:28px}.hamburger-menu{left:-340px;overflow-y:auto;width:340px}.menu-body{flex:initial;overflow-y:visible}.menu-footer{box-shadow:none}.menu-header{padding:20px 20px 20px 80px}.menu-header h2{font-size:1.3rem}.link-text{font-size:.95rem}}@media (max-width:480px){.hamburger-button{height:46px;width:46px}.hamburger-menu{left:-100%;max-width:300px;width:85%}.menu-header{padding:15px 15px 15px 70px}}.dark-mode .hamburger-menu{background:#121212;border-right-color:#333}.dark-mode .menu-header{background:#1a1a1a}.dark-mode .menu-header,.dark-mode .menu-links li{border-bottom-color:#333}.dark-mode .menu-links a:hover{background:#2a2a2a}.dark-mode .hamburger-overlay{background:#000000b3}.light-mode .hamburger-menu{background:#f5f5f5;border-right-color:#ddd}.light-mode .menu-header{background:#fff;border-bottom-color:#ddd}.light-mode .menu-links li{border-bottom-color:#e0e0e0}.light-mode .menu-links a:hover{background:#e8e8e8}.light-mode .hamburger-overlay{background:#0006}.close-button:focus,.hamburger-button:focus,.logout-button:focus,.menu-links a:focus{outline:3px solid gold;outline-offset:3px}@media (prefers-reduced-motion:reduce){.hamburger-button,.hamburger-line,.hamburger-menu,.hamburger-overlay,.menu-links a{transition:none}.hamburger-button:hover{transform:none}}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#000000b3;border-radius:8px;bottom:0;display:flex;gap:8px;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.hourglass-flip{animation:spin 2s linear infinite;display:inline-block;font-size:20px}.loading-text{color:#fff;font-size:12px;font-weight:600;text-shadow:0 1px 2px #0000004d}.header-logo{cursor:pointer;height:150px;transition:opacity .2s ease-in-out;width:auto}.header-logo:hover{opacity:.85}@media (max-width:1280px){.header-logo{height:100px}}@media (max-width:768px){.header-logo{height:100px}}.org-install-display{align-items:center;background:#0000;border:none;border-radius:8px;color:#333;color:var(--text-color,#333);display:flex;gap:32px;max-width:-webkit-fit-content;max-width:fit-content;padding:16px 24px}.org-install-item{align-items:center;display:flex;flex-direction:column;gap:4px}.org-install-content{align-items:baseline;display:flex;flex-direction:row;gap:8px}.org-install-label{color:#666;color:var(--text-secondary,#666);font-size:21px;font-weight:700}.org-install-value{color:#1976d2;color:var(--primary-color,#1976d2);font-size:21px;font-weight:700;line-height:1.2}.org-install-id{color:#888;color:var(--text-secondary,#888);font-family:monospace;font-size:13px;font-weight:400;text-align:center}.org-install-id-row{align-items:center;display:flex;gap:3px;justify-content:center}.copy-icon-button{font-size:14px;opacity:.6;padding:2px;transition:opacity .2s ease}.copy-icon-button:active{transform:scale(.95)}.org-install-divider{color:#ccc;color:var(--border-color,#ccc);font-size:42px;font-weight:300;line-height:1}[data-theme=dark-mode] .org-install-display{background:#0000}[data-theme=dark-mode] .org-install-label{color:#b0b0b0;color:var(--text-secondary,#b0b0b0)}[data-theme=dark-mode] .org-install-value{color:#64b5f6;color:var(--primary-color,#64b5f6)}[data-theme=dark-mode] .org-install-id{color:#777;color:var(--text-secondary,#777)}[data-theme=dark-mode] .org-install-divider{color:#666;color:var(--border-color,#666)}@media (max-width:768px){.org-install-display{flex-direction:column;gap:16px;padding:12px 16px}.org-install-value{font-size:32px}.org-install-divider{display:none}.org-install-label{font-size:14px}.org-install-id{font-size:12px}}@media (max-width:1280px){.org-install-display{flex-direction:column;gap:10px;max-width:100%;padding:10px 15px;width:100%}.org-install-divider{display:none}.org-install-item{width:100%}.org-install-label,.org-install-value{font-size:1.4rem;font-weight:700}.copy-icon-button,.org-install-id{display:none}}.view-switcher-container{background:var(--background-color);display:flex;justify-content:center;padding:22px 0 15px}.view-switcher{align-items:center;display:flex;font-size:24px;font-weight:500;gap:24px;padding:5px 48px}.view-option{transition:all .2s ease}.view-option.active{color:var(--accent-color);cursor:default;font-weight:600}.view-option.inactive{color:var(--text-color);cursor:pointer;text-decoration:underline}.view-option.inactive:hover{color:var(--accent-color);text-decoration:none}.view-separator{color:var(--text-muted);-webkit-user-select:none;user-select:none}@media (max-width:768px){.view-switcher-container{padding:24px 0}.view-switcher{font-size:20px;gap:18px;padding:0 36px}}.device-state-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;text-align:left;width:100%}.device-state-container h2{align-items:center;background-color:var(--bg-header-dark);border-bottom:1px solid var(--border-color);color:var(--accent-color);cursor:pointer;display:flex;justify-content:space-between;margin:0;padding:10px 15px;-webkit-user-select:none;user-select:none}body.light-mode .device-state-container h2{background-color:var(--bg-header-light)}.last-update-time{color:#888;font-size:.7rem;font-weight:400;margin-left:0;margin-top:4px}.state-grid{grid-gap:10px 20px;display:grid;gap:10px 20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));padding:15px}.state-item{align-items:center;border-bottom:1px solid var(--border-color-subtle);display:flex;justify-content:flex-start;padding:5px 0}.state-label{align-items:flex-start;display:flex;flex-direction:column;font-weight:700;margin-right:10px}.state-value{align-items:center;color:var(--text-primary);display:flex;font-size:.9rem;font-weight:400;gap:8px;text-align:left}.device-id-text,.state-value{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-id-text{flex:1 1}.state-value .copy-icon-button{flex-shrink:0}.status-online{color:var(--status-success);font-weight:700}.status-offline{color:var(--status-error);font-weight:700}.state-passage{color:var(--status-success);font-weight:700}.state-secured{color:var(--status-error);font-weight:700}.state-not-sampled{color:var(--text-muted);font-style:italic}.battery-normal{color:var(--status-success);font-weight:700}.battery-low{color:var(--status-warning);font-weight:700}.battery-critical{animation:pulse 1.5s ease-in-out infinite;color:var(--status-error);font-weight:700}.deadbolt-secured{color:red;font-weight:700}.deadbolt-passage{color:#4a4;font-weight:700}.deadbolt-other,.door-position-open{color:#ff9800;font-weight:700}.door-position-shut{color:var(--status-success);font-weight:700}.edit-display-name-button{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:1rem;line-height:1;margin:0;opacity:.7;padding:0 4px;transition:opacity .2s,color .2s}.edit-display-name-button:hover{color:var(--accent-color-hover);opacity:1}.state-lockdown-on{animation:blink 1s infinite;color:red;font-weight:700}.state-lockdown-off{color:#4a4;font-weight:700}.state-frozen-secured{color:red;font-weight:700}.state-frozen-passage{color:#4a4;font-weight:700}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes flash{0%,to{opacity:1}50%{opacity:.5}}.id-copied-tooltip{animation:fadeInOut 1s ease-in-out;background-color:var(--accent-color);border-radius:4px;box-shadow:0 2px 8px #0000004d;color:#fff;font-size:.85rem;font-weight:600;padding:6px 12px;pointer-events:none;position:fixed;transform:translateX(-50%);white-space:nowrap;z-index:10000}@keyframes fadeInOut{0%{opacity:0;transform:translateX(-50%) translateY(10px)}20%{opacity:1;transform:translateX(-50%) translateY(0)}80%{opacity:1;transform:translateX(-50%) translateY(0)}to{opacity:0;transform:translateX(-50%) translateY(-10px)}}.setting-enabled{color:var(--status-success);font-weight:600}.setting-disabled{color:var(--status-error);font-weight:600}.device-state-section-header{border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.85rem;font-weight:700;grid-column:1/-1;letter-spacing:.05em;margin-top:.5rem;padding:.75rem 0 .25rem;text-transform:uppercase}.device-state-section-header--clickable{align-items:center;cursor:pointer;display:flex;justify-content:space-between;-webkit-user-select:none;user-select:none}.device-state-section-header--clickable:hover{color:#e5e7eb;color:var(--text-primary,#e5e7eb)}.section-collapse-icon{font-size:.7rem;opacity:.7}.device-state-chips-bar{border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:6px;grid-column:1/-1;margin-top:4px;padding:8px 0 4px}.device-state-section-chip{align-items:center;background:#0000;border:1px solid var(--border-color);border-radius:20px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.72rem;font-weight:700;gap:5px;letter-spacing:.05em;padding:3px 10px 3px 12px;text-transform:uppercase;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.device-state-section-chip:hover{background:#ffffff12;border-color:var(--accent-color);color:var(--accent-color)}.chip-expand-icon{font-size:.6rem;opacity:.7}.device-settings-container .device-state-section-header{grid-column:1/-1}.last-action-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:0;text-align:left;width:100%}.last-action-header{align-items:center;background-color:var(--bg-header-dark);border-bottom:1px solid var(--border-color);border-top-left-radius:7px;border-top-right-radius:7px;cursor:grab;display:flex;justify-content:space-between;padding:10px 15px;-webkit-user-select:none;user-select:none}body.light-mode .last-action-header{background-color:var(--bg-header-light)}.last-action-header:active{cursor:grabbing}.last-action-header h2.header-title-area{align-items:center;background-color:initial;border:none;color:var(--accent-color);display:flex;flex-grow:1;margin:0;padding:0;-webkit-user-select:none;user-select:none}.info-tooltip{align-items:center;cursor:help;display:inline-flex;margin-left:8px;position:relative}.info-icon{align-items:center;border:1px solid var(--text-muted);border-radius:50%;color:var(--text-muted);display:flex;font-size:.8em;height:1em;justify-content:center;line-height:1;transition:color .2s,border-color .2s;width:1em}.info-tooltip:hover .info-icon{border-color:var(--accent-color);color:var(--accent-color)}.info-tooltip .tooltip-text{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;bottom:160%;box-shadow:0 3px 8px var(--shadow-color);color:var(--text-primary);cursor:default;font-size:.9rem;font-weight:400;left:50%;line-height:1.4;margin-left:-125px;opacity:0;padding:10px 12px;position:absolute;text-align:left;transition:opacity .3s ease,visibility 0s linear .3s;-webkit-user-select:text;user-select:text;visibility:hidden;width:250px;z-index:10}.info-tooltip .tooltip-text:after{border-color:var(--bg-tertiary) #0000 #0000 #0000;border-style:solid;border-width:6px;content:"";left:50%;margin-left:-6px;position:absolute;top:100%}.info-tooltip .tooltip-text:before{border-color:var(--border-color) #0000 #0000 #0000;border-style:solid;border-width:7px;content:"";left:50%;margin-left:-7px;position:absolute;top:100%;z-index:-1}.info-tooltip:hover .tooltip-text{opacity:1;transition:opacity .3s ease;visibility:visible}.action-history-controls.header-controls-area{align-items:center;border:none;color:var(--text-secondary);cursor:default;display:flex;flex-shrink:0;font-size:.85rem;gap:8px;margin:0 15px;padding:0}.action-history-controls.header-controls-area label{color:var(--text-secondary);font-weight:400}.history-limit-input{background-color:var(--bg-input);border:1px solid var(--border-color-light);border-radius:4px;color:var(--text-primary);cursor:text;font-size:.85rem;padding:3px 6px;text-align:center;width:45px}.header-collapse-icon-area{color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-size:1rem;padding:5px}.status-resolved{color:var(--status-success);font-weight:700}.status-rejected{color:#ff4d4d;font-weight:700}.status-timeout{color:#f90;font-weight:700}.emoji-large{font-size:1.6rem}.spinner{border:3px solid var(--border-color);border-left-color:var(--accent-color);display:inline-block;height:16px;vertical-align:middle;width:16px}.cloud-reaction-time{color:var(--status-success);font-weight:700}.action-history-list{-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:0;overflow-x:auto;padding:15px}.action-item-divider{border:none;border-top:1px dashed var(--border-color-subtle);margin:15px 0}.action-grid{grid-gap:15px 15px;align-items:center;display:grid;gap:15px 15px;grid-template-columns:minmax(180px,1fr) minmax(280px,1.2fr) minmax(120px,.8fr) minmax(140px,1fr) minmax(140px,1fr) minmax(140px,1fr) minmax(140px,1fr);min-width:1140px;padding-bottom:5px;width:100%}@media (max-width:768px){.action-grid{gap:10px 10px;grid-template-columns:minmax(140px,1fr) minmax(220px,1.2fr) minmax(100px,.8fr) minmax(120px,1fr) minmax(120px,1fr) minmax(120px,1fr) minmax(120px,1fr);min-width:960px}.action-label,.action-value{font-size:.85rem}}.action-label{color:var(--accent-color);font-size:.8rem;font-weight:700;padding-bottom:8px;white-space:nowrap}.action-label,.action-value{border-bottom:1px solid var(--border-color-subtle)}.action-value{word-wrap:break-word;align-items:center;color:var(--text-primary);display:flex;font-size:.9rem;font-weight:400;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;max-width:100%;min-height:40px;overflow-wrap:break-word;padding:8px 0;text-align:left;word-break:break-word}.no-actions-message{color:var(--text-muted);font-style:italic;padding:20px 0;text-align:center}.history-limit-input::-webkit-inner-spin-button,.history-limit-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.history-limit-input[type=number]{-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.copy-icon-button{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;line-height:1;margin:0 0 0 8px;opacity:.7;padding:0 4px;transition:opacity .2s,color .2s,transform .1s;vertical-align:middle}.copy-icon-button:hover{color:var(--accent-color);opacity:1}.copy-icon-button:active{transform:scale(.9)}.device-actions-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;text-align:left;width:100%}.device-actions-container h2{align-items:center;background-color:var(--bg-header-dark);border-bottom:1px solid var(--border-color);color:var(--accent-color);cursor:pointer;display:flex;justify-content:space-between;margin:0;padding:10px 15px;-webkit-user-select:none;user-select:none}body.light-mode .device-actions-container h2{background-color:var(--bg-header-light)}.collapse-icon{font-size:1rem}.actions-buttons{align-items:flex-start;display:flex;flex-direction:row;gap:15px;padding:15px}.action-button{background-color:var(--accent-color);border:none;border-radius:5px;color:var(--text-on-accent);cursor:pointer;flex:1 1;font-size:.9rem;font-weight:700;min-width:0;overflow:hidden;padding:10px 15px;text-overflow:ellipsis;transition:background-color .2s,opacity .2s;white-space:nowrap}.action-button:hover{background-color:var(--accent-color-hover)}.action-button:disabled{background-color:var(
    --accent-color-disabled
  );cursor:not-allowed;opacity:.6}.action-button.working{background-color:var(--bg-button-disabled);color:var(--text-on-disabled);cursor:wait}.action-button.settings-button{background:linear-gradient(135deg,#6a11cb,#2575fc);color:#fff;font-weight:600}.action-button.settings-button:hover:not(:disabled){background:linear-gradient(135deg,#2575fc,#6a11cb);box-shadow:0 4px 12px #2575fc66}.action-button.settings-button.working{background:linear-gradient(135deg,#888,#666);cursor:wait}.simplified-device-actions-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin:0 auto 20px;max-width:1200px;padding:24px;text-align:center;width:1200px}.simplified-device-actions-container h2{color:var(--accent-color);font-size:1.8rem;font-weight:600;margin:0 0 24px}.simplified-actions-buttons{align-items:stretch;display:flex;flex-direction:row;gap:20px;justify-content:center}.simplified-action-button{align-items:center;background-color:var(--accent-color);border:none;border-radius:10px;box-shadow:0 2px 8px #00000026;color:var(--text-on-accent);cursor:pointer;display:flex;flex:1 1;font-size:1.4rem;font-weight:700;justify-content:center;max-width:300px;min-height:80px;padding:24px 32px;transition:all .2s ease}.simplified-action-button:hover:not(:disabled){background-color:var(--accent-color-hover);box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.simplified-action-button:active:not(:disabled){box-shadow:0 2px 6px #00000026;transform:translateY(0)}.simplified-action-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.simplified-action-button.working{cursor:wait;opacity:.7}.simplified-action-button.secondary-action{background-color:var(--accent-color)}.simplified-action-button.secondary-action:hover:not(:disabled){background-color:var(--accent-color-hover)}@media (max-width:1280px){.simplified-device-actions-container{margin:0 20px 20px;max-width:calc(100% - 40px);width:calc(100% - 40px)}}@media (max-width:768px){.simplified-device-actions-container{margin:0 20px 20px;max-width:calc(100% - 40px);padding:20px;width:calc(100% - 40px)}.simplified-device-actions-container h2{font-size:1.5rem;margin-bottom:20px}.simplified-actions-buttons{flex-direction:column;gap:16px}.simplified-action-button{font-size:1.2rem;max-width:none;min-height:60px;padding:20px 24px}}@media (max-width:480px){.simplified-action-button{min-height:56px;padding:18px 20px}}.simplified-device-state-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin:0 auto 20px;max-width:1200px;padding:24px;width:1200px}.simplified-device-state-container h2{color:var(--accent-color);font-size:1.8rem;font-weight:600;margin:0 0 24px;text-align:center}.simplified-state-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.simplified-state-item{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:20px}.simplified-state-label{color:var(--text-secondary);font-size:1.1rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.simplified-state-value{color:var(--text-color);font-size:1.6rem;font-weight:700;word-break:break-word}.simplified-state-passage{color:#28a745;font-weight:800}.simplified-state-secured{color:#dc3545;font-weight:800}.simplified-state-frozen-passage{color:#17a2b8;font-weight:800}.simplified-state-frozen-secured{color:#6610f2;font-weight:800}.simplified-door-position-open{color:#ffc107;font-weight:800}.simplified-battery-normal,.simplified-door-position-shut{color:#28a745;font-weight:800}.simplified-battery-low{color:#ffc107;font-weight:800}.simplified-battery-critical,.simplified-deadbolt-secured{color:#dc3545;font-weight:800}.simplified-deadbolt-passage{color:#28a745;font-weight:800}.simplified-deadbolt-other{color:#ffc107;font-weight:800}.simplified-status-online{color:#28a745;font-weight:800}.simplified-state-lockdown-on,.simplified-status-offline{color:#dc3545;font-weight:800}.simplified-state-lockdown-off{color:#28a745;font-weight:800}@media (max-width:1280px){.simplified-state-grid{grid-template-columns:repeat(2,1fr);max-width:100%}.simplified-device-state-container{margin:0 20px 20px;max-width:calc(100% - 40px);width:calc(100% - 40px)}}@media (max-width:768px){.simplified-device-state-container{margin:0 20px 20px;max-width:calc(100% - 40px);padding:20px;width:calc(100% - 40px)}.simplified-device-state-container h2{font-size:1.5rem;margin-bottom:20px}.simplified-state-grid{gap:16px;grid-template-columns:1fr;max-width:100%}.simplified-state-item{padding:16px}.simplified-state-label{font-size:1rem}.simplified-state-value{font-size:1.4rem}}@media (max-width:480px){.simplified-state-item{padding:14px}.simplified-state-label{font-size:.95rem}.simplified-state-value{font-size:1.3rem}}.loading-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.loading-modal-content{align-items:center;color:#fff;display:flex;flex-direction:column;font-size:1.4rem;text-align:center}.loading-modal-content p{margin-bottom:5px}.loading-modal-content small{color:#ccc;font-size:1.1rem}.loading-modal-content .loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:40px;margin-bottom:15px;width:40px}.device-management-container{width:100%}.device-management-container.simplified-view{padding:1rem}.device-management-container.detailed-view{display:flex;flex-direction:column;gap:0}.device-management-container section{width:100%}.device-management-container .content-divider{border:none;border-top:1px solid #444;border-top:1px solid var(--border-color,#444);margin:1.5rem 0}.device-management-container>div:first-child .content-divider{margin-top:0}@media (max-width:768px){.device-management-container.simplified-view{padding:.5rem}.device-management-container .content-divider{margin:1rem 0}}.device-card-option{padding:.5rem}.device-card-option.selected{background-color:#667eea;background-color:var(--accent-color,#667eea);color:#fff}.device-list-container{align-items:center;border-radius:8px;display:flex;gap:1rem;margin-bottom:.25rem;margin-left:auto;margin-right:auto;max-width:800px;padding:.5rem 1rem}.device-list-container,.device-list-container.simplified-view{background-color:initial}.device-list-container label{font-size:24px;font-weight:600;white-space:nowrap}.device-list-container .device-selector{background-color:#1a1a1a;background-color:var(--bg-color,#1a1a1a);border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:4px;color:#e0e0e0;color:var(--text-color,#e0e0e0);cursor:pointer;flex:1 1;font-size:24px;font-weight:600;padding:.5rem}.device-list-container .device-selector:disabled{cursor:not-allowed;opacity:.5}.device-list-container .refresh-button{background-color:#667eea;background-color:var(--accent-color,#667eea);border:1px solid #667eea;border:1px solid var(--accent-color,#667eea);border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.device-list-container .refresh-button:hover:not(:disabled){background-color:#5568d3;background-color:var(--accent-color-hover,#5568d3);transform:translateY(-1px)}.device-list-container .refresh-button:disabled{cursor:not-allowed;opacity:.6}.device-list-container .refresh-spinner{animation:spin 1s linear infinite;display:inline-block}.device-list-container.no-devices{flex-direction:column;padding:2rem;text-align:center}.no-devices-message{align-items:center;display:flex;flex-direction:column;gap:1rem}.no-devices-message p{color:var(--text-primary);font-size:1.1rem;margin:0}@media (max-width:768px){.device-list-container{align-items:stretch;flex-direction:column}.device-list-container label{text-align:center}.device-list-container .device-selector,.device-list-container .refresh-button{width:100%}}.duplicate-error-overlay{align-items:center;animation:fadeIn .2s ease-in;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.duplicate-error-modal{background:#1e1e1e;background:var(--background-secondary,#1e1e1e);border:2px solid #e74c3c;border:2px solid var(--error-color,#e74c3c);border-radius:12px;box-shadow:0 8px 32px #0006;max-height:90vh;max-width:600px;opacity:1!important;overflow-y:auto;width:90%}.duplicate-error-header{align-items:center;background:#e74c3c1a;background:var(--error-bg,#e74c3c1a);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:20px 24px}.duplicate-error-header h2{align-items:center;color:#e74c3c;color:var(--error-color,#e74c3c);display:flex;font-size:1.3rem;gap:10px;margin:0}.duplicate-error-header .close-button{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:all .2s;width:30px}.duplicate-error-header .close-button:hover{background:#ffffff1a;color:var(--text-primary)}.duplicate-error-content{padding:24px}.error-message{border-left:4px solid #e74c3c;border-left:4px solid var(--error-color,#e74c3c);color:var(--text-primary);font-size:1rem;line-height:1.6;margin:0 0 24px}.error-details,.error-message{background:var(--background-primary);border-radius:8px;padding:16px}.error-details{margin-bottom:20px}.detail-row{border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:10px 0}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-secondary);flex:0 0 40%;font-weight:600}.detail-value{color:var(--text-primary);flex:1 1;text-align:right;word-break:break-word}.copy-error-button{align-items:center;background:var(--accent-color);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s;width:100%}.copy-error-button:hover{background:var(--accent-color-hover);box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.copy-error-button:active{transform:translateY(0)}.duplicate-error-footer{border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;padding:16px 24px}.close-modal-button{background:var(--background-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:1rem;padding:10px 24px;transition:all .2s}.close-modal-button:hover{background:var(--background-secondary);border-color:var(--accent-color)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}body.light-mode .duplicate-error-modal{background:#fff;border-color:#e74c3c;opacity:1}body.light-mode .duplicate-error-header{background:#e74c3c0d;border-bottom-color:#e0e0e0}body.light-mode .error-message{background:#f8f9fa;border-left-color:#e74c3c}body.light-mode .error-details{background:#f8f9fa}body.light-mode .detail-row{border-bottom-color:#e0e0e0}body.light-mode .duplicate-error-footer{border-top-color:#e0e0e0}.patron-form-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:9999}.patron-form-modal{background-color:var(--bg-primary);border-radius:12px;box-shadow:0 8px 32px #0000004d;max-height:90vh;max-width:700px;overflow-y:auto;position:relative;width:100%}.patron-form-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;justify-content:center;padding:1.5rem 2rem;position:relative}.patron-form-header h2{color:var(--accent-color);font-size:1.75rem;margin:0}.patron-form-header .close-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:2rem;left:1rem;line-height:1;padding:.5rem;position:absolute;top:50%;transform:translateY(-50%);transition:color .2s ease}.patron-form-header .close-button:hover{color:var(--accent-color);transform:translateY(-50%)}.modal-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;justify-content:center;padding:1.5rem 2rem;position:relative}.modal-header h2{color:var(--accent-color);font-size:1.75rem;margin:0}.modal-header .close-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:2rem;left:1rem;line-height:1;padding:.5rem;position:absolute;top:50%;transform:translateY(-50%);transition:color .2s ease}.modal-header .close-button:hover{color:var(--accent-color);transform:translateY(-50%)}.patron-form{padding:2rem}.form-row{display:flex;gap:1rem;margin-bottom:1rem}.form-row .form-group{flex:1 1;margin-bottom:0}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-primary);display:block;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.required{color:#dc3545}.form-group input[type=email],.form-group input[type=tel],.form-group input[type=text]{background-color:var(--bg-input);border:1px solid var(--border-color-light);border-radius:5px;box-sizing:border-box;color:var(--text-primary);font-size:1rem;padding:.75rem 1rem;transition:border-color .2s ease;width:100%}.phone-input-container{display:flex;gap:8px}.country-code-select{cursor:pointer;flex:0 0 auto;min-width:90px;padding:.75rem .5rem}.country-code-select,.phone-number-input{background-color:var(--bg-input);border:1px solid var(--border-color-light);border-radius:5px;color:var(--text-primary);font-size:1rem;transition:border-color .2s ease}.phone-number-input{flex:1 1;padding:.75rem 1rem}.country-code-select:focus,.form-group input:focus,.phone-number-input:focus{border-color:var(--accent-color);outline:none}.form-group input:disabled{background-color:#8080801a;color:var(--text-muted);cursor:not-allowed;opacity:.7}.form-group input.error{border-color:#dc3545}.error-text{color:#dc3545}.error-text,.help-text{display:block;font-size:.85rem;margin-top:.25rem}.help-text{color:var(--text-secondary);font-style:italic}.photo-upload-container{align-items:flex-start;display:flex;gap:1.5rem}.photo-preview{flex-shrink:0}.photo-preview img{border:2px solid var(--border-color);border-radius:8px;height:150px;object-fit:cover;width:150px}.photo-upload-controls{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.file-input{display:none}.file-input-label{background-color:var(--accent-color);border-radius:5px;color:#fff;cursor:pointer;display:inline-block;font-weight:600;padding:.75rem 1.5rem;text-align:center;transition:all .2s ease}.file-input-label:hover{background-color:var(--accent-color-hover);transform:translateY(-1px)}.form-error{background-color:#dc35451a;border:1px solid #dc3545;border-radius:5px;color:#dc3545;margin-bottom:1rem;padding:1rem}.form-actions{border-top:1px solid var(--border-color-light);display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}.cancel-button,.submit-button{border:none;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .2s ease}.cancel-button{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.cancel-button:hover:not(:disabled){background-color:var(--bg-hover)}.submit-button{align-items:center;background-color:#28a745;color:#fff;display:flex;gap:.5rem}.submit-button:hover:not(:disabled){background-color:#218838;transform:translateY(-1px)}.cancel-button:disabled,.submit-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.spinner-small{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;width:16px}@media (max-width:768px){.patron-form-modal{border-radius:0;max-height:100vh;max-width:100%}.patron-form,.patron-form-header{padding:1rem}.form-row{grid-template-columns:1fr}.photo-upload-container{flex-direction:column}.form-actions{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}}.patron-number-display{background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.patron-number-display label{color:var(--text-secondary);font-size:.875rem;margin-bottom:.25rem}.patron-number-value{color:var(--accent-color);font-family:Courier New,Courier,monospace;font-size:1.5rem;font-weight:700;letter-spacing:.1em}.radio-group{display:flex;gap:1.5rem;margin-top:.25rem}.radio-option{align-items:center;cursor:pointer;display:flex;font-weight:500;gap:.4rem}.radio-option input[type=radio]{accent-color:#667eea;accent-color:var(--accent-color,#667eea);cursor:pointer}.radio-description{color:#999;color:var(--text-secondary,#999);font-size:.8rem;font-weight:400}.confirm-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;left:0;position:fixed;right:0;top:0;z-index:9998}.confirm-modal{animation:slideIn .2s ease-out;background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0000004d;left:50%;max-width:550px;padding:30px;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:9999}.confirm-modal h2{border-bottom:2px solid var(--border-color);color:var(--accent-color);font-size:1.5rem;margin:0 0 20px;padding-bottom:15px;text-align:center}.confirm-modal-title-destructive{color:#dc3545!important}.confirm-modal-content{margin-bottom:25px}.confirm-modal-message{color:var(--text-primary);font-size:1.05rem;line-height:1.6;margin-bottom:20px;white-space:pre-line}.confirm-modal-message strong{color:var(--accent-color);font-weight:600}.confirm-modal-details{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:15px;padding:15px}.confirm-modal-details p{color:var(--text-secondary);font-size:.95rem;margin:8px 0}.confirm-modal-details strong{color:var(--accent-color);margin-right:8px}.confirm-modal-warning{background-color:#ffa5001a;border:1px solid #ffa5004d;border-radius:6px;margin-bottom:15px;padding:12px}.confirm-modal-warning p{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:5px 0}.confirm-modal-typed-confirmation{border-top:1px solid var(--border-color);margin-top:20px;padding-top:20px}.typed-confirmation-instruction{color:var(--text-primary);font-size:.95rem;margin-bottom:10px}.typed-confirmation-instruction strong{background-color:#dc35451a;border-radius:3px;color:#dc3545;font-family:monospace;font-size:1.1em;padding:2px 6px}.typed-confirmation-input{background-color:var(--bg-input);border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-family:monospace;font-size:1rem;padding:12px;transition:border-color .2s ease;width:100%}.typed-confirmation-input:focus{border-color:var(--accent-color);outline:none}.typed-confirmation-input::placeholder{color:var(--text-muted);opacity:.6}.confirm-modal-actions{display:flex;gap:12px;justify-content:flex-end}.confirm-modal-cancel-btn,.confirm-modal-confirm-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .2s ease}.confirm-modal-cancel-btn{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.confirm-modal-cancel-btn:hover:not(:disabled){background-color:var(--bg-primary);transform:translateY(-1px)}.confirm-modal-confirm-btn{background-color:var(--accent-color);color:#fff}.confirm-modal-confirm-btn:hover:not(:disabled){background-color:var(--accent-color-hover);transform:translateY(-1px)}.confirm-modal-confirm-btn.destructive{background-color:#dc3545}.confirm-modal-confirm-btn.destructive:hover:not(:disabled){background-color:#c82333}.confirm-modal-cancel-btn:disabled,.confirm-modal-confirm-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.add-credential-modal-backdrop{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1100}.add-credential-modal{animation:slideIn .2s ease-out;background:#1e1e1e;background:var(--modal-bg,#1e1e1e);border-radius:8px;box-shadow:0 4px 20px #00000080;display:flex;flex-direction:column;max-height:90vh;max-width:800px;width:100%}.add-credential-modal-header{border-bottom:1px solid #333;border-bottom:1px solid var(--border-color,#333);justify-content:space-between;padding:20px 24px}.add-credential-modal-header,.add-credential-modal-title-container{align-items:center;display:flex}.add-credential-modal-header h2{align-items:center;color:#e0e0e0;color:var(--text-color,#e0e0e0);display:flex;font-size:1.5rem;gap:8px;margin:0}.add-credential-modal-photo{border-radius:4px;height:1.5rem;object-fit:cover;width:auto}.add-credential-modal-close{align-items:center;background:none;border:none;color:#999;color:var(--text-secondary,#999);cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:color .2s;width:32px}.add-credential-modal-close:hover{color:#e0e0e0;color:var(--text-color,#e0e0e0)}.add-credential-modal-body{flex:1 1;overflow-y:auto;padding:24px}.credential-select-section{margin-bottom:24px}.credential-select-section label{display:block;margin-bottom:8px}.credential-select,.credential-select-section label{color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:1rem}.credential-select{background:#2a2a2a;background:var(--card-bg,#2a2a2a);border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:6px;cursor:pointer;padding:12px;transition:border-color .2s;width:100%}.credential-select:focus,.credential-select:hover:not(:disabled){border-color:#007bff;border-color:var(--accent-color,#007bff)}.credential-select:focus{box-shadow:0 0 0 3px #007bff1a;outline:none}.credential-select:disabled{cursor:not-allowed;opacity:.6}.device-select-section{margin-top:24px}.device-select-section>label{color:#e0e0e0;color:var(--text-color,#e0e0e0);display:block;font-size:1rem;margin-bottom:12px}.device-selection-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.device-selection-vertical{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto;padding-right:8px}.add-device-card{background:#3a3a3a;background:var(--badge-bg,#3a3a3a);border:2px solid #444;border:2px solid var(--border-color,#444);border-radius:6px;cursor:pointer;padding:12px;transition:all .2s}.add-device-card:hover:not(.device-already-has){border-color:#007bff;box-shadow:0 2px 8px #007bff33}.add-device-card.device-selected{background:#007bff1a;border-color:#007bff}.add-device-card.device-already-has{cursor:not-allowed;opacity:.5}.add-device-card-label{align-items:center;cursor:pointer;display:flex;gap:12px;width:100%}.add-device-checkbox{cursor:pointer;flex-shrink:0;height:18px;width:18px}.add-device-info{flex:1 1;min-width:0}.add-device-name{color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:.95rem;font-weight:600;line-height:1.3}.add-device-serial-inline{color:#999;color:var(--text-secondary,#999);font-family:monospace;font-size:.8rem;font-weight:400}.device-checkbox-label{align-items:center;background:#3a3a3a;background:var(--badge-bg,#3a3a3a);border:2px solid #444;border:2px solid var(--border-color,#444);border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:12px 16px;transition:all .2s;-webkit-user-select:none;user-select:none}.device-checkbox-label:hover:not(.device-already-has){background:#2a2a2a;background:var(--card-bg,#2a2a2a);border-color:#007bff;border-color:var(--accent-color,#007bff);box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.device-checkbox-label input[type=checkbox]{cursor:pointer;flex-shrink:0;height:18px;width:18px}.device-checkbox-label input[type=checkbox]:disabled{cursor:not-allowed}.device-checkbox-name{color:#e0e0e0;color:var(--text-color,#e0e0e0);flex:1 1;font-size:.95rem;font-weight:500}.device-already-has{background:#2a2a2a;background:var(--badge-bg,#2a2a2a);border-color:#333;border-color:var(--border-color,#333);cursor:not-allowed;opacity:.5}.device-already-has .device-checkbox-name{color:#999;color:var(--text-secondary,#999)}.device-already-badge{background:#f39c1233;border-radius:4px;color:#f39c12;flex-shrink:0;font-size:.8rem;font-weight:600;padding:4px 8px}.no-devices-message{color:#999;color:var(--text-secondary,#999);font-style:italic;padding:40px 20px;text-align:center}.add-credential-modal-footer{border-top:1px solid #333;border-top:1px solid var(--border-color,#333);display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.add-credential-cancel-btn,.add-credential-confirm-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;padding:10px 24px;transition:all .2s}.add-credential-cancel-btn{background-color:#555;background-color:var(--button-bg,#555);color:#e0e0e0;color:var(--text-color,#e0e0e0)}.add-credential-cancel-btn:hover:not(:disabled){background-color:#666;background-color:var(--button-hover-bg,#666)}.add-credential-confirm-btn{background-color:#2ecc71;color:#fff}.add-credential-confirm-btn:hover:not(:disabled){background-color:#27ae60;box-shadow:0 4px 12px #2ecc7166;transform:translateY(-2px)}.add-credential-cancel-btn:disabled,.add-credential-confirm-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.light-mode .add-credential-modal{--modal-bg:#fff;--card-bg:#f5f5f5;--badge-bg:#e8e8e8;--border-color:#ddd;--text-color:#333;--text-secondary:#666;--button-bg:#007bff;--button-hover-bg:#0056b3}@media (max-width:768px){.add-credential-modal{border-radius:0;max-height:100vh;max-width:100%}.add-credential-modal-backdrop{padding:0}.device-selection-grid{grid-template-columns:1fr}}.add-physical-credential-backdrop{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1200}.add-physical-credential-modal{background:#1e1e1e;background:var(--modal-bg,#1e1e1e);border-radius:8px;box-shadow:0 4px 20px #00000080;display:flex;flex-direction:column;max-height:90vh;max-width:480px;width:100%}.add-physical-credential-header{align-items:center;border-bottom:1px solid #333;border-bottom:1px solid var(--border-color,#333);display:flex;justify-content:space-between;padding:20px 24px}.add-physical-credential-header h2{color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:1.25rem;margin:0}.add-physical-credential-close-btn{background:none;border:none;color:#999;color:var(--text-secondary,#999);cursor:pointer;font-size:1.25rem;line-height:1;padding:4px 8px;transition:color .2s}.add-physical-credential-close-btn:hover:not(:disabled){color:#e0e0e0;color:var(--text-color,#e0e0e0)}.add-physical-credential-form{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow-y:auto;padding:24px}.add-physical-credential-field{display:flex;flex-direction:column;gap:6px}.add-physical-credential-field label{color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:.9rem;font-weight:600}.add-physical-credential-field input,.add-physical-credential-field select{background:#2a2a2a;background:var(--card-bg,#2a2a2a);border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:6px;color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:1rem;padding:10px 12px;transition:border-color .2s}.add-physical-credential-field input:hover:not(:disabled),.add-physical-credential-field select:hover:not(:disabled){border-color:#007bff;border-color:var(--accent-color,#007bff)}.add-physical-credential-field input:focus,.add-physical-credential-field select:focus{border-color:#007bff;border-color:var(--accent-color,#007bff);box-shadow:0 0 0 3px #007bff1a;outline:none}.add-physical-credential-field input:disabled,.add-physical-credential-field select:disabled{cursor:not-allowed;opacity:.6}.add-physical-credential-helper-text{color:#999;color:var(--text-secondary,#999);font-size:.8rem;line-height:1.4;margin:0}.add-physical-credential-error{background:#e74c3c26;border:1px solid #e74c3c66;border-radius:6px;color:#e74c3c;font-size:.9rem;padding:10px 14px}.add-physical-credential-success{background:#2ecc7126;border:1px solid #2ecc7166;border-radius:6px;color:#2ecc71;font-size:.9rem;padding:10px 14px}.add-physical-credential-actions{border-top:1px solid #333;border-top:1px solid var(--border-color,#333);display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:8px}.add-physical-credential-cancel-btn,.add-physical-credential-submit-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;padding:10px 24px;transition:all .2s}.add-physical-credential-cancel-btn{background-color:#555;background-color:var(--button-bg,#555);color:#e0e0e0;color:var(--text-color,#e0e0e0)}.add-physical-credential-cancel-btn:hover:not(:disabled){background-color:#666;background-color:var(--button-hover-bg,#666)}.add-physical-credential-submit-btn{background-color:#2ecc71;color:#fff}.add-physical-credential-submit-btn:hover:not(:disabled){background-color:#27ae60;box-shadow:0 4px 12px #2ecc7166;transform:translateY(-2px)}.add-physical-credential-cancel-btn:disabled,.add-physical-credential-submit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.light-mode .add-physical-credential-modal{--modal-bg:#fff;--card-bg:#f5f5f5;--border-color:#ddd;--text-color:#333;--text-secondary:#666;--button-bg:#6c757d;--button-hover-bg:#5a6268}@media (max-width:768px){.add-physical-credential-modal{border-radius:0;max-height:100vh;max-width:100%}.add-physical-credential-backdrop{padding:0}}.suspend-resume-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;left:0;position:fixed;right:0;top:0;z-index:9998}.suspend-resume-modal{animation:slideIn .2s ease-out;background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0000004d;left:50%;max-width:520px;padding:30px;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:9999}.suspend-resume-modal h2{border-bottom:2px solid var(--border-color);color:var(--accent-color);font-size:1.5rem;margin:0 0 20px;padding-bottom:15px;text-align:center}.suspend-resume-modal-content{margin-bottom:25px}.suspend-resume-warning{color:var(--text-primary);font-size:1.1rem;line-height:1.5;margin-bottom:20px;text-align:center}.suspend-resume-details{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:15px;padding:15px}.suspend-resume-details p{color:var(--text-secondary);font-size:.95rem;margin:8px 0}.suspend-resume-details strong{color:var(--accent-color);margin-right:8px}.suspend-resume-id{font-size:.95rem!important;word-break:break-all}.suspend-resume-id strong{color:var(--accent-color)}.suspend-resume-notice{background-color:#6495ed1a;border:1px solid #6495ed4d;border-radius:6px;padding:12px}.suspend-resume-notice p{color:var(--text-secondary);font-size:.9rem;margin:5px 0;text-align:center}.suspend-resume-modal-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:25px}.suspend-resume-cancel-btn,.suspend-resume-confirm-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 24px;transition:all .2s ease}.suspend-resume-cancel-btn{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.suspend-resume-cancel-btn:hover:not(:disabled){background-color:var(--bg-secondary);border-color:var(--accent-color)}.suspend-resume-confirm-btn{color:#fff;font-weight:600}.suspend-resume-confirm-btn.suspend{background:linear-gradient(135deg,#ff9800,#f57c00)}.suspend-resume-confirm-btn.suspend:hover:not(:disabled){background:linear-gradient(135deg,#f57c00,#e65100);box-shadow:0 4px 12px #ff980066;transform:translateY(-1px)}.suspend-resume-confirm-btn.resume{background:linear-gradient(135deg,#4caf50,#2e7d32)}.suspend-resume-confirm-btn.resume:hover:not(:disabled){background:linear-gradient(135deg,#2e7d32,#1b5e20);box-shadow:0 4px 12px #4caf5066;transform:translateY(-1px)}.suspend-resume-cancel-btn:disabled,.suspend-resume-confirm-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:600px){.suspend-resume-modal{padding:20px;width:95%}.suspend-resume-modal h2{font-size:1.3rem}.suspend-resume-modal-actions{flex-direction:column}.suspend-resume-cancel-btn,.suspend-resume-confirm-btn{width:100%}}.patron-credentials-modal-backdrop{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:900}.patron-credentials-modal{background:#1e1e1e;background:var(--modal-bg,#1e1e1e);border-radius:8px;box-shadow:0 4px 20px #00000080;display:flex;flex-direction:column;max-height:95vh;max-width:1200px;width:100%}.patron-credentials-modal-header{align-items:center;border-bottom:1px solid #333;border-bottom:1px solid var(--border-color,#333);display:flex;justify-content:space-between;padding:20px 24px}.patron-credentials-modal-title-container{align-items:center;display:flex;gap:12px}.patron-credentials-modal-photo{border-radius:4px;height:1.5rem;object-fit:cover;width:auto}.patron-credentials-modal-header h2{color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:1.5rem;margin:0}.patron-credentials-modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#e0e0e0;color:var(--text-color,#e0e0e0);cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:background-color .2s;width:32px}.patron-credentials-modal-close:hover{background-color:#ffffff1a}.patron-credentials-modal-body{flex:1 1;overflow-y:auto;padding:24px}.patron-credentials-empty,.patron-credentials-error,.patron-credentials-loading{color:#999;color:var(--text-secondary,#999);font-size:1.1rem;padding:40px 20px;text-align:center}.patron-credentials-error{color:#ff6b6b;color:var(--error-color,#ff6b6b)}.patron-credentials-empty{font-style:italic}.patron-credentials-list{display:flex;flex-direction:column;gap:16px}.patron-credential-card{background:#2a2a2a;background:var(--card-bg,#2a2a2a);border:1px solid #333;border:1px solid var(--border-color,#333);border-radius:6px;padding:16px 16px 20px;position:relative;transition:box-shadow .2s}.patron-credential-card:hover{box-shadow:0 2px 8px #0000004d}.patron-credential-card.pending-deletion{opacity:.6;pointer-events:none}.credential-deletion-overlay{align-items:center;background-color:#000000b3;border-radius:6px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.credential-deletion-message{animation:pulse-orange 1.5s ease-in-out infinite;background-color:#ff9800;border-radius:4px;color:#fff;font-size:1rem;font-weight:600;padding:12px 24px}@keyframes pulse-orange{0%,to{opacity:1}50%{opacity:.6}}.credential-processing-overlay{align-items:center;background-color:#000000bf;border-radius:6px;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.credential-processing-spinner{animation:credential-spin 1s linear infinite;border:4px solid #667eea4d;border-radius:50%;border-top:4px solid var(--accent-color,#667eea);height:40px;width:40px}.credential-processing-message{color:#fff;font-size:1rem;font-weight:600;letter-spacing:.5px;margin-top:12px}@keyframes credential-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.credential-suspended-banner{background:#ff0000f2;border-radius:6px;box-shadow:0 4px 12px #ff000080;color:#fff;margin:8px 0;padding:8px 16px;text-align:center}.credential-suspended-banner strong{color:#fff;font-size:1.1rem;font-weight:700;letter-spacing:1.5px}.credential-card.device-offline{opacity:.6;pointer-events:none}.credential-offline-overlay{align-items:center;background-color:#000000b3;border-radius:6px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.credential-offline-message{background-color:#d32f2f;border-radius:4px;color:#fff;font-size:1rem;font-weight:600;padding:12px 24px}.patron-credential-header{align-items:center;display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.patron-credential-header-actions{align-items:center;display:flex;gap:12px;justify-content:flex-end;width:100%}.patron-credential-suspend-btn{background:#ff98001a;border:1px solid #ff98004d;border-radius:4px;color:#ff9800;cursor:pointer;flex-shrink:0;font-size:1.2rem;margin-right:6px;padding:6px 12px;transition:all .2s}.patron-credential-suspend-btn:hover:not(:disabled){background:#ff980033;border-color:#ff980080;transform:scale(1.05)}.patron-credential-suspend-btn:active:not(:disabled){transform:scale(.95)}.patron-credential-suspend-btn:disabled{cursor:not-allowed;opacity:.3}.patron-credential-resume-btn{background:#4caf501a;border:1px solid #4caf504d;border-radius:4px;color:#4caf50;cursor:pointer;flex-shrink:0;font-size:1.2rem;margin-right:6px;padding:6px 12px;transition:all .2s}.patron-credential-resume-btn:hover:not(:disabled){background:#4caf5033;border-color:#4caf5080;transform:scale(1.05)}.patron-credential-resume-btn:active:not(:disabled){transform:scale(.95)}.patron-credential-resume-btn:disabled{cursor:not-allowed;opacity:.3}.patron-credential-delete-btn{background:#ff3b301a;border:1px solid #ff3b304d;border-radius:4px;color:#ff3b30;cursor:pointer;flex-shrink:0;font-size:1.2rem;margin-right:6px;padding:6px 12px;transition:all .2s}.patron-credential-delete-btn:hover:not(:disabled){background:#ff3b3033;border-color:#ff3b3080;transform:scale(1.05)}.patron-credential-delete-btn:active:not(:disabled){transform:scale(.95)}.patron-credential-delete-btn:disabled{cursor:not-allowed;opacity:.4}.patron-credential-id{align-items:center;color:#b0b0b0;color:var(--text-secondary,#b0b0b0);display:flex;font-size:1rem;gap:8px;justify-content:center;word-break:break-all}.patron-credential-copy-btn,.patron-credential-id strong{color:#e0e0e0;color:var(--text-color,#e0e0e0)}.patron-credential-copy-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:4px;cursor:pointer;flex-shrink:0;font-size:.85rem;padding:4px 8px;transition:all .2s}.patron-credential-copy-btn:hover{background:#fff3;border-color:#ffffff4d}.patron-credential-copy-btn:active{transform:scale(.95)}.patron-credential-wiegand{gap:12px}.patron-credential-device-type-row,.patron-credential-wiegand{color:#b0b0b0;color:var(--text-secondary,#b0b0b0);display:flex;flex-wrap:wrap;font-size:.9rem;margin-bottom:8px}.patron-credential-device-type-row{align-items:center;gap:16px}.patron-device-type-field,.patron-wiegand-field{white-space:nowrap}.patron-device-type-field strong,.patron-wiegand-field strong{color:#e0e0e0;color:var(--text-color,#e0e0e0)}.patron-credential-status{border-radius:12px;font-size:.85rem;font-weight:600;padding:4px 12px;text-transform:uppercase;white-space:nowrap}.patron-credential-status.status-active{background-color:#2ecc71;color:#fff}.patron-credential-status.status-suspended{background-color:#f39c12;color:#fff}.patron-credential-created,.patron-credential-device-type{color:#999;color:var(--text-secondary,#999);font-size:.9rem;margin-bottom:8px}.patron-credential-devices{border-top:1px solid #333;border-top:1px solid var(--border-color,#333);margin-top:16px;padding-top:16px}.patron-credential-devices>strong{color:#e0e0e0;color:var(--text-color,#e0e0e0);display:block;font-size:.95rem;margin-bottom:12px}.patron-credential-device-badges{display:flex;flex-wrap:wrap;gap:12px}.patron-credential-device-badge{background:#3a3a3a;background:var(--badge-bg,#3a3a3a);border:1px solid #444;border:1px solid var(--border-color,#444);border-radius:6px;min-width:200px;padding:10px 14px;transition:transform .2s,box-shadow .2s}.patron-credential-device-badge:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.device-badge-name{color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:.95rem;font-weight:600;margin-bottom:4px}.device-badge-id{color:#777;color:var(--text-tertiary,#777);font-family:monospace;font-size:.8rem}.patron-credential-no-devices{color:#999;color:var(--text-secondary,#999);font-style:italic;padding:8px 0}.patron-credentials-modal-footer{align-items:center;border-top:1px solid #333;border-top:1px solid var(--border-color,#333);display:flex;gap:12px;justify-content:space-between;padding:16px 24px}.patron-credentials-add-btn{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 24px;transition:background-color .2s}.patron-credentials-add-btn:hover:not(:disabled){background-color:#0056b3}.patron-credentials-add-btn:disabled{background-color:#555;cursor:not-allowed;opacity:.5}.patron-credentials-close-btn{background-color:#555;background-color:var(--button-bg,#555);border:none;border-radius:4px;color:#e0e0e0;color:var(--text-color,#e0e0e0);cursor:pointer;font-size:1rem;padding:10px 24px;transition:background-color .2s}.patron-credentials-close-btn:hover{background-color:#666;background-color:var(--button-hover-bg,#666)}.patron-device-cards-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));margin-top:12px}@media (min-width:768px){.patron-device-cards-grid{grid-template-columns:repeat(6,1fr)}}.patron-device-card{background:#3a3a3a;background:var(--badge-bg,#3a3a3a);border:2px solid #444;border:2px solid var(--border-color,#444);border-radius:6px;cursor:pointer;display:flex;flex-direction:column;min-height:70px;padding:10px;transition:all .2s}.patron-device-card:hover:not(.device-disabled):not(.device-no-credential){border-color:#007bff;box-shadow:0 2px 8px #007bff33}.patron-device-card.device-selected{background:#007bff1a;border-color:#007bff}.patron-device-card.device-disabled{cursor:not-allowed;opacity:.5}.patron-device-card.device-no-credential{cursor:not-allowed;opacity:.4}.patron-device-card-label{cursor:pointer;display:flex;flex-direction:column;gap:8px;height:100%;width:100%}.patron-device-checkbox{align-self:flex-start;cursor:pointer;flex-shrink:0;height:18px;width:18px}.patron-device-info{flex:1 1;min-width:0}.patron-device-name{word-wrap:break-word;color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:.9rem;font-weight:600;line-height:1.3}.patron-device-serial-inline{font-size:.75rem;font-weight:400}.patron-device-serial,.patron-device-serial-inline{color:#999;color:var(--text-secondary,#999);font-family:monospace}.patron-device-serial{font-size:.85rem}.device-has-credential-badge,.device-no-credential-badge{align-self:center;font-size:1.2rem;margin-top:auto}.device-no-credential-badge{opacity:.5}.delete-from-selected-btn{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;margin-top:12px;padding:10px 20px;transition:background-color .2s}.delete-from-selected-btn:hover:not(:disabled){background-color:#c82333}.delete-from-selected-btn:disabled{background-color:#666;cursor:not-allowed;opacity:.6}.device-operation-overlay{align-items:center;background-color:#000000bf;border-radius:6px;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.device-operation-message{animation:pulse 1.5s ease-in-out infinite;color:#fff;font-size:.95rem;padding:12px;text-align:center}.device-operation-message strong{font-weight:700;text-shadow:0 2px 4px #00000080}.device-operation-overlay.overlay-failed{background-color:#dc3545d9}.device-operation-overlay.overlay-failed .device-operation-message{animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.patron-device-card.device-pending{opacity:.95;pointer-events:none}.light-mode .patron-credentials-modal{--modal-bg:#fff;--card-bg:#f5f5f5;--badge-bg:#e8e8e8;--border-color:#ddd;--text-color:#333;--text-secondary:#666;--text-tertiary:#999;--button-bg:#007bff;--button-hover-bg:#0056b3}.light-mode .patron-credentials-close-btn{color:#fff}@media (max-width:768px){.patron-credentials-modal{border-radius:0;max-height:100vh;max-width:100%}.patron-credentials-modal-backdrop{padding:0}.patron-credential-header{align-items:flex-start;flex-direction:column}.patron-credential-device-badge{min-width:100%}}.quick-create-warning{background-color:#f39c121f;border:1px solid #f39c1280;border-radius:6px;color:#f39c12;font-size:.9rem;line-height:1.5;margin:0 0 1rem;padding:.75rem 1rem}.quick-create-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1200}.quick-create-modal{background:#1e1e1e;background:var(--modal-bg,#1e1e1e);border-radius:8px;box-shadow:0 4px 20px #00000080;display:flex;flex-direction:column;max-height:90vh;max-width:480px;width:100%}.quick-create-success-body{display:flex;flex-direction:column;gap:8px;padding:24px}.quick-create-success-body p{color:#e0e0e0;color:var(--text-color,#e0e0e0);line-height:1.5;margin:0}.quick-create-success-body p:first-child{color:#2ecc71;font-weight:600}.quick-create-submit-btn{background-color:#f39c12!important;background-color:var(--status-warning,#f39c12)!important}.quick-create-submit-btn:hover:not(:disabled){background-color:#d68910!important;box-shadow:0 4px 12px #f39c1266!important;transform:translateY(-2px)}.light-mode .quick-create-modal{--modal-bg:#fff}@media (max-width:768px){.quick-create-modal{border-radius:0;max-height:100vh;max-width:100%}.quick-create-modal-overlay{padding:0}}.patron-limit-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;left:0;position:fixed;right:0;top:0;z-index:10000}.patron-limit-modal{animation:slideIn .2s ease-out;background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0000004d;left:50%;max-width:500px;overflow:hidden;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:10001}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.patron-limit-modal-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;justify-content:space-between;padding:24px 24px 16px}.patron-limit-modal-header h2{color:#dc2626;font-size:1.5rem;font-weight:600;margin:0}.patron-limit-modal-header .close-button{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;padding:0;transition:background-color .2s;width:32px}.patron-limit-modal-header .close-button:hover{background-color:var(--bg-tertiary)}.patron-limit-modal-content{padding:24px;text-align:center}.patron-limit-icon{font-size:4rem;margin-bottom:16px}.patron-limit-message{color:var(--text-primary);font-size:1.1rem;line-height:1.6;margin-bottom:16px}.patron-limit-message strong{color:var(--accent-color);font-weight:600}.patron-limit-suggestion{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin:0}.patron-limit-modal-actions{display:flex;justify-content:center;padding:16px 24px 24px}.patron-limit-ok-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 6px #667eea4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 32px;transition:all .3s ease}.patron-limit-ok-button:hover{box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.patron-limit-ok-button:active{transform:translateY(0)}@media (max-width:640px){.patron-limit-modal{max-width:none;width:95%}.patron-limit-modal-header h2{font-size:1.25rem}.patron-limit-icon{font-size:3rem}.patron-limit-message{font-size:1rem}.patron-limit-suggestion{font-size:.875rem}}.patron-management{margin:0 auto;max-width:1400px;padding:2rem}.patron-header{margin-bottom:2rem;text-align:center}.patron-header h1{color:var(--accent-color);font-size:2.5rem;margin-bottom:.5rem}.patron-header .org-name{color:var(--text-secondary);font-size:1.1rem}.patron-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.search-form{display:flex;flex:1 1;gap:.5rem;max-width:500px}.search-input{background-color:var(--bg-input);border:1px solid var(--border-color-light);border-radius:5px;color:var(--text-primary);flex:1 1;font-size:1rem;padding:.75rem 1rem}.search-input:focus{border-color:var(--accent-color);outline:none}.create-button,.search-button{border:none;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.search-button{background-color:var(--accent-color);color:#fff}.search-button:hover{background-color:var(--accent-color-hover);transform:translateY(-1px)}.create-button{background-color:#28a745;color:#fff}.create-button:hover{background-color:#218838;transform:translateY(-1px)}.patron-action-buttons{align-items:center;display:flex;gap:1rem}.quick-create-button{background-color:#f39c12;background-color:var(--status-warning,#f39c12);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.quick-create-button:hover:not(:disabled){background-color:#d68910;transform:translateY(-1px)}.quick-create-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.no-mobile-rights-badge{color:#f39c12;color:var(--status-warning,#f39c12);display:inline-block;font-size:.75rem;font-weight:600;margin-left:.5rem;white-space:nowrap}.nfc-type-badge{border-radius:4px;display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.03em;margin-left:.5rem;padding:1px 6px;vertical-align:middle}.nfc-type-na{background-color:#e74c3c26;border:1px solid #e74c3c66;color:#e74c3c}.nfc-type-40x{background-color:#ffffff14;background-color:var(--bg-secondary,#ffffff14);border:1px solid #444;border:1px solid var(--border-color,#444);color:#999;color:var(--text-secondary,#999)}.nfc-type-56w{background-color:#667eea26;border:1px solid #667eea;border:1px solid var(--accent-color,#667eea);color:#667eea;color:var(--accent-color,#667eea)}.patrons-table-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem;overflow-x:auto}.patrons-table{border-collapse:collapse;width:100%}.patrons-table thead{background-color:var(--bg-primary);border-bottom:2px solid var(--border-color)}.patrons-table th{color:var(--accent-color);font-size:.95rem;font-weight:600;padding:1rem;text-align:center}.patrons-table td{border-bottom:1px solid var(--border-color-light);color:var(--text-primary);padding:1rem}.patrons-table tbody tr:hover{background-color:var(--bg-hover)}.patron-thumbnail{background-color:#fff;border:2px solid var(--border-color);border-radius:50%;cursor:pointer;height:50px;object-fit:cover;transition:transform .2s ease;width:50px}.patron-thumbnail:hover{border-color:var(--accent-color);transform:scale(1.1)}.patron-number-cell{color:var(--accent-color);font-family:Courier New,Courier,monospace;font-size:1rem;font-weight:600;letter-spacing:.05em}.actions-cell{white-space:nowrap}.actions-cell-inner{display:flex;gap:.5rem;justify-content:center}.delete-button,.edit-button,.view-credentials-button{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.3rem;padding:.25rem .5rem;transition:all .2s ease}.view-credentials-button:hover{background-color:#2ecc711a;transform:scale(1.1)}.edit-button:hover{background-color:var(--bg-hover);transform:scale(1.1)}.delete-button{background:#ff3b301a;border:1px solid #ff3b304d;color:#ff3b30}.delete-button:hover{background:#ff3b3033;border-color:#ff3b3080;transform:scale(1.1)}.pagination-controls{align-items:center;display:flex;gap:2rem;justify-content:center;margin-top:1.5rem}.pagination-button{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:5px;color:var(--text-primary);cursor:pointer;font-size:.95rem;padding:.5rem 1rem;transition:all .2s ease}.pagination-button:hover:not(:disabled){background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.pagination-button:disabled{cursor:not-allowed;opacity:.5}.page-info{color:var(--text-secondary);font-size:.95rem}.error-message,.loading-message,.no-org-message,.no-patrons-message{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin-top:2rem;padding:3rem;text-align:center}.error-message p,.no-org-message p,.no-patrons-message p{color:var(--text-primary);font-size:1.1rem;margin-bottom:1rem}.loading-message{align-items:center;display:flex;flex-direction:column;gap:1rem}.spinner{animation:spin 1s linear infinite;border-top:4px solid var(--border-color-light);border:4px solid var(--border-color-light);border-radius:50%;border-top-color:var(--accent-color);height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message button,.no-patrons-message button{background-color:var(--accent-color);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.error-message button:hover,.no-patrons-message button:hover{background-color:var(--accent-color-hover);transform:translateY(-1px)}.photo-modal{align-items:center;background-color:#000000d9;bottom:0;cursor:pointer;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.photo-modal-content{max-height:90%;max-width:90%;position:relative}.photo-modal-content img{border-radius:8px;box-shadow:0 8px 32px #00000080;max-height:90vh;max-width:100%}.photo-modal-close{background:none;border:none;color:#fff;cursor:pointer;font-size:2rem;line-height:1;padding:.5rem;position:absolute;right:0;top:-40px}.photo-modal-close:hover{color:var(--accent-color)}@media (max-width:768px){.patron-management{padding:1rem}.patron-header h1{font-size:2rem}.patron-controls{flex-direction:column}.search-form{max-width:100%}.patrons-table{font-size:.85rem}.patrons-table td,.patrons-table th{padding:.5rem}.patron-thumbnail{height:40px;width:40px}}.dev-stream-pane{background:var(--bg-secondary);border-left:2px solid var(--border-color);box-shadow:-4px 0 12px #0000004d;display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow:hidden;position:relative;transition:width .2s ease,box-shadow .2s ease}.dev-stream-pane.dev-stream-popout{border:none;box-shadow:none;height:100vh;left:0;margin:0;max-width:100vw!important;padding:0;position:fixed;right:0;top:0;width:100vw!important;z-index:10500}.dev-stream-popout-container{background:var(--bg-secondary);height:100vh;margin:0;overflow:hidden;padding:0;position:relative;width:100vw;z-index:1}.dev-stream-resize-handle{background:#0000;cursor:ew-resize;height:100%;left:0;position:absolute;top:0;transition:background .2s ease;width:8px;z-index:10}.dev-stream-resize-handle:hover{background:#667eea4d}.dev-stream-resize-handle:active{background:#667eea80}.dev-stream-header{align-items:center;background:var(--header-bg);border-bottom:2px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:20px}.dev-stream-header h2{color:var(--accent-color);font-size:1.4rem;font-weight:600;margin:0}.dev-stream-header-right{align-items:center;display:flex;gap:12px}.dev-stream-close-btn,.dev-stream-popin-btn,.dev-stream-popout-btn{align-items:center;background:#0000;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.2rem;justify-content:center;line-height:1;padding:6px 10px;transition:all .2s ease}.dev-stream-popin-btn:hover,.dev-stream-popout-btn:hover{background:#667eea1a;border-color:var(--accent-color);color:var(--accent-color)}.dev-stream-close-btn:hover{background:#f443361a;border-color:#f44336;color:#f44336}.dev-stream-status{align-items:center;border-radius:12px;display:flex;font-size:.85rem;font-weight:600;gap:6px;padding:4px 12px}.dev-stream-status.connected{background:#4caf5033;border:1px solid #4caf5066;color:#4caf50}.dev-stream-status.authenticating{background:#ffc10733;border:1px solid #ffc10766;color:#ffc107}.dev-stream-status.disconnected{background:#f4433633;border:1px solid #f4433666;color:#f44336}.dev-stream-error{align-items:center;background:#f4433626;border-bottom:1px solid #f443364d;color:#f44336;display:flex;flex-shrink:0;font-size:.9rem;gap:10px;padding:12px 20px}.dev-stream-error .error-icon{font-size:1.2rem}.dev-stream-controls{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;padding:15px 20px}.source-toggles{display:flex;gap:10px;margin-bottom:12px}.source-toggle{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;font-size:.85rem;font-weight:600;gap:6px;justify-content:center;padding:8px 12px;transition:all .2s ease}.source-toggle:hover{background:var(--button-bg);border-color:var(--accent-color)}.source-toggle.active{background:#667eea33;border-color:var(--accent-color);color:var(--accent-color)}.source-toggle-mc.active{background:#4caf5033;border-color:#4caf50;color:#4caf50}.source-toggle-mc:hover{border-color:#4caf50}.toggle-icon{font-size:1rem}.max-events-config{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;display:flex;gap:10px;margin-bottom:12px;padding:10px}.max-events-label{color:var(--text-secondary);font-size:.85rem;font-weight:600;white-space:nowrap}.max-events-input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:.9rem;font-weight:600;padding:6px 10px;text-align:center;transition:all .2s ease;width:60px}.max-events-input:focus{background:var(--bg-primary);outline:none}.max-events-input:focus,.max-events-input:hover{border-color:var(--accent-color)}.control-actions{display:flex;flex-wrap:wrap;gap:8px}.control-btn{background:var(--button-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);cursor:pointer;flex:1 1;font-size:.85rem;font-weight:600;min-width:90px;padding:8px 12px;transition:all .2s ease;white-space:nowrap}.control-btn:hover:not(:disabled){background:var(--accent-color);border-color:var(--accent-color);color:#fff;transform:translateY(-1px)}.control-btn:active:not(:disabled){transform:translateY(0)}.control-btn:disabled{cursor:not-allowed;opacity:.5}.control-btn.clear-btn:hover:not(:disabled){background:#f44336;border-color:#f44336}.control-btn.test-btn:hover:not(:disabled){background:#9c27b0;border-color:#9c27b0}.test-event-options{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;margin-top:12px;padding:12px}.test-event-buttons{display:flex;gap:8px;margin-bottom:12px}.test-event-btn{background:linear-gradient(135deg,#9c27b0,#673ab7);border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:600;padding:8px 12px;transition:all .2s ease}.test-event-btn:hover{box-shadow:0 4px 8px #9c27b04d;transform:translateY(-1px)}.test-event-btn:active{transform:translateY(0)}.custom-payload-section{display:flex;flex-direction:column;gap:6px}.custom-payload-section label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.custom-payload-input{background:var(--body-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-family:Courier New,monospace;font-size:.8rem;padding:8px;resize:vertical;width:100%}.custom-payload-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 2px #667eea33;outline:none}.input-hint{color:var(--text-muted);font-size:.75rem;font-style:italic}.dev-stream-filters{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.filters-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:12px 20px;transition:background .2s ease;-webkit-user-select:none;user-select:none}.filters-header:hover{background:var(--bg-tertiary)}.filters-header h3{align-items:center;color:var(--text-color);display:flex;font-size:1rem;font-weight:600;gap:8px;margin:0}.active-filters-badge{color:#4caf50;font-size:.6rem}.collapse-icon{color:var(--text-secondary);font-size:.9rem}.filters-content{padding:12px 20px 16px}.filter-hint{background:#667eea1a;border-left:3px solid var(--accent-color);border-radius:4px;color:var(--text-secondary);font-size:.8rem;margin-bottom:12px;padding:8px 12px}.filter-hint code{background:#0003;border-radius:3px;color:var(--accent-color);font-family:Courier New,monospace;padding:2px 6px}.filter-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:12px}.filter-field{display:flex;flex-direction:column;gap:4px;min-width:0}.filter-field label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.filter-field input,.filter-field select{background:var(--body-bg);border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;color:var(--text-color);font-size:.85rem;min-width:0;padding:8px 10px;transition:all .2s ease;width:100%}.filter-field input:focus,.filter-field select:focus{border-color:var(--accent-color);box-shadow:0 0 0 2px #667eea33;outline:none}.filter-field input.has-value,.filter-field select.has-value{background:#4caf500d;border-color:#4caf50}.clear-filters-btn{background:var(--button-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);cursor:pointer;font-size:.85rem;font-weight:600;padding:8px;transition:all .2s ease;width:100%}.clear-filters-btn:hover{background:#f44336;border-color:#f44336;color:#fff}.dev-stream-view{background:var(--body-bg);flex:1 1;overflow-y:auto}.event-count-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-size:.85rem;font-weight:600;padding:12px 20px;position:-webkit-sticky;position:sticky;text-align:center;top:0;z-index:5}.event-list{gap:10px;padding:12px}.empty-state,.event-list{display:flex;flex-direction:column}.empty-state{align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-state-icon{font-size:4rem;margin-bottom:16px;opacity:.5}.empty-state-text{color:var(--text-secondary);font-size:1.2rem;font-weight:600;margin-bottom:8px}.empty-state-hint{color:var(--text-muted);font-size:.9rem}.dev-stream-event-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:default;padding:12px;transition:all .2s ease}.dev-stream-event-card:hover{border-color:var(--accent-color);box-shadow:0 4px 8px #667eea33;transform:translateY(-1px)}.dev-stream-event-card.expanded{border-color:var(--accent-color);box-shadow:0 4px 12px #667eea4d}.dev-stream-event-card.subscription-confirmation{background:#ffa50026;border-color:#ffa50066}.dev-stream-event-card.subscription-confirmation:hover{border-color:#ffa50099;box-shadow:0 4px 8px #ffa50033}.dev-stream-event-card.subscription-confirmation.expanded{border-color:#ffa500b3;box-shadow:0 4px 12px #ffa5004d}.dev-stream-event-card.subscription-confirmation .source-badge.source-yp{background:#ffa50033;border:1px solid #ffa50066;color:#ff8c00}.event-card-header{align-items:center;background:#00000008;border-bottom:1px solid var(--border-color);border-radius:6px 6px 0 0;cursor:pointer;display:flex;justify-content:space-between;margin:-8px -12px 8px;padding:8px;transition:background .2s ease;-webkit-user-select:none;user-select:none}.event-card-header:hover{background:#0000000d}.event-card-header:active{background:#00000014}.event-card-left{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.source-badge{border-radius:4px;flex-shrink:0;font-size:.7rem;font-weight:700;letter-spacing:.5px;padding:3px 8px;text-transform:uppercase}.source-badge.source-yp{background:#2196f333;border:1px solid #2196f366}.source-badge.source-mc{background:#9c27b033;border:1px solid #9c27b066;color:#9c27b0}.source-badge.source-error{background:#f4433633;border:1px solid #f4433666}.source-badge.source-unknown{background:#9e9e9e33;border:1px solid #9e9e9e66;color:#9e9e9e}.event-type{color:var(--text-color);font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-time{color:var(--text-muted);flex-shrink:0;font-family:Courier New,monospace;font-size:.75rem;white-space:nowrap}.event-card-right{align-items:center;display:flex;gap:8px}.copy-event-btn{background:none;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:.9rem;padding:4px 8px;transition:all .2s ease}.copy-event-btn:hover{background:var(--button-bg);border-color:var(--accent-color);color:var(--accent-color)}.expand-icon{color:var(--text-secondary);font-size:.8rem;transition:transform .2s ease}.event-card-header:hover .expand-icon{color:var(--accent-color)}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.copy-section-btn{background:none;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:.85rem;opacity:.7;padding:2px 6px;transition:all .2s ease}.copy-section-btn:hover{background:var(--button-bg);border-color:var(--accent-color);color:var(--accent-color);opacity:1}.event-card-summary{display:flex;flex-direction:column;gap:4px;padding:8px 0}.summary-field{align-items:flex-start;display:flex;font-size:.8rem;gap:8px;overflow:hidden}.field-label{color:var(--text-secondary);font-weight:600;min-width:80px;text-align:left}.field-value{color:var(--text-color);flex:1 1;font-family:Courier New,monospace;min-width:0;overflow-wrap:break-word;text-align:left;word-break:break-all}.event-card-expanded{display:flex;flex-direction:column;gap:16px;margin-top:12px}.event-body-section,.event-headers-section{display:flex;flex-direction:column;gap:8px}.section-label{color:var(--text-secondary);font-size:.85rem;font-weight:600;margin-bottom:4px;text-align:left}.event-headers-content{background:var(--body-bg);border:1px solid var(--border-color);border-radius:6px;max-height:200px;overflow-y:auto;padding:12px}.event-headers-content pre{word-wrap:break-word;max-width:100%;overflow-wrap:break-word;text-align:left;white-space:pre-wrap}.event-body-section .event-card-json{background:var(--body-bg);border:1px solid var(--border-color);border-radius:6px;max-height:400px;overflow-y:auto;padding:12px}.dev-metadata-section{margin-top:12px}.dev-metadata-section .section-label{color:var(--accent-color);font-size:.8rem;font-weight:600;margin-bottom:6px;text-align:left}.dev-metadata-section .event-card-json{background:#667eea0d;border:1px solid #667eea4d;border-radius:6px;max-height:200px;overflow-y:auto;padding:12px}.event-card-json pre{word-wrap:break-word;color:var(--text-color);font-family:Courier New,monospace;font-size:.75rem;margin:0;white-space:pre-wrap}.dev-stream-view::-webkit-scrollbar,.event-card-json::-webkit-scrollbar{width:8px}.dev-stream-view::-webkit-scrollbar-track,.event-card-json::-webkit-scrollbar-track{background:var(--body-bg)}.dev-stream-view::-webkit-scrollbar-thumb,.event-card-json::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.dev-stream-view::-webkit-scrollbar-thumb:hover,.event-card-json::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}@media (max-width:1400px){.dev-stream-pane{max-width:70%}.filter-grid{grid-template-columns:1fr}}@media (max-width:768px){.dev-stream-pane{max-width:90%}.dev-stream-header h2{font-size:1.2rem}.control-actions{flex-direction:column}.control-btn{min-width:100%}}body.dark-mode .dev-stream-pane{--body-bg:#121212;--bg-secondary:#1a1a1a;--bg-tertiary:#2a2a2a;--header-bg:#1a1a1a;--border-color:#333;--text-color:#e0e0e0;--text-secondary:#b0b0b0;--text-muted:#888;--button-bg:#2a2a2a;--accent-color:#667eea}body.light-mode .dev-stream-pane{--body-bg:#fff;--bg-secondary:#f5f5f5;--bg-tertiary:#e8e8e8;--header-bg:#fff;--border-color:#ddd;--text-color:#333;--text-secondary:#666;--text-muted:#999;--button-bg:#e8e8e8;--accent-color:#667eea;box-shadow:-4px 0 12px #0000001a}body.light-mode .filter-hint code{background:#667eea1a;color:var(--accent-color)}body.light-mode .event-headers-row:nth-child(odd){background:#00000008}body.light-mode .json-viewer{background:#fafafa;border-color:#ddd}body.light-mode .json-viewer code{color:#333}body.light-mode .dev-stream-event-card{background:#fff;border-color:#ddd}body.light-mode .dev-stream-event-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.dev-stream-pane button:focus,.dev-stream-pane input:focus{outline:3px solid gold;outline-offset:2px}@media (prefers-reduced-motion:reduce){.control-btn,.dev-stream-event-card,.dev-stream-pane,.test-event-btn{transition:none}.control-btn:hover:not(:disabled),.dev-stream-event-card:hover{transform:none}}.dev-stream-org-selector{align-items:center;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;gap:10px;padding:12px 20px}.org-selector-label{color:var(--text-secondary);font-size:.9rem;font-weight:600;white-space:nowrap}.org-selector-dropdown{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);cursor:pointer;flex:1 1;font-size:.9rem;min-width:0;padding:6px 12px;transition:all .2s ease}.org-selector-dropdown:focus,.org-selector-dropdown:hover{border-color:var(--accent-color)}.org-selector-dropdown:focus{box-shadow:0 0 0 3px #667eea33;outline:none}.org-selector-error,.org-selector-loading{color:var(--text-muted);font-size:.85rem;font-style:italic}.org-selector-error{color:#f44336}.dev-stream-event-card[data-source=YP]{background:#2196f314;border-left:4px solid #2196f3}.dev-stream-event-card[data-source=YP]:hover{background:#2196f31f;box-shadow:0 4px 12px #2196f333}.dev-stream-event-card[data-source=YP].subscription-confirmation{background:#ffa50026;border-left:4px solid #ff8c00}.dev-stream-event-card[data-source=YP].subscription-confirmation:hover{background:#ffa50033;box-shadow:0 4px 12px #ffa50040}.dev-stream-event-card[data-source=MC]{background:#4caf5014;border-left:4px solid #4caf50}.dev-stream-event-card[data-source=MC]:hover{background:#4caf501f;box-shadow:0 4px 12px #4caf5033}.dev-stream-event-card[data-orphaned=true],.dev-stream-event-card[data-source=SYSTEM_ERROR]{animation:pulse-red 2s ease-in-out infinite;background:#f443361f;border-left:4px solid #f44336}@keyframes pulse-red{0%,to{background:#f443361f}50%{background:#f4433633}}.dev-stream-event-card[data-orphaned=true]:hover,.dev-stream-event-card[data-source=SYSTEM_ERROR]:hover{background:#f443362e;box-shadow:0 4px 12px #f443364d}.source-badge.source-yp{background:#2196f340;border:1px solid #2196f380;color:#2196f3}.source-badge.source-mc{background:#4caf5040;border:1px solid #4caf5080;color:#4caf50}.source-badge.source-error{background:#f4433640;border:1px solid #f4433680;color:#f44336;font-weight:800}.json-key{color:#9cdcfe;font-weight:500}.json-string{color:#ce9178}.json-number{color:#b5cea8}.json-boolean{color:#569cd6;font-weight:600}.json-null{color:#569cd6;font-style:italic}.welcome-page{background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh}.welcome-nav{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.welcome-nav-inner{align-items:center;display:flex;height:64px;justify-content:space-between;margin:0 auto;max-width:1100px}.welcome-nav-logo{height:32px;width:auto}.welcome-nav-links{align-items:center;display:flex;gap:24px}.welcome-nav-link{color:var(--text-secondary);font-size:.9rem;text-decoration:none;transition:color .2s ease}.welcome-nav-link:hover{color:var(--text-primary)}.welcome-nav-cta{background:var(--accent-color);border-radius:8px;color:var(--text-on-accent);font-size:.9rem;font-weight:600;padding:8px 20px;text-decoration:none;transition:background .2s ease,transform .2s ease}.welcome-nav-cta:hover{background:var(--accent-color-hover);transform:translateY(-1px)}.welcome-hero{animation:welcome-fadeUp .6s ease both;background:linear-gradient(160deg,var(--bg-secondary) 0,var(--bg-tertiary) 100%);border-bottom:1px solid var(--border-color);padding:100px 24px 80px;text-align:center}.welcome-hero-inner{margin:0 auto;max-width:760px}.welcome-hero-badge{background:#61dafb1f;border:1px solid #61dafb4d;border-radius:20px;color:var(--accent-color);display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.04em;margin-bottom:28px;padding:5px 14px;text-transform:uppercase}.welcome-hero-heading{font-size:2.8rem;font-weight:700;line-height:1.2;margin:0 0 20px}.welcome-hero-accent{color:var(--accent-color)}.welcome-hero-sub{color:var(--text-secondary);font-size:1.15rem;line-height:1.7;margin:0 0 40px}.welcome-hero-actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.welcome-badge-link{color:inherit;text-decoration:underline;text-underline-offset:2px;transition:opacity .2s ease}.welcome-badge-link:hover{opacity:.75}.welcome-btn-primary{background:var(--accent-color);border-radius:10px;box-shadow:0 4px 14px #61dafb40;color:var(--text-on-accent);font-size:1rem;font-weight:600;padding:14px 32px;text-decoration:none;transition:background .2s ease,transform .2s ease,box-shadow .2s ease}.welcome-btn-primary:hover{background:var(--accent-color-hover);box-shadow:0 6px 20px #61dafb59;transform:translateY(-2px)}.welcome-btn-secondary{background:#0000;border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:1rem;font-weight:500;padding:14px 32px;text-decoration:none;transition:border-color .2s ease,background .2s ease,transform .2s ease}.welcome-btn-secondary:hover{background:#61dafb0f;border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-2px)}.welcome-section-inner{margin:0 auto;max-width:1100px;padding:0 24px}.welcome-section-heading{font-size:2rem;font-weight:700;margin:0 0 12px;text-align:center}.welcome-section-sub{color:var(--text-secondary);font-size:1.05rem;line-height:1.6;margin:0 auto 56px;max-width:600px;text-align:center}.welcome-features{background:var(--bg-primary);padding:80px 0}.welcome-feature-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.welcome-feature-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:28px 24px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.welcome-feature-card:hover{border-color:var(--accent-color);box-shadow:0 8px 24px var(--shadow-color);transform:translateY(-4px)}.welcome-feature-icon{font-size:2rem;margin-bottom:14px}.welcome-feature-title{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 10px}.welcome-feature-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.65;margin:0}.welcome-cta-band{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-tertiary) 100%);border-bottom:1px solid var(--border-color);border-top:1px solid var(--border-color);padding:72px 24px}.welcome-cta-inner{align-items:center;display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between}.welcome-cta-heading{font-size:1.8rem;font-weight:700;margin:0 0 8px}.welcome-cta-sub{color:var(--text-secondary);font-size:1rem;margin:0}.welcome-cta-actions{display:flex;flex-shrink:0;flex-wrap:wrap;gap:16px}.welcome-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);margin-top:auto;padding:24px;text-align:center}.welcome-footer p{color:var(--text-muted);font-size:.82rem;margin:0}.welcome-footer a{color:var(--text-muted);text-decoration:underline;transition:opacity .2s ease}.welcome-footer a:hover{opacity:.75}@keyframes welcome-fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}body.light-mode .welcome-hero-badge{background:#007bff14;border-color:#007bff40;color:var(--accent-color)}body.light-mode .welcome-btn-primary{box-shadow:0 4px 14px #007bff33}body.light-mode .welcome-btn-primary:hover{box-shadow:0 6px 20px #007bff4d}body.light-mode .welcome-btn-secondary:hover{background:#007bff0d;border-color:var(--accent-color);color:var(--accent-color)}@media (max-width:640px){.welcome-hero-heading{font-size:2rem}.welcome-hero{padding:72px 20px 60px}.welcome-cta-inner{flex-direction:column;text-align:center}.welcome-cta-actions{justify-content:center}}.support-page{background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh}.support-nav{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.support-nav-inner{align-items:center;display:flex;height:64px;justify-content:space-between;margin:0 auto;max-width:860px}.support-nav-logo{height:32px;width:auto}.support-nav-links{align-items:center;display:flex;gap:24px}.support-nav-link{color:var(--text-secondary);font-size:.9rem;text-decoration:none;transition:color .2s ease}.support-nav-link:hover{color:var(--text-primary)}.support-nav-cta{background:var(--accent-color);border-radius:8px;color:var(--text-on-accent);font-size:.9rem;font-weight:600;padding:8px 20px;text-decoration:none;transition:background .2s ease,transform .2s ease}.support-nav-cta:hover{background:var(--accent-color-hover);transform:translateY(-1px)}.support-main{animation:support-fadeUp .5s ease both;flex:1 1;padding:72px 24px 60px}.support-container{margin:0 auto;max-width:640px}.support-header{margin-bottom:40px;text-align:center}.support-header-icon{display:block;font-size:3rem;margin-bottom:16px}.support-heading{font-size:2.2rem;font-weight:700;margin:0 0 16px}.support-sub{color:var(--text-secondary);font-size:1.05rem;line-height:1.7;margin:0}.support-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 20px var(--shadow-color);overflow:hidden}.support-card-section{padding:28px 32px}.support-card-heading{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin:0 0 10px}.support-card-body{color:var(--text-secondary);font-size:.93rem;line-height:1.65;margin:0}.support-divider{background:var(--border-color-subtle);height:1px;margin:0}.support-resource-row{align-items:baseline;display:flex;gap:16px;justify-content:space-between;padding:12px 0}.support-resource-row+.support-resource-row{border-top:1px solid var(--border-color-subtle)}.support-resource-label{color:var(--text-muted);font-size:.88rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.support-resource-link{align-items:center;color:var(--accent-color);display:inline-flex;font-size:.95rem;font-weight:500;gap:4px;text-align:right;text-decoration:none;transition:opacity .2s ease;word-break:break-all}.support-resource-link:hover{opacity:.8;text-decoration:underline}.support-external-icon{flex-shrink:0;font-size:.75rem}.support-ticket-action{text-align:center}.support-btn-primary{background:var(--accent-color);border-radius:10px;box-shadow:0 4px 14px #61dafb40;color:var(--text-on-accent);display:inline-block;font-size:1rem;font-weight:600;padding:14px 32px;text-decoration:none;transition:background .2s ease,transform .2s ease,box-shadow .2s ease}.support-btn-primary:hover{background:var(--accent-color-hover);box-shadow:0 6px 20px #61dafb59;transform:translateY(-2px)}.support-ticket-note{color:var(--text-muted);font-size:.85rem;line-height:1.5;margin:14px 0 0}.support-back{margin-top:32px;text-align:center}.support-back-link{color:var(--text-secondary);font-size:.9rem;text-decoration:none;transition:color .2s ease}.support-back-link:hover{color:var(--text-primary)}.support-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:24px;text-align:center}.support-footer p{color:var(--text-muted);font-size:.82rem;margin:0}.support-footer a{color:var(--text-muted);text-decoration:underline;transition:opacity .2s ease}.support-footer a:hover{opacity:.75}@keyframes support-fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.support-inline-link{color:var(--accent-color);text-decoration:underline;transition:opacity .2s ease}.support-inline-link:hover{opacity:.8}body.light-mode .support-btn-primary{box-shadow:0 4px 14px #007bff33}body.light-mode .support-btn-primary:hover{box-shadow:0 6px 20px #007bff4d}@media (max-width:500px){.support-card-section{padding:20px}.support-resource-row{flex-direction:column;gap:4px}.support-resource-link{text-align:left}.support-heading{font-size:1.8rem}}
/*# sourceMappingURL=main.89126a38.css.map*/