*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--color-bg: #f5f6f8;--color-surface: #ffffff;--color-surface-alt: #f8f9fa;--color-border: #e5e7eb;--color-text: #212529;--color-muted: #6c757d;--color-primary: #0d6efd;--color-primary-strong: #0a58ca;--color-success: #28a745;--color-warning: #ffc107;--color-danger: #dc3545;--color-info: #0dcaf0;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 2px 6px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .12);--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--font-base: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}body{margin:0;font-family:var(--font-base);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}h1,h2,h3,h4,h5,h6{margin:0;font-weight:700;color:var(--color-text)}p{margin:0;color:var(--color-text)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}code{font-family:var(--font-mono)}.page-shell{max-width:1400px;margin:0 auto;padding:20px}.page-stack{display:flex;flex-direction:column;gap:16px}.page-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-md)}.crud-container{width:100%;padding:1.5rem}.crud-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.layout{display:flex;flex-direction:column;min-height:100vh}.header{background-color:#2c3e50;color:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a}.header .header-content{display:flex;justify-content:space-between;align-items:center;width:100%}.header-left{display:flex;align-items:center;gap:1rem}.sidebar-toggle{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .3s}.sidebar-toggle:hover{background-color:#ffffff1a}.header-title{font-size:1.5rem;margin:0;color:#fff}.header-user{display:flex;align-items:center;gap:1rem}.btn-logout{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .3s}.btn-logout:hover{background-color:#c0392b}.main-container{display:flex;flex:1;width:100%;transition:all .3s ease}.sidebar{width:250px;background-color:#34495e;padding:2rem 0;box-shadow:2px 0 4px #0000001a;transition:width .3s ease,padding .3s ease}.sidebar-collapsed{width:0;padding:0;overflow:hidden}.nav-section{margin-bottom:1.5rem}.nav-section-header{display:flex;justify-content:space-between;align-items:center;padding:0 1.5rem .5rem;border-bottom:1px solid #2c3e50}.nav-section-title{color:#bdc3c7;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin:0}.nav-section-toggle{background:none;border:none;color:#bdc3c7;font-size:.8rem;cursor:pointer;padding:.25rem;border-radius:2px;transition:background-color .2s,color .2s}.nav-section-toggle:hover{background-color:#2c3e50;color:#ecf0f1}.nav-list{list-style:none;padding:0;margin:0;animation:slideDown .2s ease-out}.nav-link{display:block;padding:1rem 1.5rem;color:#ecf0f1;text-decoration:none;transition:background-color .3s}.nav-link:hover{background-color:#2c3e50;text-decoration:none}.content{flex:1;padding:2rem;background-color:#ecf0f1;overflow-y:auto}.page-title{color:#2c3e50;margin-bottom:2rem;font-size:2rem;font-weight:700}.page-subtitle{font-size:1.1rem;opacity:.9;margin:0}.section-heading{margin-bottom:var(--space-3);font-size:20px;font-weight:700}.muted-text{color:var(--color-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid transparent;font-weight:600;font-size:14px;cursor:pointer;transition:background-color .2s,border-color .2s,box-shadow .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-strong)}.btn-primary:disabled{background-color:#bdc3c7;cursor:not-allowed;transform:none}.btn-secondary{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-alt);border-color:#cfd3d8}.btn.btn-secondary{background:var(--color-surface);border-color:var(--color-border);display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgb(0,0,0);border-radius:8px;color:var(--color-text);font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;font-size:14px}.btn.btn-secondary:hover:not(:disabled){background:#ffffff40;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.btn.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:transparent;border-color:transparent;color:var(--color-text)}.btn-outline{background:#fff;border-color:#e2e8f0;color:#000103}.btn-outline:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e0;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-outline:active:not(:disabled){transform:translateY(0)}.btn-small{padding:.375rem .75rem;font-size:.75rem}.btn-edit{background-color:#f39c12;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .3s}.btn-edit:hover:not(:disabled){background-color:#e67e22}.btn-delete{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .3s}.btn-delete:hover:not(:disabled){background-color:#c0392b}.btn-view{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .3s}.btn-view:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #0003}.action-buttons{display:flex;gap:8px}.edit-button{padding:6px 14px;background:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:background-color .2s}.edit-button:hover:not(:disabled){background:#0062cc}.view-button{padding:6px 12px;border-radius:6px;border:1px solid #ced4da;background:#fff;color:#343a40;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s,border-color .2s}.view-button:hover:not(:disabled){background:#f8f9fa;border-color:#adb5bd}.btn-refresh{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease;height:fit-content;box-shadow:0 2px 4px #3498db33;display:flex;align-items:center;gap:.5rem}.btn-refresh:hover:not(:disabled){background:linear-gradient(135deg,#2980b9,#1f618d);transform:translateY(-1px);box-shadow:0 4px 8px #3498db4d}.btn-refresh:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #3498db33}.btn-refresh:disabled{background:linear-gradient(135deg,#bdc3c7,#95a5a6);cursor:not-allowed;transform:none;box-shadow:none;opacity:.7}.btn-save,.btn-cancel{padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s}.btn-save{background-color:#27ae60;color:#fff}.btn-save:hover:not(:disabled){background-color:#219a52}.btn-save:disabled{background-color:#bdc3c7;cursor:not-allowed}.btn-cancel{background-color:#95a5a6;color:#fff}.btn-cancel:hover:not(:disabled){background-color:#7f8c8d}.btn-close-modal{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#7f8c8d;padding:.5rem;border-radius:4px;transition:all .3s;line-height:1}.btn-close-modal:hover{background-color:#ecf0f1;color:#2c3e50}.form-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.form-card h2{color:#2c3e50;margin:0 0 1.5rem;font-weight:600}.crud-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#2c3e50;font-weight:500;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .3s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db1a}.form-group textarea{resize:vertical;min-height:100px}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.form-label{display:block;margin-bottom:6px;font-weight:500;color:var(--color-text);font-size:14px}.form-control{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px;background:#fff;transition:border-color .2s,box-shadow .2s}.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 .2rem #0d6efd40}.form-control:disabled{background:#e9ecef;cursor:not-allowed}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow-x:auto;box-shadow:0 2px 4px #0000001a}.data-table th{background-color:#34495e;color:#fff;padding:1rem;text-align:left;font-weight:600;border-bottom:1px solid #2c3e50}.data-table td{padding:1rem;border-bottom:1px solid #ecf0f1;vertical-align:middle}.data-table tbody tr:hover{background-color:#f8f9fa}.data-table tbody tr:last-child td{border-bottom:none}.table-container{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow-x:auto;border:1px solid var(--color-border)}.table-base{width:100%;border-collapse:collapse}.table-base thead{background:var(--color-surface-alt)}.table-base th{padding:14px 16px;text-align:left;font-weight:600;color:#555;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--color-border)}.table-base td{padding:12px 16px;font-size:13px;color:var(--color-text);border-top:1px solid var(--color-border)}.table-base tbody tr{transition:background-color .2s;border-bottom:1px solid #f0f0f0}.table-base tbody tr:hover{background-color:#fafafa}.table-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.table-info{color:#7f8c8d;font-size:.9rem}.items-per-page{display:flex;align-items:center;gap:.5rem}.items-per-page label{font-weight:500;color:#2c3e50}.items-per-page select{padding:.5rem;border:1px solid #bdc3c7;border-radius:4px;background-color:#fff}.actions{display:flex;gap:.5rem}.reports-table{width:100%;border-collapse:collapse}.reports-table thead{background:#f5f5f5}.reports-table th{padding:14px 16px;text-align:left;font-weight:600;color:#555;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e0e0e0}.reports-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background-color .2s}.reports-table tbody tr:hover{background-color:#fafafa}.reports-table td{padding:12px 16px;font-size:13px;color:#333}.reports-table td:last-child{white-space:nowrap}.pagination{display:flex;justify-content:center;align-items:center;padding:1rem 0}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-top:1px solid #ecf0f1;background:#f8f9fa}.pagination-info{color:#7f8c8d;font-size:.9rem}.pagination-controls{display:flex;gap:.5rem;align-items:center}.pagination-btn{padding:.5rem .75rem;border:1px solid #ddd;background:#fff;color:#2c3e50;cursor:pointer;border-radius:4px;transition:all .3s;font-size:.9rem;min-width:40px;text-align:center}.pagination-btn:hover:not(:disabled):not(.ellipsis){background-color:#3498db;color:#000;border-color:#3498db}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background-color:#f8f9fa}.pagination-btn.active{background-color:#3498db;color:#fff;border-color:#3498db}.pagination-btn.ellipsis{cursor:default;background:none;border:none}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.modal-content{background:#fff;border-radius:8px;width:min(1200px,96vw);max-height:90vh;overflow:auto;position:relative;box-shadow:0 10px 25px #0003}.modal-card{width:min(900px,95vw);max-height:90vh;overflow-y:auto;background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);padding:18px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #ecf0f1;background:#f8f9fa}.modal-header h2{margin:0;color:#2c3e50;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#7f8c8d;padding:.5rem;border-radius:4px;transition:all .3s;line-height:1}.modal-close:hover{background-color:#ecf0f1;color:#2c3e50}.modal-body{padding:2rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #ecf0f1;background:#f8f9fa}.modal-loading{display:flex;align-items:center;justify-content:center;padding:3rem}.map-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center}.map-modal{background:#fff;border-radius:8px;width:90%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.map-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee}.map-modal-header h3{margin:0;color:#333}.map-modal-content{padding:1.5rem}.interactive-map-container{margin:1rem 0;border:1px solid #ddd;border-radius:8px;overflow:hidden}.interactive-map-container .leaflet-container{height:400px;width:100%;border-radius:8px 8px 0 0}.map-info{padding:1rem;background:#f8f9fa;border-top:1px solid #eee}.map-info p{margin:.5rem 0}.modal-error{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1rem;border:1px solid #fcc}.card-body{padding:2rem}.card-footer{padding:1rem 2rem;border-top:1px solid #ecf0f1;background:#f8f9fa}.stat-card{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.25rem 1.5rem;border-radius:12px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;min-width:200px;text-align:center}.stat-card:hover{background:#fff3;transform:translateY(-2px)}.stat-value{font-size:1.5rem;font-weight:700;line-height:1;margin-bottom:.5rem;color:#fff}.stat-label{font-size:.875rem;opacity:.9;font-weight:500;color:#fff}.page-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:2rem;margin-bottom:1.5rem;color:#fff;box-shadow:0 8px 32px #667eea4d;position:relative;overflow:hidden}.page-header:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:200%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);transform:rotate(45deg);animation:shimmer 3s infinite}.page-header .header-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;position:relative;z-index:2}.header-title-section h1{margin:0;font-size:2rem;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2)}.header-description{margin:.5rem 0 0;font-size:1rem;opacity:.9;font-weight:400;color:var(--color-bg)}.header-left .page-title{font-size:2rem;margin:0 0 .5rem;font-weight:700}.header-left .page-subtitle{font-size:1.1rem;opacity:.9;margin:0}.header-stats{display:flex;gap:1.5rem}.header-actions{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2}.last-update{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.75rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.update-label{font-size:.875rem;opacity:.9;font-weight:500}.update-time{font-size:.875rem;font-weight:600;color:#fffffff2}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-muted{background:#e2e3e5;color:#6c757d}.badge-info{background:#e7f1ff;color:#0c63e7}.badge-success{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-danger{background:#f8d7da;color:#721c24}.badge-active{background:#cfe2ff;color:#084298}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background-color:#d1fae5;color:#065f46;border:1px solid #10b981}.status-badge.inactive{background-color:#fee2e2;color:#991b1b;border:1px solid #ef4444}.status-badge.maintenance{background-color:#fef3c7;color:#92400e;border:1px solid #f59e0b}.status-active{background-color:#d4edda;color:#155724;border-color:#c3e6cb}.status-inactive{background-color:#f8d7da;color:#721c24;border-color:#f5c6cb}.status-suspended{background-color:#fff3cd;color:#856404;border-color:#ffeaa7}.inactive-badge{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:.125rem .5rem;border-radius:12px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-badge{display:inline-block;background-color:#e3f2fd;color:#1976d2;padding:.2rem .5rem;border-radius:12px;font-size:.75rem;margin:.1rem;font-weight:500}.role-badge.sudo{background-color:#ffebee;color:#c62828}.role-badge.admin{background-color:#f3e5f5;color:#7b1fa2}.role-badge.ops{background-color:#e8f5e8;color:#2e7d32}.role-badge.supervisor{background-color:#fff3e0;color:#f57c00}.role-badge.guard{background-color:#e3f2fd;color:#1976d2}.role-badge.user{background-color:#f5f5f5;color:#616161}.filters-section{background:linear-gradient(145deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 6px #0000000d;position:relative;transition:all .3s ease;width:100%;max-width:100%;overflow:visible}.filters-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:12px 12px 0 0}.filters-section:hover{box-shadow:0 6px 12px #00000014}.filters-header{display:flex;align-items:center;gap:.5rem;width:100%;max-width:100%;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem;padding-bottom:1rem;font-size:1.1rem;color:#1e293b;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:initial;background-clip:text}.filters-header .btn{align-self:flex-start}.title-icon{font-size:1.1em;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;align-items:start;width:100%;max-width:100%}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:0}.filter-label{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.5px}.field-icon{font-size:1em;opacity:.8}.required-indicator{color:#ef4444;font-weight:700}.form-input{width:100%;min-width:0;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff;transition:all .2s ease;box-shadow:0 1px 3px #0000001a;font-family:inherit}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fefeff;transform:translateY(-1px)}.form-input:hover:not(:disabled){border-color:#cbd5e0}.form-input:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed;opacity:.7}.form-input::placeholder{color:#94a3b8;font-style:italic}.form-select{width:100%;min-width:0;padding:.75rem 2.5rem .75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff;transition:all .2s ease;box-shadow:0 1px 3px #0000001a;cursor:pointer;font-family:inherit;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em}.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;transform:translateY(-1px)}.form-select:hover:not(:disabled){border-color:#cbd5e0}.form-select:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed;opacity:.7}.date-range-container{display:flex;align-items:center;gap:.5rem}.date-range-input{flex:1;min-width:0}.date-range-separator{color:#64748b;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:0 .25rem}.filters-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:15px;border-top:1px solid #e2e8f0}.clear-button,.new-button{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.clear-button{background:#f3f4f6;color:#6b7280}.clear-button:hover{background:#e5e7eb;color:#374151}.new-button{background:#4caf50;color:#fff}.new-button:hover{background:#45a049;transform:translateY(-1px);box-shadow:0 4px 8px #4caf5033}.autocomplete-container{position:relative;width:100%}.input-with-clear{position:relative;display:flex;align-items:center}.clear-filter-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1rem;color:#ef4444;cursor:pointer;padding:.25rem;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem}.clear-filter-btn:hover{background:#fef2f2;transform:translateY(-50%) scale(1.1)}.clear-filter-btn:active{transform:translateY(-50%) scale(.95)}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 25px #00000026;z-index:1000;max-height:200px;overflow-y:auto;margin-top:.25rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:dropdownSlideIn .2s ease}.autocomplete-option{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:all .2s ease;position:relative}.autocomplete-option:hover{background:linear-gradient(90deg,#f8fafc,#e2e8f0);transform:translate(4px)}.autocomplete-option:last-child{border-bottom:none}.option-main{font-weight:600;color:#1e293b;font-size:.875rem}.option-sub{font-size:.75rem;color:#64748b;margin-top:.25rem;display:flex;align-items:center;gap:.5rem}.autocomplete-no-results{padding:1rem;text-align:center;color:#64748b;font-style:italic;font-size:.875rem}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem;margin-top:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s}.checkbox-label:hover{background-color:#f8f9fa}.checkbox-label input[type=checkbox]{width:auto;margin:0}.loading{text-align:center;padding:2rem;font-size:1.2rem;color:#7f8c8d}.loading-spinner{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem}.loading-users{display:flex;align-items:center;justify-content:center;padding:2rem;color:#7f8c8d}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24;padding:12px 20px;border-radius:4px;font-size:14px;margin-bottom:1rem}.success-message{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724;padding:12px 20px;border-radius:4px;font-size:14px}.no-data{text-align:center;padding:60px 20px;color:#999;font-size:16px;background:#fff;border-radius:8px;margin:20px 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-state .empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{font-size:1.5rem;font-weight:600;color:#334155;margin-bottom:.5rem}.empty-state p{font-size:1rem;color:#64748b}.filter-loading{opacity:.7;pointer-events:none}.filter-loading *{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.loader-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s ease-out}.loader-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.loader-message{color:#fff;font-size:1.1rem;font-weight:500;text-align:center;animation:pulse 2s ease-in-out infinite}.loader-default{position:relative;display:flex;align-items:center;justify-content:center}.loader-circle{position:relative;border-radius:50%;background:conic-gradient(from 0deg,transparent,rgba(52,152,219,.3),#3498db,#2980b9,transparent);animation:rotate 1.5s linear infinite}.loader-arc{position:absolute;inset:4px;background:#0009;border-radius:50%}.loader-pulse{position:relative;display:flex;align-items:center;justify-content:center}.pulse-ring{position:absolute;border:3px solid transparent;border-top-color:#3498db;border-radius:50%;animation:pulse-ring 2s ease-out infinite}.pulse-ring:nth-child(1){animation-delay:0s}.pulse-ring:nth-child(2){animation-delay:.7s}.pulse-ring:nth-child(3){animation-delay:1.4s}.loader-dots{display:flex;gap:.75rem;align-items:center}.dot{background:linear-gradient(135deg,#3498db,#2980b9);border-radius:50%;animation:dot-bounce 1.4s ease-in-out infinite}.dot:nth-child(1){animation-delay:0s}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}.loader-spinner{position:relative;display:flex;align-items:center;justify-content:center}.spinner-ring{border-radius:50%;border:4px solid rgba(255,255,255,.2);border-top:4px solid #3498db;border-right:4px solid #2980b9;animation:spin 1s linear infinite}.small .loader-circle{width:40px;height:40px}.small .pulse-ring{width:30px;height:30px}.small .dot{width:8px;height:8px}.small .spinner-ring{width:32px;height:32px}.medium .loader-circle{width:60px;height:60px}.medium .pulse-ring{width:50px;height:50px}.medium .dot{width:12px;height:12px}.medium .spinner-ring{width:48px;height:48px}.large .loader-circle{width:80px;height:80px}.large .pulse-ring{width:70px;height:70px}.large .dot{width:16px;height:16px}.large .spinner-ring{width:64px;height:64px}@keyframes shimmer{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes pulse-ring{0%{transform:scale(0);opacity:1}to{transform:scale(1.5);opacity:0}}@keyframes dot-bounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-slide-in{animation:slideInDown .3s ease-out}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-up{animation:slideInUp .3s ease-out}.dashboard-time-filters{margin-bottom:1rem}.dashboard-time-filters .filters-header{margin-bottom:1rem;padding-bottom:.5rem}.dashboard-time-filters .filters-grid{gap:1rem}.refresh-button-container{display:flex;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:2px solid #e2e8f0}.detail-section{border:1px solid #e1e8ed;border-radius:4px;padding:1rem}.detail-section p{margin:.5rem 0;color:#34495e}.detail-section h3{color:#2c3e50;font-size:1.1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #e1e8ed;display:flex;align-items:center;gap:.5rem}.info-value{font-weight:500;color:#2c3e50;text-align:right;word-break:break-word}.info-label{font-weight:600;color:#495057;font-size:.875rem;flex-shrink:1}@media(max-width:1400px){.table-base{font-size:12px}.table-base th,.table-base td{padding:10px 12px}.reports-table{font-size:12px}.reports-table th,.reports-table td{padding:10px 12px}}@media(max-width:1024px){.header-stats{gap:1.5rem}.pagination-info{font-size:.85rem}.filters-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.filters-header{font-size:1rem;background:none;-webkit-text-fill-color:initial;color:#1e293b}.date-range-container{flex-direction:column;gap:.5rem}.date-range-separator{align-self:center}.table-container{overflow-x:visible;border:none;box-shadow:none;margin:0}.table-base{display:block}.table-base thead{display:none}.table-base tbody{display:flex;flex-direction:column;gap:12px}.table-base tr{display:grid;grid-template-columns:1fr;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);background:#fff}.table-base td{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:0;border:none}.table-base td:before{content:attr(data-label);font-weight:600;color:#495057;font-size:13px;flex-shrink:0}.table-base td:last-child{justify-content:flex-start}.reports-table{display:block}.reports-table thead{display:none}.reports-table tbody{display:flex;flex-direction:column;gap:12px}.reports-table tr{display:grid;grid-template-columns:1fr;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);background:#fff}.reports-table td{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:0;border:none}.reports-table td:before{content:attr(data-label);font-weight:600;color:#495057;font-size:13px;flex-shrink:0}.reports-table td:last-child{justify-content:flex-start}.data-table{overflow:visible;box-shadow:none;border-radius:0;background:transparent}.data-table table{display:block}.data-table thead{display:none}.data-table tbody{display:flex;flex-direction:column;gap:12px}.data-table tr{display:grid;grid-template-columns:1fr;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);background:#fff}.data-table td{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:0!important;border-bottom:none!important}.data-table td:before{content:attr(data-label);font-weight:600;color:#495057;font-size:13px;flex-shrink:0}.data-table td:last-child{justify-content:flex-start}.data-table td.no-data{justify-content:center;text-align:center}.data-table td.no-data:before{content:none}.actions{flex-direction:column}}@media(max-width:768px){.page-shell{padding:12px}.form-row{grid-template-columns:1fr}.table-controls{flex-direction:column;align-items:stretch}.page-header .header-content{flex-direction:column;gap:1.5rem;align-items:stretch}.header .header-content{flex-direction:column;gap:1rem}.header-title{font-size:1.2rem}.main-container{flex-direction:column}.sidebar{width:100%;padding:1rem 0}.nav-list{display:flex;flex-wrap:wrap;justify-content:center}.nav-link{padding:.75rem 1rem}.content{padding:1rem}.header-title-section h1{font-size:1.5rem}.header-description{font-size:.875rem}.header-stats{flex-wrap:wrap;gap:1rem;justify-content:center}.stat-card{padding:1rem;min-width:0;flex:1}.header-actions{flex-direction:column;gap:1rem;align-items:stretch}.last-update{justify-content:center}.page-header{padding:1.5rem 1rem}.pagination-container{flex-direction:column;gap:1rem}.pagination-controls{flex-wrap:wrap;justify-content:center}.modal-content{margin:.5rem;max-width:calc(100vw - 1rem);max-height:calc(100vh - 1rem)}.modal-body{padding:1rem}.modal-actions{flex-direction:column-reverse;gap:.75rem}.btn-edit,.btn-delete,.btn-view{padding:.4rem .8rem;font-size:.8rem}.map-modal{width:95%;margin:1rem}.info-value{text-align:left}.info-label{min-width:auto}}@media(max-width:700px){.filters-section{padding:1rem}.filters-grid{grid-template-columns:1fr!important;gap:.875rem;width:100%;max-width:100%}.filters-header h3{font-size:1.05rem;background:none;-webkit-text-fill-color:initial;color:#1e293b}.filters-header{gap:.75rem}}@media(max-width:480px){.page-header{padding:1rem .75rem;border-radius:12px}.header-title-section h1{font-size:1.25rem}.stat-card{padding:.75rem .5rem}.stat-value{font-size:1.25rem}.stat-label{font-size:.75rem}.btn.btn-secondary{padding:.75rem 1rem;font-size:.75rem}.filters-section{padding:.75rem;margin-bottom:.75rem;border-radius:10px}.form-input,.form-select{font-size:.8125rem;padding:.625rem .875rem}.filter-label{font-size:.8125rem}.filters-header{flex-direction:column;align-items:flex-start;gap:.75rem}.detail-section{padding:.75rem}}.comment-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:6px 8px;font-size:13px}.notification-toast-container{position:fixed;bottom:20px;right:20px;z-index:2000;width:360px;max-width:calc(100vw - 32px);background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 30px #00000026;overflow:hidden;animation:slideInUp .3s ease}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.notification-toast-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#0d6efd;color:#fff}.notification-toast-title{font-weight:700;font-size:14px}.notification-toast-actions{display:flex;gap:8px;align-items:center}.notification-link{background:none;border:none;color:#fff;text-decoration:underline;cursor:pointer;font-size:12px;padding:0}.notification-link:hover{opacity:.85}.notification-dismiss-all{background:#fff3;border:none;color:#fff;border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer;font-weight:600}.notification-dismiss-all:hover{background:#ffffff59}.notification-toast-list{display:flex;flex-direction:column;max-height:300px;overflow-y:auto}.notification-toast-item{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #f0f0f0;transition:background .15s}.notification-toast-item:last-child{border-bottom:none}.notification-toast-item:hover{background:#f8f9fa}.notification-toast-content{display:flex;flex-direction:column;gap:2px;min-width:0}.notification-toast-label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:#6c757d;font-weight:600}.notification-toast-id{font-size:13px;color:#212529;font-family:monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-toast-time{font-size:12px;color:#6c757d}.notification-toast-close{background:none;border:none;font-size:18px;color:#6c757d;cursor:pointer;padding:0 4px;line-height:1;flex-shrink:0}.notification-toast-close:hover{color:#dc3545}.notification-toast-more{padding:8px 16px;text-align:center;font-size:12px;color:#6c757d;font-weight:600;background:#f8f9fa}.install-prompt-banner{position:fixed;bottom:0;left:0;right:0;z-index:1900;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px;background:linear-gradient(135deg,#0d6efd,#0a58ca);color:#fff;box-shadow:0 -4px 20px #00000026;animation:slideInUp .35s ease}.install-prompt-content{display:flex;align-items:center;gap:12px;min-width:0}.install-prompt-icon{font-size:28px;flex-shrink:0}.install-prompt-text{display:flex;flex-direction:column;gap:2px}.install-prompt-text strong{font-size:15px}.install-prompt-text span{font-size:13px;opacity:.9}.install-prompt-actions{display:flex;gap:8px;flex-shrink:0}.install-prompt-btn{border:none;border-radius:8px;padding:8px 18px;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s,transform .15s}.install-prompt-btn:hover{opacity:.9;transform:translateY(-1px)}.install-prompt-btn.install{background:#fff;color:#0d6efd}.install-prompt-btn.dismiss{background:#fff3;color:#fff}@media(max-width:600px){.install-prompt-banner{flex-direction:column;text-align:center;padding:16px}.install-prompt-content{justify-content:center}.install-prompt-actions{width:100%;justify-content:center}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-title{color:#fff;font-size:1.8rem;margin:0 0 .5rem;text-align:center}.login-subtitle{color:#7f8c8d;font-size:1.2rem;margin:0 0 2rem;text-align:center;font-weight:400}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-form .form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .3s}.login-form .form-group input:focus{outline:none;border-color:#667eea;box-shadow:none}.login-form .form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.password-input-wrapper{position:relative}.password-input-wrapper input{width:100%;padding-right:5.5rem}.password-toggle-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);border:none;background:transparent;color:#667eea;font-size:.85rem;font-weight:600;cursor:pointer;padding:.25rem .35rem}.password-toggle-btn:disabled{color:#a0aec0;cursor:not-allowed}.btn-login{background-color:#667eea;color:#fff;border:none;padding:.75rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .3s}.btn-login:hover:not(:disabled){background-color:#5568d3}.btn-login:disabled{background-color:#a0aec0;cursor:not-allowed}@media(max-width:480px){.login-card{padding:1.5rem}.login-title{font-size:1.5rem}.login-subtitle{font-size:1rem}}.reports-page{padding:1.5rem;max-width:1400px;margin:0 auto}.reports-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem}.reports-filters{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000001a}.filters-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;margin-bottom:1rem}.reports-page .filter-group{flex-direction:column}.reports-page .filter-label{font-size:.95rem;text-transform:none;letter-spacing:normal}.date-range{display:flex;align-items:center;gap:.75rem}.date-input{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;transition:border-color .2s}.date-input:focus{outline:none;border-color:#667eea}.date-separator{color:#6b7280;font-size:.9rem}.autocomplete-input-wrapper{position:relative}.autocomplete-input{width:100%;padding:.75rem 2.5rem .75rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;transition:border-color .2s}.autocomplete-input:focus{outline:none;border-color:#667eea}.filters-summary{border-top:1px solid #e5e7eb;padding-top:1rem}.active-filters{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.filters-label{font-weight:500;color:#374151}.filter-tag{background:#e0e7ff;color:#3730a3;padding:.375rem .75rem;border-radius:20px;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.filter-tag button{background:none;border:none;color:#3730a3;cursor:pointer;padding:.125rem;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:.75rem}.filter-tag button:hover{background:#3730a333}.reports-page .reports-table{font-size:.9rem}.reports-page .reports-table th{background:#f9fafb;padding:1rem .75rem;color:#374151;font-size:inherit;border-bottom:1px solid #e5e7eb}.reports-page .reports-table td{padding:1rem .75rem;border-bottom:1px solid #f3f4f6}.report-row{transition:background-color .2s}.report-row:hover{background-color:#fff}.user-info .user-name{font-weight:500;color:#374151}.user-info .user-details{font-size:.8rem;color:#6b7280;margin-top:.25rem}.device-info .device-name{font-weight:500;color:#374151}.device-info .device-id{font-size:.8rem;color:#6b7280;margin-top:.25rem}.time-info .time-main,.location-info .location-name{font-weight:500;color:#374151}.location-info .location-details{font-size:.8rem;color:#6b7280;margin-top:.25rem}@media(max-width:1024px){.filters-row{grid-template-columns:1fr 1fr;gap:1.5rem}}@media(max-width:768px){.reports-page{padding:1rem}.filters-row{grid-template-columns:1fr;gap:1rem}.date-range{flex-direction:column;align-items:flex-start;gap:.5rem}.date-separator{align-self:center}}.access-profiles-page{padding:20px;max-width:1400px;margin:0 auto}.access-profiles-stack{display:flex;flex-direction:column;gap:16px}.access-profiles-table .name-cell{display:flex;flex-direction:column;gap:4px}.identifiers-cell,.internal-ids-cell,.comments-cell{display:flex;flex-direction:column;gap:6px;max-width:340px}.identifier-item,.internal-id-item,.identifier-type{display:inline-block;font-weight:600;color:#495057;margin-right:6px}.identifier-value{color:#212529}.no-data-text{color:#6c757d;font-size:12px}.more-items{color:#495057;font-size:12px}.acl-count{padding:4px 10px;background:#e9ecef;color:#495057;border-radius:12px;font-size:12px;font-weight:600}.access-profiles-page .detail-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.access-profiles-page .detail-modal{width:min(900px,95vw);max-height:90vh;overflow-y:auto}.profile-detail-card{border:1px solid #e9ecef;border-radius:10px;background:#fff;padding:20px;box-shadow:0 2px 6px #0000000f;display:flex;flex-direction:column;gap:16px}.profile-detail-card .detail-card-header{display:flex;align-items:center;justify-content:space-between}.profile-detail-card .detail-card-header h3{margin:2px 0 0;color:#343a40;font-size:18px}.profile-detail-card .detail-header-actions{display:flex;gap:8px;align-items:center}.profile-detail-card .eyebrow{margin:0;color:#6c757d;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.profile-detail-card .detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.profile-detail-card .label{margin:0 0 4px;color:#6c757d;font-size:12px;font-weight:600}.profile-detail-card .value{margin:0;color:#212529;font-size:14px}.profile-detail-card .value.strong{font-weight:700}.profile-detail-card .value.code{font-family:monospace;font-size:13px;word-break:break-all}.profile-detail-card .detail-section{display:flex;flex-direction:column;gap:8px}.profile-detail-card .section-title{margin:0;font-size:14px;font-weight:700;color:#343a40;display:flex;align-items:center;gap:8px;border-bottom:1px solid #e9ecef;padding-bottom:6px}.profile-detail-card .count-badge{display:inline-flex;align-items:center;justify-content:center;background:#0d6efd;color:#fff;font-size:11px;font-weight:700;width:22px;height:22px;border-radius:50%}.profile-detail-card .info-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:10px 12px}.profile-detail-card .client-id-hint{font-size:11px;color:#6c757d;font-family:monospace;margin-top:-2px}.profile-detail-card .comments-list{display:flex;flex-direction:column;gap:8px}.profile-detail-card .comment-card{display:flex;align-items:flex-start;gap:10px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:10px 14px}.profile-detail-card .comment-index{color:#6c757d;font-size:12px;font-weight:700;flex-shrink:0;margin-top:1px}.profile-detail-card .comment-text{margin:0;color:#212529;font-size:14px;line-height:1.5}.profile-detail-card .acl-list{display:flex;flex-wrap:wrap;gap:6px}.profile-detail-card .acl-chip{display:inline-block;padding:4px 10px;background:#e9ecef;color:#495057;border-radius:12px;font-size:12px;font-weight:600}.access-profiles-table .clickable-row{cursor:pointer;transition:background-color .15s}.access-profiles-table .clickable-row:hover{background-color:#f0f4ff}@media(max-width:1024px){.access-profiles-page{padding:12px}.access-profiles-table .identifiers-cell,.access-profiles-table .internal-ids-cell,.access-profiles-table .comments-cell{max-width:none}}.access-reports-page{padding:20px;max-width:1400px;margin:0 auto}.access-reports-stack{display:flex;flex-direction:column;gap:16px}.csv-download-row{display:flex;justify-content:flex-end}.csv-download-button{padding:8px 18px;background:var(--color-primary, #2563eb);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.csv-download-button:hover:not(:disabled){background:var(--color-primary-hover, #1d4ed8)}.csv-download-button:disabled{opacity:.55;cursor:not-allowed}.report-type-selector{display:flex;gap:10px;margin:20px 0}.type-button{padding:10px 20px;border:2px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.type-button.active{background:#4caf50;color:#fff;border-color:#4caf50}.type-button:hover:not(.active){border-color:#4caf50;color:#4caf50}.id-code{font-family:monospace;font-size:12px;color:#666;background:#f5f5f5;padding:2px 6px;border-radius:3px;display:inline-block;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plate-text{font-size:14px;color:#2c3e50;font-weight:700;letter-spacing:1px}.status-pending{background:#fff3cd;color:#856404}.status-granted{background:#d4edda;color:#155724}.status-denied{background:#f8d7da;color:#721c24}.status-na{background:#e2e3e5;color:#6c757d}.badge-yes{display:inline-block;padding:4px 10px;background:#d4edda;color:#155724;border-radius:12px;font-size:11px;font-weight:600}.badge-no{display:inline-block;padding:4px 10px;background:#e2e3e5;color:#6c757d;border-radius:12px;font-size:11px;font-weight:600}.badge-active{display:inline-block;padding:4px 10px;background:#cfe2ff;color:#084298;border-radius:12px;font-size:11px;font-weight:600}.grant-button{margin-left:8px;padding:4px 10px;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;transition:all .2s}.grant-button:hover{background:#1976d2}.status-action-stack{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.status-action-stack .grant-button{margin-left:0}.report-detail-card{border:1px solid #e9ecef;border-radius:10px;background:#fff;padding:18px;box-shadow:0 2px 6px #0000000f;display:flex;flex-direction:column;gap:14px;width:100%}.permission-modal{max-width:520px;width:100%;padding-bottom:0}.permission-modal .modal-body{padding-top:1.25rem;padding-bottom:1rem}.permission-modal .meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}.permission-modal .meta-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.permission-modal .meta-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#6c757d;font-weight:600}.permission-modal .meta-hint{font-size:11px;color:#6c757d}.permission-modal .meta-value{font-weight:600;color:#2c3e50;word-break:break-word}.permission-modal .meta-chip{display:inline-block;padding:6px 10px;border-radius:12px;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.4px;width:fit-content}.permission-modal .span-2{grid-column:span 2}.permission-modal .chip-ingress{background:#e8f4ff;color:#0b6fbf}.permission-modal .chip-egress{background:#fdf2e8;color:#c25c1c}.permission-modal .decision-group .radio-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.permission-modal .comment-sections{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}.permission-modal .comment-group{display:flex;flex-direction:column;gap:8px}.permission-modal .comment-group label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#6c757d;font-weight:600}.permission-modal .message-list.comment-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.permission-modal .message-list.comment-list li{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:10px 12px;color:#2c3e50;line-height:1.4;word-break:break-word}.permission-modal .radio-label{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid #e0e0e0;border-radius:8px;transition:border-color .2s,box-shadow .2s,background-color .2s}.permission-modal .radio-label.selected{border-color:#3498db;box-shadow:0 0 0 3px #3498db26;background:#f5fbff}.permission-modal .radio-label input{margin:0}.permission-modal .form-group textarea,.permission-modal .form-group input{width:100%}.detail-card-header{display:flex;align-items:center;justify-content:space-between}.eyebrow{margin:0;color:#6c757d;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.detail-card-header h3{margin:2px 0 0;color:#343a40;font-size:18px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.profile-info-card{grid-column:1 / -1;border:1px solid #e9ecef;border-radius:10px;background:#f8f9fa;padding:12px;display:flex;flex-direction:column;gap:8px}.profile-info-row{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.profile-info-main-row{padding-bottom:4px;border-bottom:1px solid #e9ecef}.profile-info-label{color:#6c757d;font-size:11px;text-transform:uppercase;letter-spacing:.4px;font-weight:700}.profile-info-muted{color:#6c757d;font-size:12px}.profile-info-divider{color:#adb5bd;font-size:12px}.access-reports-page .label{margin:0 0 4px;color:#6c757d;font-size:12px;font-weight:600}.access-reports-page .value{margin:0;color:#212529;font-size:14px}.access-reports-page .value.strong{font-weight:700;letter-spacing:.5px}.access-reports-page .value.code{font-family:monospace;background:#f8f9fa;padding:4px 6px;border-radius:4px;border:1px solid #e9ecef}.permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.permission-card{border:1px solid #f1f3f5;border-radius:8px;padding:12px;background:#fdfdfd;display:flex;flex-direction:column;gap:6px}.permission-header{display:flex;align-items:center;justify-content:space-between}.messages-card{border:1px solid #f1f3f5;border-radius:8px;padding:12px;background:#fdfdfd;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{background:#e9ecef;color:#495057;border-radius:999px;padding:4px 10px;font-size:12px;border:1px solid #dee2e6}.access-reports-page .link-button{background:none;border:none;color:#dc3545;cursor:pointer;padding:4px 8px;font-weight:600}.detail-card-wrapper{margin-top:4px}.detail-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.detail-modal{width:min(900px,95vw);max-height:90vh;overflow-y:auto}@media(max-width:768px){.access-reports-page{padding:12px}.profile-info-card,.profile-info-item.profile-info-note{grid-column:span 1}}@media(max-width:640px){.grant-button{margin-left:0}}.access-configuration-page{padding:20px;max-width:1400px;margin:0 auto}.access-configuration-stack{display:flex;flex-direction:column;gap:16px}.access-configuration-table{width:100%;border-collapse:collapse;background:#fff}.access-configuration-table thead{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.access-configuration-table th{padding:12px 16px;text-align:left;font-weight:600;color:#495057;font-size:14px;white-space:nowrap}.access-configuration-table td{padding:12px 16px;border-top:1px solid #dee2e6;color:#212529;font-size:14px}.access-configuration-table tbody tr:hover{background-color:#f8f9fa}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;text-align:center;white-space:nowrap}.badge-required{background-color:#d1ecf1;color:#0c5460}.badge-optional{background-color:#f8f9fa;color:#6c757d}.badge-active{background-color:#d4edda;color:#155724}.badge-inactive{background-color:#f8d7da;color:#721c24}.access-configuration-form-container{background:#fff;border-radius:8px;padding:24px 28px;box-shadow:0 2px 4px #0000001a;max-width:960px;margin:0 auto}.access-configuration-form-container h2{margin:0 0 24px;color:#333;font-size:24px}.access-configuration-form{display:flex;flex-direction:column;gap:18px}.access-configuration-form .form-group{margin-bottom:20px}.access-configuration-form .form-group label{display:block;margin-bottom:8px;font-weight:500;color:#495057;font-size:14px}.access-configuration-form .required{color:#dc3545}.access-configuration-form select,.access-configuration-form input[type=text],.access-configuration-form input[type=email],.access-configuration-form input[type=datetime-local]{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px;transition:border-color .2s;background:#fff}.access-configuration-form select:focus,.access-configuration-form input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.access-configuration-form select:disabled,.access-configuration-form input:disabled{background-color:#e9ecef;cursor:not-allowed}.access-configuration-page .info-section{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;padding:16px;margin-bottom:20px}.access-configuration-page .info-section p{margin:8px 0;color:#495057;font-size:14px}.form-section{margin-bottom:24px;padding:18px;border:1px solid #e9ecef;border-radius:8px;background:#fdfdfd}.form-section h3{margin:0 0 14px;color:#343a40;font-size:18px;font-weight:600}.acl-section{display:flex;flex-direction:column;gap:16px}.acl-search label{font-weight:500;color:#495057}.acl-search-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;align-items:center}.acl-search-results{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.acl-result{border:1px solid #ced4da;border-radius:4px;padding:8px 12px;background:#f8f9fa;cursor:pointer;display:flex;flex-direction:column;gap:2px}.acl-result.selected{border-color:#007bff;background:#e7f1ff}.acl-draft-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.acl-draft-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}.acl-lists{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.acl-create{border:1px dashed #ced4da;border-radius:6px;padding:12px;background:#fafbfc}.acl-create-form{margin-top:12px;display:flex;flex-direction:column;gap:12px}.acl-create-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.acl-create-actions{display:flex;justify-content:flex-end}.error-text{color:#dc3545;font-size:13px;margin:0}.acl-list{border:1px solid #dee2e6;border-radius:6px;padding:12px;background:#fdfdfd;overflow:hidden;display:flex;flex-direction:column;gap:4px}.acl-list h4{margin:0 0 8px;color:#495057;font-size:16px}.acl-entry{display:flex;flex-wrap:wrap;align-items:flex-start;gap:12px;padding:12px;border:1px solid #f1f3f5;border-radius:6px;background:#fff}.acl-entry:last-child{border-bottom:none}.acl-entry-info{flex:1 1 180px;min-width:0;word-break:break-word}.acl-entry-info small{color:#6c757d;display:block}.acl-entry-times{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;flex:2 1 260px;min-width:0}.acl-entry-times label{font-size:12px;color:#6c757d}.acl-entry-times input{width:100%}.acl-entry .link-button{align-self:center;white-space:nowrap}.access-configuration-page .secondary-button{padding:8px 14px;border-radius:4px;border:1px solid #ced4da;background:#fff;cursor:pointer}.access-configuration-page .secondary-button.danger{border-color:#dc3545;color:#dc3545}.access-configuration-page .link-button{background:none;border:none;color:#dc3545;cursor:pointer;padding:0 6px}.muted{color:#6c757d;margin:6px 0}.access-configuration-page .form-actions{margin-top:24px}.cancel-button,.submit-button{padding:10px 24px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;min-width:140px;background-color:#28a745;color:#fff}.deny-button{padding:10px 24px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;min-width:140px;background-color:#a72828;color:#fff}.cancel-button{background-color:#6c757d;color:#fff}.cancel-button:hover:not(:disabled){background-color:#5a6268}.submit-button:hover:not(:disabled){background-color:#218838}.deny-button:hover:not(:disabled){background-color:#882121}.cancel-button:disabled,.submit-button:disabled{opacity:.6;cursor:not-allowed}.deny-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:1024px){.access-configuration-page{padding:10px}.access-configuration-table,.access-configuration-form-container{max-width:100%}.access-configuration-table{display:block}.access-configuration-table thead{display:none}.access-configuration-table tbody{display:flex;flex-direction:column;gap:12px}.access-configuration-table tr{display:grid;grid-template-columns:1fr;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);background:#fff}.access-configuration-table td{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:0;border:none}.access-configuration-table td:before{content:attr(data-label);font-weight:600;color:#495057;font-size:13px;flex-shrink:0}.acl-lists{grid-template-columns:1fr;gap:12px}.acl-entry{padding:10px}.acl-entry-times{grid-template-columns:1fr}.access-configuration-page .form-actions{flex-direction:column}.cancel-button,.submit-button,.deny-button{width:100%}}.welcome-page{padding:2rem;max-width:1200px;margin:0 auto}.welcome-header{text-align:center;margin-bottom:3rem;padding:2rem;background:linear-gradient(135deg,#2c3e50,#34495e);border-radius:15px;color:#fff}.company-logo{max-height:80px;max-width:200px;margin-bottom:1rem;object-fit:contain}.welcome-title{font-size:2.5rem;margin-bottom:.5rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3);color:#fff}.company-subtitle{font-size:1.3rem;margin:0;opacity:.9;font-weight:300;color:#fff}.welcome-content{padding:2rem 0}.welcome-message{text-align:center;margin-bottom:3rem}.welcome-text{font-size:1.2rem;color:#555;line-height:1.8;margin-bottom:3rem;max-width:800px;margin-left:auto;margin-right:auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-bottom:3rem}.feature-card{background:#f8f9fa;padding:2rem;border-radius:15px;text-align:center;border:1px solid #e9ecef;transition:all .3s ease}.feature-card.clickable{cursor:pointer}.feature-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000001a}.feature-card.clickable:hover{background:#e3f2fd;border-color:#2196f3}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#2c3e50;margin-bottom:1rem;font-size:1.3rem}.feature-card p{color:#666;line-height:1.6;margin:0}.section-label{font-size:1.4rem;color:#2c3e50;margin-bottom:1rem;margin-top:.5rem;text-align:left;border-bottom:2px solid #e9ecef;padding-bottom:.5rem}.getting-started{text-align:center;margin-bottom:3rem}.getting-started h3{color:#2c3e50;font-size:1.8rem;margin-bottom:2rem}.quick-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.quick-action-btn{display:inline-flex;align-items:center;padding:1rem 2rem;background:#6c757d;color:#fff;border:none;border-radius:10px;font-weight:500;transition:all .3s ease;cursor:pointer;font-size:1rem;text-decoration:none}.quick-action-btn:hover{transform:translateY(-3px);box-shadow:0 5px 15px #0003;color:#fff}.quick-action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2)}.quick-action-btn.primary:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.support-info{display:flex;justify-content:center;margin-bottom:2rem}.support-card{background:#e3f2fd;padding:2rem;border-radius:15px;border-left:5px solid #2196f3;max-width:600px;width:100%;margin-bottom:2rem}.support-card h4{color:#1976d2;margin-bottom:1rem;font-size:1.3rem}.support-card p{color:#555;margin-bottom:1rem;line-height:1.6}.support-card p:last-child{margin-bottom:0}.contact-info{background:#fff;padding:1rem;border-radius:8px;border:1px solid #bbdefb}@media(max-width:768px){.welcome-page{padding:1rem}.welcome-title{font-size:2rem}.company-subtitle{font-size:1.1rem}.welcome-header{padding:2rem 1rem}.features-grid{grid-template-columns:1fr;gap:1.5rem}.quick-actions{flex-direction:column;align-items:center}.quick-action-btn{width:100%;max-width:300px}}@media(max-width:480px){.welcome-title{font-size:1.8rem}.feature-card,.support-card{padding:1.5rem}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}
