.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:10px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px}.app-title{font-size:16px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px;letter-spacing:-.02em;flex-shrink:0}.header-nav{display:flex;gap:2px;background:var(--bg-color);padding:3px;border-radius:var(--radius-sm)}.nav-tab{padding:6px 14px;background:transparent;color:var(--text-muted);border:none;border-radius:4px;font-size:13px;font-weight:500;transition:all var(--transition-fast);white-space:nowrap}.nav-tab:hover{color:var(--text-primary)}.nav-tab.active{background:var(--bg-card);color:var(--text-primary)}.logout-btn{padding:6px 12px;background:transparent;color:var(--text-muted);border:1px solid var(--border-color);border-radius:4px;font-size:12px;font-weight:500;transition:all var(--transition-fast);flex-shrink:0}.logout-btn:hover{color:var(--error-color);border-color:var(--error-color);background:#ef44441a}.hamburger-btn{display:none;background:none;border:none;padding:8px;cursor:pointer}.hamburger-icon{display:flex;flex-direction:column;justify-content:space-between;width:20px;height:14px}.hamburger-icon span{display:block;height:2px;background:var(--text-primary);border-radius:1px;transition:all .2s ease}.hamburger-icon.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.hamburger-icon.open span:nth-child(2){opacity:0}.hamburger-icon.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}.mobile-nav{display:none}@media (max-width: 768px){.header-content{padding:10px 16px}.desktop-nav,.desktop-logout{display:none}.hamburger-btn{display:block}.mobile-nav{display:flex;flex-direction:column;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:8px}.mobile-nav-tab{padding:12px 16px;background:transparent;color:var(--text-secondary);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:500;text-align:left;transition:all var(--transition-fast)}.mobile-nav-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.mobile-nav-tab.active{background:var(--bg-card);color:var(--text-primary)}.mobile-nav-tab.logout{margin-top:8px;border-top:1px solid var(--border-color);padding-top:16px;color:var(--error-color)}.mobile-nav-tab.logout:hover{background:#ef44441a}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:360px;text-align:center}.login-card.shake{animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.login-icon{font-size:48px;margin-bottom:16px}.login-title{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:8px;letter-spacing:-.02em}.login-subtitle{color:var(--text-muted);font-size:14px;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:16px}.login-input{width:100%;padding:14px 16px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:16px;text-align:center;letter-spacing:.2em;transition:all var(--transition-fast)}.login-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-glow)}.login-input.error{border-color:var(--error-color);box-shadow:0 0 0 3px #ef444426}.login-input::placeholder{color:var(--text-muted);letter-spacing:normal}.login-error{color:var(--error-color);font-size:13px;margin:-8px 0 0}.login-button{width:100%;padding:14px;background:var(--primary-color);color:var(--bg-color);border:none;border-radius:var(--radius-md);font-size:15px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.login-button:hover{background:var(--primary-dark);box-shadow:0 0 20px var(--primary-glow)}.login-button:active{transform:scale(.98)}.door-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px 16px;transition:all var(--transition-normal);display:flex;flex-direction:row;align-items:center;gap:16px;cursor:pointer}.door-card:hover{border-color:var(--border-subtle);background:var(--bg-hover)}.door-status{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em;width:100px;justify-content:center;flex-shrink:0}.door-status.locked{background:#f59e0b26;color:var(--locked-color)}.door-status.unlocked{background:#22c55e26;color:var(--success-color)}.status-icon{font-size:14px}.door-info{flex:1;min-width:0}.door-name{font-size:15px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.door-location{color:var(--text-secondary);font-size:13px;display:flex;align-items:center;gap:4px;margin-top:2px}.door-last-accessed{color:var(--text-muted);font-size:12px;margin-top:4px}.door-actions{display:flex;gap:8px;flex-shrink:0}.door-actions .btn{padding:8px 16px;font-size:13px}@media (max-width: 768px){.door-card{flex-direction:column;align-items:stretch;padding:16px;gap:12px;border-radius:var(--radius-lg)}.door-status{width:fit-content}.door-name{font-size:17px}.door-location{font-size:14px}.door-actions{margin-top:8px;padding-top:12px;border-top:1px solid var(--border-color)}.door-actions .btn{flex:1;padding:10px 16px}}@media (max-width: 480px){.door-actions{flex-direction:column}}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .15s ease}.modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);max-width:480px;width:100%;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:18px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.modal-close{background:transparent;color:var(--text-muted);font-size:24px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.modal-body{padding:24px}.door-detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.door-detail-row:last-of-type{border-bottom:none}.detail-label{font-weight:500;color:var(--text-muted);font-size:14px}.detail-value{color:var(--text-primary);text-align:right;font-size:14px}.detail-value.status-locked{color:var(--locked-color);font-weight:500}.detail-value.status-unlocked{color:var(--success-color);font-weight:500}.unlock-duration{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.unlock-duration label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-secondary);font-size:14px}.unlock-duration input{width:100%;padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.unlock-duration input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-glow)}.modal-footer{display:flex;gap:12px;padding:20px 24px;border-top:1px solid var(--border-color);background:var(--bg-secondary);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.modal-footer .btn{flex:1}@media (max-width: 480px){.modal-content{max-width:100%;margin:0}.modal-footer{flex-direction:column-reverse}}.collapsible-section{margin-bottom:8px}.collapsible-header{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;color:var(--text-primary)}.collapsible-header:hover{background:var(--bg-hover);border-color:var(--border-subtle)}.collapse-icon{font-size:10px;color:var(--text-muted);transition:transform var(--transition-fast);flex-shrink:0}.collapse-icon.expanded{transform:rotate(90deg)}.section-title{font-weight:600;font-size:14px;flex:1}.section-count{font-size:12px;color:var(--text-muted);background:var(--bg-tertiary);padding:2px 8px;border-radius:10px}.collapsible-content{padding:8px 0 8px 16px;display:flex;flex-direction:column;gap:8px}@media (max-width: 768px){.collapsible-content{padding:8px 0}}.door-grid{display:flex;flex-direction:column;gap:8px;margin-top:16px}.door-grid-grouped{display:flex;flex-direction:column;gap:12px;margin-top:16px}.door-list{display:flex;flex-direction:column;gap:8px}.door-grid-empty{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:14px}@media (max-width: 768px){.door-grid,.door-list{display:grid;grid-template-columns:1fr;gap:16px}}.controller-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-top:20px}.controller-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition-normal)}.controller-card:hover{border-color:var(--border-subtle);box-shadow:var(--shadow-md)}.controller-status{display:flex;align-items:center;gap:10px;margin-bottom:16px}.status-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-indicator.online{background:var(--success-color);box-shadow:0 0 8px #22c55e80;animation:pulse 2s infinite}.status-indicator.offline{background:var(--text-muted)}@keyframes pulse{0%,to{box-shadow:0 0 8px #22c55e80}50%{box-shadow:0 0 16px #22c55e4d}}.status-text{font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.status-text.online{color:var(--success-color)}.status-text.offline{color:var(--text-muted)}.controller-info h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:12px;letter-spacing:-.01em}.controller-info p{color:var(--text-secondary);font-size:14px;margin:6px 0}.controller-info p strong{color:var(--text-muted);font-weight:500}.controller-actions{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color);display:flex;gap:8px}.controller-list-header{grid-column:1 / -1;display:flex;justify-content:flex-end;margin-bottom:10px}.discover-btn{min-width:180px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.discovery-modal{background:var(--bg-card);border-radius:var(--radius-lg);width:90%;max-width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:18px;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:20px;overflow-y:auto}.discovery-summary{background:var(--bg-secondary);padding:15px;border-radius:var(--radius-md);margin-bottom:20px;text-align:center}.discovery-summary p{margin:5px 0;color:var(--text-secondary)}.no-results{text-align:center;color:var(--text-muted);padding:30px}.discovered-list{display:flex;flex-direction:column;gap:12px}.discovered-item{display:flex;justify-content:space-between;align-items:center;padding:15px;border-radius:var(--radius-md);border:1px solid var(--border-color)}.discovered-item.known{background:var(--bg-secondary)}.discovered-item.new{background:#3b82f61a;border-color:var(--primary-color)}.discovered-info h4{margin:0 0 8px;font-size:14px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.discovered-info p{margin:4px 0;font-size:12px;color:var(--text-secondary)}.known-badge,.new-badge{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:500;text-transform:uppercase}.known-badge{background:var(--bg-secondary);color:var(--text-muted)}.new-badge{background:var(--primary-color);color:#fff}.discovered-actions{flex-shrink:0}@media (max-width: 768px){.controller-list{grid-template-columns:1fr}.discovered-item{flex-direction:column;align-items:flex-start;gap:12px}.discovered-actions,.discovered-actions button{width:100%}}.user-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px 16px;transition:all var(--transition-normal);display:flex;flex-direction:row;align-items:center;gap:16px}.user-card:hover{border-color:var(--border-subtle);background:var(--bg-hover)}.user-card.disabled{opacity:.7}.user-status{display:flex;align-items:center;gap:8px;width:80px;flex-shrink:0}.user-status .status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.user-status.enabled .status-indicator{background:var(--success-color);box-shadow:0 0 6px #22c55e80}.user-status.disabled .status-indicator{background:var(--text-muted)}.user-status .status-text{font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.05em}.user-status.enabled .status-text{color:var(--success-color)}.user-status.disabled .status-text{color:var(--text-muted)}.user-info{flex:1;min-width:0;display:flex;align-items:center;gap:16px}.user-name{font-size:15px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:150px}.user-badge-container{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;padding:4px 10px;border-radius:16px;font-size:12px}.badge-icon{font-size:12px}.badge-number{font-family:SF Mono,Monaco,Inconsolata,monospace;font-weight:600;letter-spacing:.05em}.user-department{color:var(--text-muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-actions{display:flex;gap:6px;flex-shrink:0}.user-actions .btn,.btn-sm{padding:6px 12px;font-size:12px}.btn-warning{background:#f59e0b26;color:var(--locked-color);border:1px solid rgba(245,158,11,.3)}.btn-warning:hover{background:#f59e0b40}.btn-success{background:#22c55e26;color:var(--success-color);border:1px solid rgba(34,197,94,.3)}.btn-success:hover{background:#22c55e40}.btn-danger{background:#ef444426;color:var(--error-color);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444440}@media (max-width: 768px){.user-card{flex-direction:column;align-items:stretch;padding:16px;gap:12px;border-radius:var(--radius-lg)}.user-status{width:auto}.user-info{flex-direction:column;align-items:flex-start;gap:8px}.user-name{font-size:16px;min-width:0}.user-badge-container{padding:6px 12px;font-size:13px}.user-actions{margin-top:8px;padding-top:12px;border-top:1px solid var(--border-color)}.user-actions .btn{flex:1}}@media (max-width: 480px){.user-actions{flex-wrap:wrap}}.user-list{display:flex;flex-direction:column;gap:8px;margin-top:20px}.user-list-grouped{display:flex;flex-direction:column;gap:12px;margin-top:20px}.user-items{display:flex;flex-direction:column;gap:8px}.user-list-empty{text-align:center;padding:40px;color:var(--text-muted);background:var(--bg-card);border:1px dashed var(--border-color);border-radius:var(--radius-lg);margin-top:20px}.user-list-empty p{margin:0;font-size:14px}@media (max-width: 768px){.user-list,.user-items{display:grid;grid-template-columns:1fr;gap:16px}}.user-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.user-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:450px;max-height:90vh;overflow-y:auto}.user-form-title{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:20px;letter-spacing:-.01em}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-group input[type=text],.form-group input[type=email]{width:100%;padding:10px 12px;font-size:14px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition-fast)}.form-group input[type=text]:focus{outline:none;border-color:var(--primary-color)}.form-group input.readonly{background:var(--bg-secondary);cursor:not-allowed;opacity:.7}.form-group-checkbox label{display:flex;align-items:center;gap:8px;cursor:pointer}.form-group-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer}.form-group-checkbox span{font-size:14px;color:var(--text-primary)}.error-text{display:block;color:var(--error-color);font-size:12px;margin-top:4px}.help-text{display:block;color:var(--text-muted);font-size:11px;margin-top:4px}.form-actions{display:flex;gap:10px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color)}.form-actions .btn{flex:1;padding:10px 16px}.badge-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.badge-label-row label{margin-bottom:0}.scan-toggle{padding:4px 10px;font-size:11px;font-weight:500;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.scan-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.scan-toggle.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.scan-mode-active{background:var(--bg-secondary);border-radius:var(--radius-md);padding:16px;margin:-8px -8px 16px;border:2px dashed var(--primary-color)}.scan-instructions{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 0;text-align:center}.scan-icon{color:var(--primary-color);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}.scan-instructions p{font-size:14px;color:var(--text-secondary);margin:0}.scan-input{text-align:center;font-size:18px!important;font-weight:600;letter-spacing:2px}.scan-input::placeholder{font-weight:400;letter-spacing:normal;font-size:14px!important}@media (max-width: 480px){.user-form{padding:16px}.form-actions{flex-direction:column-reverse}}.badge-lookup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.badge-lookup-modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.badge-lookup-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.badge-lookup-header h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.01em}.modal-close{background:none;border:none;font-size:28px;color:var(--text-muted);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.badge-lookup-content{padding:24px}.scan-area{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 0 24px}.scan-icon-large{color:var(--primary-color);animation:pulse 2s infinite}.scan-prompt{font-size:16px;color:var(--text-secondary);margin:0;text-align:center}.badge-input-group{display:flex;gap:12px;margin-bottom:20px}.badge-input-group input{flex:1;padding:12px 16px;font-size:14px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition-fast)}.badge-input-group input:focus{outline:none;border-color:var(--primary-color)}.badge-input-group input.scan-input-large{text-align:center;font-size:20px;font-weight:600;letter-spacing:2px}.badge-input-group input.scan-input-large::placeholder{font-size:14px;font-weight:400;letter-spacing:normal}.lookup-error{display:flex;align-items:center;gap:12px;padding:16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--error-color)}.lookup-error svg{flex-shrink:0}.user-result{animation:slideUp .3s ease-out}.user-result-header{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:20px}.user-status-indicator{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;flex-shrink:0}.user-status-indicator[data-enabled=true]{background:#22c55e33;color:var(--success-color)}.user-status-indicator[data-enabled=false]{background:#ef444433;color:var(--error-color)}.user-result-info{flex:1;min-width:0}.user-result-info h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge-display{font-size:13px;color:var(--text-muted);font-family:Courier New,monospace}.user-result-details{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-color)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.detail-value{font-size:14px;color:var(--text-primary)}.status-badge{padding:4px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:500}.status-badge.active{background:#22c55e33;color:var(--success-color)}.status-badge.inactive{background:#ef444433;color:var(--error-color)}.user-result-actions{display:flex;gap:12px;padding-top:16px;border-top:1px solid var(--border-color)}.user-result-actions .btn{flex:1;padding:10px 16px}@media (max-width: 480px){.badge-lookup-modal{max-width:100%;margin:0 10px}.badge-lookup-header,.badge-lookup-content{padding:16px}.badge-input-group,.user-result-actions{flex-direction:column}}.activity-feed{width:100%}.no-activity{text-align:center;padding:40px 20px;color:var(--text-muted);background:var(--bg-card);border:1px dashed var(--border-color);border-radius:var(--radius-lg)}.activity-list{display:flex;flex-direction:column;gap:4px}.activity-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);transition:all .2s ease}.activity-item:hover{background:var(--bg-secondary);border-color:var(--border-subtle)}.activity-item.access{border-left:3px solid var(--primary-color)}.activity-item.unlock.success{border-left:3px solid var(--success-color)}.activity-item.unlock.failed{border-left:3px solid var(--error-color)}.activity-icon{font-size:1.125rem;width:1.5rem;text-align:center;flex-shrink:0}.activity-content{flex:1;min-width:0}.activity-description{display:flex;flex-wrap:wrap;gap:4px;align-items:center;font-size:13px}.activity-user{font-weight:600;color:var(--text-primary)}.activity-action{color:var(--text-muted)}.activity-door{font-weight:500;color:var(--primary-color)}.activity-duration{color:var(--text-muted);font-size:12px}.activity-error{margin-top:4px;padding:4px 8px;background:#ef44441a;color:var(--error-color);border-radius:4px;font-size:12px}.activity-reason{margin-top:2px;color:var(--text-muted);font-size:12px;font-style:italic}.activity-time{color:var(--text-muted);font-size:12px;white-space:nowrap;flex-shrink:0}.pagination{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.page-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:6px 10px;border-radius:var(--radius-sm);font-size:12px;cursor:pointer;min-width:32px;transition:all .15s ease}.page-btn:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--border-subtle)}.page-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:var(--bg-color);font-weight:600}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-btn.nav-btn{padding:6px 12px}.page-ellipsis{color:var(--text-muted);padding:0 4px;font-size:12px}.activity-legend{display:flex;gap:16px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color);justify-content:center}.legend-item{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:12px}.legend-icon{font-size:14px}@media (max-width: 640px){.activity-item{flex-direction:column;align-items:flex-start;gap:4px}.activity-icon{width:auto}.activity-time{align-self:flex-end}.activity-legend{flex-wrap:wrap;gap:12px}}.admin-panel{width:100%}.admin-tabs{display:flex;gap:4px;background:var(--bg-secondary);padding:4px;border-radius:var(--radius-md);margin-bottom:24px;width:fit-content}.admin-tab{padding:8px 20px;background:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{background:var(--bg-card);color:var(--text-primary)}.group-list-container{width:100%}.group-list-empty{text-align:center;padding:40px 20px;color:var(--text-muted);background:var(--bg-card);border:1px dashed var(--border-color);border-radius:var(--radius-lg);font-size:14px}.group-list{display:flex;flex-direction:column;gap:8px}.group-card{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);gap:16px;transition:all .2s ease}.group-card:hover{background:var(--bg-secondary);border-color:var(--border-subtle)}.group-card-info{flex:1;min-width:0}.group-card-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.group-card-description{font-size:13px;color:var(--text-secondary);margin-bottom:6px}.group-card-count{font-size:12px;color:var(--text-muted)}.group-card-actions{display:flex;gap:8px;flex-shrink:0}.btn-sm{padding:6px 12px;font-size:12px}.btn-danger{background:transparent;color:var(--error-color);border:1px solid var(--error-color)}.btn-danger:hover{background:#ef44441a}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:var(--text-secondary)}.form-input{width:100%;padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-glow)}.form-textarea{resize:vertical;min-height:80px}.modal-large{max-width:600px}.members-controls{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.members-controls .search-input{width:100%}.members-filters{display:flex;gap:16px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}.members-list{max-height:400px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-md)}.members-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:14px}.member-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-color);gap:12px}.member-item:last-child{border-bottom:none}.member-item.assigned{background:#22d3ee0d}.member-info{flex:1;min-width:0}.member-name{display:block;font-size:14px;font-weight:500;color:var(--text-primary)}.member-subtitle{display:block;font-size:12px;color:var(--text-muted);margin-top:2px}@media (max-width: 600px){.group-card{flex-direction:column;align-items:stretch}.group-card-actions{justify-content:flex-end}.members-filters{flex-direction:column;gap:8px}}.toast{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-md);margin-bottom:10px;box-shadow:var(--shadow-lg);animation:slideInRight .2s ease;min-width:320px;max-width:420px;border:1px solid transparent}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background:#22c55e26;border-color:#22c55e4d;color:var(--success-color)}.toast-error{background:#ef444426;border-color:#ef44444d;color:var(--error-color)}.toast-warning{background:#f59e0b26;border-color:#f59e0b4d;color:var(--warning-color)}.toast-info{background:#22d3ee26;border-color:#22d3ee4d;color:var(--primary-color)}.toast-icon{font-size:18px;flex-shrink:0}.toast-message{flex:1;font-size:14px;font-weight:500}.toast-close{background:transparent;color:inherit;opacity:.7;width:24px;height:24px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition-fast);flex-shrink:0}.toast-close:hover{opacity:1;background:#ffffff1a}.toast-container{position:fixed;top:20px;right:20px;z-index:9999}@media (max-width: 480px){.toast-container{top:10px;right:10px;left:10px}.toast-container .toast{min-width:auto;max-width:100%}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{margin-top:16px;color:var(--text-muted);font-size:14px}.app{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:24px}.tab-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap}.search-input{flex:1;min-width:280px;padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-glow)}.search-input::placeholder{color:var(--text-muted)}.door-count,.controller-count,.user-count,.activity-count,.group-count{padding:8px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;font-size:14px;white-space:nowrap}.doors-tab,.users-tab,.controllers-tab,.activity-tab,.groups-tab{width:100%}.checkbox-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:14px;color:var(--text-secondary);white-space:nowrap}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-color);cursor:pointer}.checkbox-label span{-webkit-user-select:none;user-select:none}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:16px 20px;color:var(--error-color);text-align:center;margin:20px 0;font-size:14px}.btn{padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:var(--primary-color);color:var(--bg-color)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);box-shadow:0 0 20px var(--primary-glow)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover:not(:disabled){background:var(--border-subtle);border-color:var(--text-muted)}.btn-danger{background:#dc2626;color:#fff;border:none}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.app-main{padding:16px}.tab-controls{flex-direction:column;align-items:stretch}.search-input{min-width:100%}}:root{--primary-color: #22d3ee;--primary-dark: #06b6d4;--primary-glow: rgba(34, 211, 238, .15);--success-color: #22c55e;--error-color: #ef4444;--warning-color: #f59e0b;--locked-color: #f59e0b;--bg-color: #09090b;--bg-secondary: #18181b;--bg-card: #1f1f23;--bg-elevated: #27272a;--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-muted: #71717a;--border-color: #27272a;--border-subtle: #3f3f46;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .6);--transition-fast: .15s ease;--transition-normal: .2s ease;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-color);min-height:100vh;color:var(--text-primary);line-height:1.5}code{font-family:JetBrains Mono,Fira Code,monospace}button{cursor:pointer;border:none;outline:none;font-family:inherit}input{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--primary-glow);color:var(--text-primary)}
