body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0}code{font-family:Courier New,Courier,monospace}*{box-sizing:border-box}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:15px;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;font-size:2.5em;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.login-title{color:#333;font-size:1.8em;margin-bottom:10px}.login-subtitle{color:#666;font-size:.95em}.login-form{gap:20px}.form-group,.login-form{display:flex;flex-direction:column}.form-label{color:#333;display:block;font-size:.95em;font-weight:600;margin-bottom:8px}.form-input{border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:1em;padding:14px 16px;width:100%}.password-field{position:relative}.password-input{padding-right:45px}.password-toggle{background:none;border:none;cursor:pointer;font-size:1.2em;padding:5px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;font-size:.9em;padding:12px 16px}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.05em;font-weight:600;margin-top:10px;padding:14px}.login-button:disabled{cursor:not-allowed;opacity:.6}.login-demo{border-top:1px solid #e9ecef;color:#666;font-size:.9em;margin-top:20px;padding-top:20px;text-align:center}.login-demo strong{background:#f8f9fa;border-radius:4px;color:#667eea;margin:0 2px;padding:2px 8px}.alert{align-items:center;animation:slideIn .3s ease-out;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;gap:12px;max-width:500px;min-width:300px;padding:16px 20px;position:fixed;right:20px;top:20px;z-index:9999}.alert-success{background:#d4edda;border:2px solid #c3e6cb;color:#155724}.alert-error{background:#f8d7da;border:2px solid #f5c6cb;color:#721c24}.alert-warning{background:#fff3cd;border:2px solid #ffeaa7;color:#856404}.alert-info{background:#d1ecf1;border:2px solid #bee5eb;color:#0c5460}.alert-icon{flex-shrink:0;font-size:1.5em;font-weight:700}.alert-message{flex:1 1;font-size:.95em;font-weight:500}.alert-close{background:none;border:none;color:inherit;cursor:pointer;flex-shrink:0;font-size:1.5em;line-height:1;opacity:.7;padding:0 5px}.alert-close:hover{opacity:1}.confirm-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.confirm-dialog{background:#fff;border-radius:15px;box-shadow:0 10px 40px #0000004d;max-width:450px;width:100%}.confirm-header{border-top-left-radius:15px;border-top-right-radius:15px;color:#fff;font-size:1.2em;font-weight:600;padding:20px 25px}.confirm-header-danger{background:linear-gradient(135deg,#dc3545,#c82333)}.confirm-header-warning{background:linear-gradient(135deg,#ffc107,#e0a800)}.confirm-header-info{background:linear-gradient(135deg,#17a2b8,#138496)}.confirm-header-default{background:linear-gradient(135deg,#667eea,#764ba2)}.confirm-body{padding:30px 25px}.confirm-message{color:#495057;font-size:1em;line-height:1.6;margin:0;white-space:pre-line}.confirm-footer{border-top:1px solid #e9ecef;display:flex;gap:12px;padding:20px 25px}.confirm-btn-cancel{background:#e9ecef;color:#495057}.confirm-btn-cancel,.confirm-btn-confirm{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1em;font-weight:600;padding:12px}.confirm-btn-confirm{color:#fff}.confirm-btn-danger{background:linear-gradient(135deg,#dc3545,#c82333)}.confirm-btn-warning{background:linear-gradient(135deg,#ffc107,#e0a800)}.confirm-btn-info{background:linear-gradient(135deg,#17a2b8,#138496)}.confirm-btn-default{background:linear-gradient(135deg,#667eea,#764ba2)}.input-prompt-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.input-prompt-dialog{background:#fff;border-radius:15px;box-shadow:0 10px 40px #0000004d;max-width:450px;width:100%}.input-prompt-header{background:linear-gradient(135deg,#667eea,#764ba2);border-top-left-radius:15px;border-top-right-radius:15px;color:#fff;font-size:1.2em;font-weight:600;padding:20px 25px}.input-prompt-body{padding:30px 25px}.input-prompt-message{color:#495057;font-size:1em;line-height:1.6;margin:0 0 15px}.input-prompt-field{border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-size:1em;padding:12px;width:100%}.input-prompt-footer{border-top:1px solid #e9ecef;display:flex;gap:12px;padding:20px 25px}.input-prompt-btn-cancel{background:#e9ecef;color:#495057}.input-prompt-btn-cancel,.input-prompt-btn-confirm{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1em;font-weight:600;padding:12px}.input-prompt-btn-confirm{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.license-form-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.license-form-modal{background:#fff;border-radius:15px;max-height:90vh;max-width:700px;overflow-y:auto;width:100%}.license-form-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px 15px 0 0;color:#fff;display:flex;justify-content:space-between;padding:25px 30px}.license-form-header h2{font-size:1.5em;margin:0}.license-form-close{background:none;border:none;color:#fff;cursor:pointer;font-size:2em;line-height:1;padding:0}.license-form{padding:30px}.license-form-info{margin-bottom:20px}.license-form-info strong{color:#333;display:block;font-size:.95em;font-weight:600;margin-bottom:8px}.license-form-input,.license-form-select,.license-form-textarea{border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:1em;padding:12px 16px;width:100%}.license-form-mac{font-family:Courier New,monospace}.license-form-textarea{resize:vertical}.license-form-hint{color:#6c757d;display:block;font-size:.85em;margin-top:5px}.license-form-actions{border-top:2px solid #e9ecef;display:flex;gap:15px;margin-top:30px;padding-top:20px}.license-form-btn-cancel{background:#e9ecef;border:none;border-radius:8px;color:#495057;cursor:pointer;flex:1 1;font-size:1em;font-weight:600;padding:14px}.license-form-btn-cancel:disabled{cursor:not-allowed;opacity:.6}.license-form-btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:1em;font-weight:600;padding:14px}.license-form-btn-submit:disabled{cursor:not-allowed;opacity:.6}.license-form-modal-wide{max-width:760px}.license-type-toggle{display:flex;gap:10px;margin-bottom:16px}.type-option{align-items:center;border:2px solid #cbd5e1;border-radius:10px;cursor:pointer;display:flex;flex:1 1;font-weight:600;gap:8px;justify-content:center;padding:10px 12px}.type-option.active{background:#eff6ff;border-color:#2563eb;color:#1d4ed8}.systems-section{border:1px solid #e2e8f0;border-radius:10px;margin-bottom:12px;padding:12px}.systems-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.system-remove-btn,.systems-add-btn{background:#fff;border:1px solid #cbd5e1;border-radius:8px;cursor:pointer;font-size:12px;padding:6px 10px}.system-row{display:flex;gap:8px;margin-bottom:8px}.system-row .license-form-input{flex:1 1}.details-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.details-modal{background:#fff;border-radius:15px;max-height:90vh;max-width:700px;overflow-y:auto;width:100%}.details-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px 15px 0 0;color:#fff;display:flex;justify-content:space-between;padding:25px 30px}.details-header h2{font-size:1.5em;margin:0}.details-close{background:none;border:none;color:#fff;cursor:pointer;font-size:2em;line-height:1;padding:0}.details-content{padding:30px}.details-section{border-bottom:2px solid #e9ecef;margin-bottom:20px;padding-bottom:20px}.details-section:last-child{border-bottom:none}.details-section-title{color:#495057;font-size:1.1em;margin-bottom:15px}.details-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:150px 1fr;padding:12px 0}.details-label{color:#6c757d;font-size:.9em;font-weight:600}.details-value{color:#212529}.details-code{background:#f8f9fa;border-radius:6px;font-family:Courier New,monospace;font-size:.95em;padding:8px 12px}.details-status{border-radius:20px;display:inline-block;font-size:.85em;font-weight:600;padding:6px 14px;text-transform:uppercase}.details-notes{border-top:2px solid #e9ecef;padding-top:20px}.details-notes-content{background:#f8f9fa;border-radius:8px;color:#495057;padding:15px}.extend-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.extend-modal{background:#fff;border-radius:15px;max-width:500px;width:100%}.extend-header{align-items:center;background:linear-gradient(135deg,#ffc107,#ff9800);border-radius:15px 15px 0 0;color:#fff;display:flex;justify-content:space-between;padding:25px 30px}.extend-header h2{font-size:1.5em;margin:0}.extend-close{background:none;border:none;color:#fff;cursor:pointer;font-size:2em;line-height:1;padding:0}.extend-form{padding:30px}.extend-info{background:#f8f9fa;border-radius:8px;line-height:1.8;margin-bottom:20px;padding:15px}.extend-info strong{color:#333}.extend-info code{background:#fff;border-radius:4px;font-family:Courier New,monospace;padding:2px 6px}.extend-status-expired{color:#dc3545;font-weight:600}.extend-field{margin-bottom:20px}.extend-label{color:#333;display:block;font-weight:600;margin-bottom:8px}.extend-input{border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-size:1em;padding:12px;width:100%}.extend-hint{color:#666;display:block;font-size:.9em;margin-top:5px}.extend-actions{display:flex;gap:15px}.extend-btn-cancel{background:#e9ecef;border:none;border-radius:8px;color:#495057;cursor:pointer;flex:1 1;font-size:1em;font-weight:600;padding:14px}.extend-btn-cancel:disabled{cursor:not-allowed;opacity:.6}.extend-btn-submit{background:linear-gradient(135deg,#ffc107,#ff9800);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:1em;font-weight:600;padding:14px}.extend-btn-submit:disabled{cursor:not-allowed;opacity:.6}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.modal-content{background:#fff;border-radius:15px;box-shadow:0 10px 40px #0000004d;max-width:500px;padding:30px;text-align:left;width:100%}.modal-message{color:#333;font-size:1em;margin-bottom:30px;white-space:pre-line}.modal-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;float:right;font-size:1em;font-weight:600;padding:12px 24px}.modal-button:hover{opacity:.9}.approve-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.approve-modal{background:#fff;border-radius:15px;max-width:500px;width:100%}.approve-header{align-items:center;background:linear-gradient(135deg,#28a745,#20c997);border-radius:15px 15px 0 0;color:#fff;display:flex;justify-content:space-between;padding:25px 30px}.approve-header h2{font-size:1.5em;margin:0}.approve-close{background:none;border:none;color:#fff;cursor:pointer;font-size:2em;line-height:1;padding:0}.approve-form{padding:30px}.approve-info{background:#f8f9fa;border-radius:8px;line-height:1.8;margin-bottom:20px;padding:15px}.approve-info strong{color:#333}.approve-info code{background:#fff;border-radius:4px;font-family:Courier New,monospace;padding:2px 6px}.approve-device-row{display:flex;flex-direction:column;gap:6px;margin-top:4px}.approve-device-id{display:block;font-size:.82em;line-height:1.45;overflow-wrap:anywhere;padding:8px 10px!important;white-space:normal;word-break:break-all}.approve-field{margin-bottom:20px}.approve-label{color:#333;display:block;font-weight:600;margin-bottom:8px}.approve-select,.approve-textarea{border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:1em;padding:12px 16px;width:100%}.approve-textarea{resize:vertical}.approve-actions{display:flex;gap:15px}.approve-btn-cancel{background:#e9ecef;border:none;border-radius:8px;color:#495057;cursor:pointer;flex:1 1;font-size:1em;font-weight:600;padding:14px}.approve-btn-cancel:disabled{cursor:not-allowed;opacity:.6}.approve-btn-submit{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:1em;font-weight:600;padding:14px}.approve-btn-submit:disabled{cursor:not-allowed;opacity:.6}.device-info-cell-wrap{align-items:center;display:flex;flex-wrap:wrap;gap:8px;position:relative}.device-info-hostname{color:#333;font-size:.9em;word-break:break-word}.device-info-view-btn{background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;color:#334155;cursor:pointer;flex-shrink:0;font-size:.75em;font-weight:600;padding:2px 8px}.device-info-view-btn:hover{background:#e2e8f0}.device-info-popover{background:#fff;border:1px solid #cbd5e1;border-radius:10px;box-shadow:0 8px 24px #0f172a26;left:0;max-width:340px;min-width:260px;padding:12px 14px;position:absolute;top:calc(100% + 6px);z-index:20}.device-info-popover-title{color:#64748b;font-size:.78em;font-weight:700;letter-spacing:.04em;margin-bottom:8px;text-transform:uppercase}.device-info-popover-list{margin:0}.device-info-popover-row{grid-gap:8px;display:grid;font-size:.82em;gap:8px;grid-template-columns:88px 1fr;margin-bottom:6px}.device-info-popover-row dt{color:#64748b;font-weight:600;margin:0}.device-info-popover-row dd{color:#1e293b;margin:0;word-break:break-all}.org-groups-panel{background:#fff;border-radius:10px;box-shadow:0 2px 10px #00000014;margin-bottom:20px;padding:16px}.org-groups-panel h3{margin:0 0 12px}.org-group-card{align-items:flex-start;border:1px solid #e2e8f0;border-radius:10px;display:flex;gap:16px;justify-content:space-between;margin-bottom:10px;padding:12px}.org-group-meta{color:#64748b;font-size:12px;margin-top:4px}.org-group-systems{font-size:13px;margin:8px 0 0 18px;padding:0}.requests-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.stat-card{border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px}.stat-label{color:#666;font-size:.9em;letter-spacing:1px;margin-bottom:10px;text-transform:uppercase}.stat-approved{color:#28a745}.stat-rejected{color:#dc3545}.requests-filters{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:20px}.filter-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.filter-label{font-weight:600;margin-right:10px}.refresh-btn{margin-left:auto}.requests-table-container{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.requests-table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto;width:100%}.loading-container{padding:60px 20px;text-align:center}.empty-icon{font-size:3em}.empty-title{color:#495057;font-size:1.2em;font-weight:600}.empty-subtitle{color:#6c757d}.requests-table{border-collapse:collapse;min-width:1500px;table-layout:fixed;width:100%}.requests-table thead{background:#f8f9fa}.requests-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.9em;font-weight:600;padding:12px 14px;text-align:left;text-transform:uppercase;vertical-align:top;white-space:nowrap}.requests-table td{border-bottom:1px solid #e9ecef;padding:12px 14px;vertical-align:top}.mac-code{background:#f8f9fa;border-radius:4px;font-family:Courier New,monospace;font-size:.85em;padding:4px 8px}.device-id-cell{max-width:160px;min-width:140px}.device-info-cell{max-width:220px;min-width:160px;width:180px}.status-cell{min-width:100px}.actions-cell{background:#fff}.actions-cell,.requests-table thead th:last-child{box-shadow:-6px 0 8px #0000000f;min-width:150px;position:-webkit-sticky;position:sticky;right:0}.requests-table thead th:last-child{background:#f8f9fa;z-index:2}.request-status{border-radius:20px;font-size:.85em;font-weight:600;padding:6px 14px;text-transform:uppercase}.status-approved{background:#d4edda;color:#155724}.status-rejected{background:#f8d7da;color:#721c24}.status-default{background:#e9ecef;color:#495057}.request-date{color:#666;font-size:.9em;line-height:1.4;min-width:140px;white-space:nowrap}.action-buttons{align-items:flex-start;display:flex;flex-wrap:wrap;gap:8px}.btn-approve{background:#28a745}.btn-approve,.btn-reject{border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85em;font-weight:600;padding:8px 12px}.btn-reject{background:#dc3545}.btn-delete{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85em;font-weight:600;padding:8px 12px}.add-system-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:2100}.add-system-modal{background:#fff;border-radius:12px;box-shadow:0 12px 40px #0000002e;max-width:420px;width:100%}.add-system-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:16px 18px}.add-system-header h3{color:#1e3a5f;margin:0}.add-system-close{background:#0000;border:none;color:#64748b;cursor:pointer;font-size:24px}.add-system-form{display:flex;flex-direction:column;gap:14px;padding:18px}.add-system-form label{color:#334155;display:flex;flex-direction:column;font-size:13px;gap:6px}.add-system-form input{border:1px solid #cbd5e1;border-radius:8px;font-size:14px;padding:10px 12px}.add-system-error{color:#b91c1c;font-size:13px}.add-system-actions{display:flex;gap:10px;margin-top:4px}.add-system-actions button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-weight:600;padding:10px 12px}.add-system-actions button[type=button]{background:#e2e8f0;color:#334155}.add-system-actions button[type=submit]{background:#2563eb;color:#fff}.add-system-actions button:disabled{cursor:not-allowed;opacity:.6}.event-timeline{margin-top:12px}.event-timeline-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.event-filter-btn{background:#fff;border:1px solid #cbd5e1;border-radius:999px;cursor:pointer;font-size:12px;padding:4px 10px}.event-filter-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.event-timeline-list{display:flex;flex-direction:column;gap:8px}.event-row{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px}.event-row-invalid{background:#fef2f2;border-color:#fecaca}.event-row-main{grid-gap:8px;align-items:center;display:grid;font-size:13px;gap:8px;grid-template-columns:24px 90px 120px 1fr 160px}.event-icon{font-size:16px}.event-badge{color:#475569;font-size:11px;font-weight:700;text-transform:uppercase}.event-system{color:#1e3a5f;font-weight:600}.event-description{color:#334155}.event-time{color:#64748b;font-size:12px;text-align:right}.event-expand-btn{background:#0000;border:none;color:#b91c1c;cursor:pointer;font-size:12px;margin-top:8px;padding:0}.event-device-json{background:#fff;border-radius:6px;font-size:12px;margin:8px 0 0;padding:8px;white-space:pre-wrap}.event-timeline-empty{color:#64748b;padding:16px;text-align:center}@media (max-width:900px){.event-row-main{grid-template-columns:1fr}.event-time{text-align:left}}.customer-detail-overlay{background:#0f172a73;display:flex;inset:0;justify-content:flex-end;position:fixed;z-index:2000}.customer-detail-panel{background:#f8fafc;box-shadow:-8px 0 24px #0000001f;height:100vh;overflow:auto;width:min(760px,100vw)}.customer-detail-header{align-items:flex-start;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:1}.customer-detail-header h2{color:#1e3a5f;margin:0}.customer-detail-subtitle{color:#64748b;font-size:13px;margin:4px 0 0}.customer-detail-close{background:#0000;border:none;color:#64748b;cursor:pointer;font-size:28px;line-height:1}.customer-detail-body{padding:20px 24px 32px}.customer-info-grid{grid-gap:12px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr));padding:16px}.customer-info-grid div{display:flex;flex-direction:column;font-size:13px;gap:4px}.customer-info-grid strong{color:#64748b;font-size:11px;text-transform:uppercase}.customer-systems-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin:24px 0 12px}.customer-systems-title,.customer-timeline-title{color:#1e3a5f;margin:24px 0 12px}.customer-systems-header .customer-systems-title{margin:0}.add-system-btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 14px}.add-system-btn:hover{background:#1d4ed8}.customer-systems-list{display:flex;flex-direction:column;gap:10px}.customer-system-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px}.customer-system-card summary{grid-gap:12px;align-items:center;cursor:pointer;display:grid;gap:12px;grid-template-columns:1fr auto auto}.system-name{color:#1e3a5f;font-weight:700}.system-status{background:#e2e8f0;border-radius:999px;font-size:11px;font-weight:700;padding:3px 8px;text-transform:uppercase}.system-status-active{background:#dcfce7;color:#166534}.system-details{grid-gap:6px;display:grid;font-size:13px;gap:6px;margin-top:10px}.customer-detail-error,.customer-detail-loading{padding:24px}.customer-detail-error{color:#b91c1c}.dashboard-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.dashboard-header-card{background:#fff;border-radius:15px;margin-bottom:20px;overflow:hidden}.dashboard-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;padding:30px}.header-info h1{font-size:2em;margin-bottom:5px}.header-info p{font-size:.95em;opacity:.9}.header-user{align-items:center;display:flex;gap:20px}.user-info{text-align:right}.user-name{font-size:1em;font-weight:600}.user-role{font-size:.85em;opacity:.8;text-transform:capitalize}.logout-btn{background:#fff3;border:2px solid #fff;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.dashboard-tabs{border-top:1px solid #0000001a;display:flex;gap:0}.tab-btn{background:#f8f9fa;border:none;border-bottom:3px solid #0000;color:#6c757d;cursor:pointer;flex:1 1;font-size:1em;font-weight:600;padding:15px}.tab-btn.active{background:#fff;border-bottom-color:#667eea;color:#667eea}.dashboard-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.stat-card{background:#fff;border-radius:12px;padding:25px;text-align:center}.stat-card h3{color:#666;font-size:.9em;letter-spacing:1px;margin-bottom:15px;text-transform:uppercase}.stat-value{font-size:2.5em;font-weight:700}.stat-total{color:#667eea}.stat-active{color:#28a745}.stat-pending{color:#ffc107}.stat-expired{color:#dc3545}.dashboard-controls{align-items:center;background:#fff;border-radius:12px;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:20px;padding:25px}.search-input{border:2px solid #e9ecef;border-radius:8px;flex:1 1;font-size:1em;min-width:300px;padding:12px 20px}.filter-group{display:flex;flex-wrap:wrap;gap:10px}.filter-btn{background:#fff;border:2px solid #e9ecef;border-radius:8px;color:#495057;cursor:pointer;font-weight:500;padding:10px 20px;text-transform:capitalize}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.new-license-btn{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;white-space:nowrap}.licenses-table-card{background:#fff;border-radius:12px}.table-header{align-items:center;border-bottom:2px solid #e9ecef;border-radius:12px 12px 0 0;display:flex;gap:15px;justify-content:space-between;padding:20px 30px}.table-header h3{color:#333;font-size:1.3em;margin:0}.refresh-indicator{animation:pulse 1.5s ease-in-out infinite;color:#667eea;font-size:.9em}.refresh-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.loading-state{padding:60px 20px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto 20px;width:50px}.empty-state{font-size:3em;padding:60px 20px;text-align:center}.empty-state p{color:#495057;font-size:.4em}.licenses-table-scroll{-webkit-overflow-scrolling:touch;border-radius:0 0 12px 12px;overflow-x:auto;width:100%}.licenses-table{border-collapse:initial;border-spacing:0;min-width:100%;table-layout:auto;width:-webkit-max-content;width:max-content}.licenses-table thead{background:#f8f9fa}.col-client{width:140px}.col-clinic{width:90px}.col-phone{width:105px}.col-city{width:90px}.col-license-key{width:145px}.col-application,.col-status{width:95px}.col-activated{width:85px}.col-expiry{width:110px}.col-device-info{width:280px}.col-actions{width:165px}.licenses-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.78em;font-weight:600;letter-spacing:.3px;line-height:1.25;overflow-wrap:normal;padding:10px 12px;text-align:left;text-transform:uppercase;vertical-align:bottom;white-space:normal;word-break:keep-all}.licenses-table th.header-device,.licenses-table th.header-expiry{min-width:110px}.licenses-table th.header-device{min-width:280px}.licenses-table th.header-app,.licenses-table th.header-status{min-width:95px}.licenses-table td{border-bottom:1px solid #e9ecef;padding:12px 14px;vertical-align:top}.client-cell{max-width:200px;min-width:140px}.client-name{color:#333;font-weight:600;line-height:1.35;overflow-wrap:anywhere;word-break:break-word}.client-email{color:#666;font-size:.82em;line-height:1.4;margin-top:4px;overflow-wrap:anywhere;white-space:normal;word-break:break-all}.client-created{color:#94a3b8;font-size:.78em;margin-top:4px}.org-license-summary{color:#64748b;font-size:.9em;font-style:italic}.city-cell,.clinic-cell,.phone-cell{font-size:.9em;line-height:1.4;max-width:140px;min-width:100px;overflow-wrap:anywhere;white-space:normal;word-break:break-word}.phone-cell{max-width:120px;word-break:break-all}.license-key{background:#f8f9fa;border-radius:5px;color:#495057;display:inline-block;font-family:Courier New,monospace;font-size:.82em;letter-spacing:.5px;max-width:100%;overflow-wrap:anywhere;padding:6px 10px;white-space:normal;word-break:break-all}.license-key-cell{min-width:145px}.application-cell,.status-cell{min-width:95px}.activated-cell{font-size:.85em;line-height:1.35;max-width:220px;min-width:180px;overflow-wrap:anywhere;white-space:normal;word-break:break-word}.expiry-cell{min-width:110px;white-space:nowrap;width:110px}.device-info-cell{max-width:320px;min-width:280px;width:280px}.device-info-summary{color:#495057;display:block;font-size:.82em;line-height:1.4;overflow-wrap:anywhere;white-space:normal;word-break:break-word}.actions-cell,.actions-col{background:#fff;box-shadow:-6px 0 8px #0000000f;max-width:170px;min-width:170px;position:-webkit-sticky;position:sticky;right:0;width:170px;z-index:1}.licenses-table thead th.actions-col{background:#f8f9fa;z-index:2}.license-status{border-radius:20px;display:inline-block;font-size:.85em;font-weight:600;letter-spacing:.5px;padding:6px 14px;text-transform:uppercase}.status-active{background:#d4edda;color:#155724}.status-pending{background:#fff3cd;color:#856404}.status-inactive{background:#d6d8db;color:#383d41}.status-expired{background:#f8d7da;color:#721c24}.yes-badge{color:#28a745;font-weight:600}.no-badge{color:#dc3545;font-weight:600}.mac-address{background:#f8f9fa;border-radius:4px;color:#495057;font-family:Courier New,monospace;font-size:.85em;padding:4px 8px}.action-btns{align-items:stretch;display:flex;flex-direction:column;gap:6px}.action-btns button{border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.8em;font-weight:600;line-height:1.2;padding:8px 10px;text-align:center;white-space:normal}.btn-view{background:#17a2b8}.btn-unbind{background:#dc3545}.btn-inactive{background:#6c757d}.btn-extend{background:#ffc107}.btn-activate{background:#28a745}.history-table-card{background:#fff;border-radius:12px}.history-table-scroll{-webkit-overflow-scrolling:touch;border-radius:0 0 12px 12px;overflow-x:auto;width:100%}.history-table{border-collapse:initial;border-spacing:0;min-width:100%;table-layout:auto;width:-webkit-max-content;width:max-content}.history-table thead{background:#f8f9fa}.history-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.78em;font-weight:600;letter-spacing:.3px;line-height:1.25;padding:10px 12px;text-align:left;text-transform:uppercase;vertical-align:bottom;white-space:normal}.history-table td{border-bottom:1px solid #e9ecef;padding:12px 14px;vertical-align:top}.history-date-cell{color:#495057;font-size:.9em;min-width:150px;white-space:nowrap}.device-id-cell{max-width:200px;min-width:160px}.device-id-code{background:#f8f9fa;border-radius:4px;display:block;font-family:Courier New,monospace;font-size:.72em;line-height:1.45;overflow-wrap:anywhere;padding:6px 8px;white-space:normal;word-break:break-all}.performed-by-cell{font-size:.9em;min-width:140px;overflow-wrap:anywhere;word-break:break-word}.history-action{border-radius:20px;display:inline-block;font-size:.82em;font-weight:600;padding:6px 12px;text-transform:capitalize;white-space:nowrap}.history-action.created{background:#d4edda;color:#155724}.history-action.activated{background:#cce5ff;color:#004085}.history-action.validated{background:#e2e3e5;color:#383d41}.history-action.unbound{background:#fff3cd;color:#856404}.history-action.status_changed{background:#e2e3e5;color:#383d41}.history-action.deactivated,.history-action.inactive{background:#f8d7da;color:#721c24}.history-action.extended{background:#d1ecf1;color:#0c5460}.customer-link-btn{background:#0000;border:none;color:#2563eb;cursor:pointer;font-weight:600;padding:0;text-align:left}.type-badge{border-radius:999px;display:inline-block;font-size:11px;font-weight:700;padding:3px 8px;text-transform:uppercase}.type-badge-individual{background:#e0e7ff;color:#3730a3}.type-badge-organisation{background:#dbeafe;color:#1d4ed8}.invalid-attempt-badge{color:#b91c1c;display:block;font-size:11px;font-weight:700;margin-top:4px}.history-action.invalid_attempt{background:#fee2e2;color:#991b1b}.App{min-height:100vh}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}
/*# sourceMappingURL=main.06c5bf9c.css.map*/