*{box-sizing:border-box;margin:0;padding:0}body{background:#f0f2f5;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.splash-screen{align-items:center;background:linear-gradient(135deg,#2196f3,#1565c0);color:#fff;display:flex;height:100vh;justify-content:center}.splash-content{animation:fadeIn .5s ease-in;text-align:center}.splash-icon{animation:bounce 2s infinite;margin-bottom:20px}.splash-title{font-size:2.5rem;margin-bottom:10px}.splash-subtitle{font-size:1.1rem;margin-bottom:30px;opacity:.9}.splash-loader{background:#ffffff4d;border-radius:2px;height:4px;margin:0 auto;overflow:hidden;width:200px}.splash-loader-bar{animation:loadBar 5s ease-in-out;background:#fff;border-radius:2px;height:100%;width:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes loadBar{0%{width:0}to{width:100%}}.login-page{background:linear-gradient(135deg,#0d47a1,#1565c0,#1976d2);overflow:hidden}.login-page,.login-split{display:flex;height:100vh;width:100%}.login-branding{background:#0a2e5c;flex:6 1;overflow:hidden;position:relative}.branding-image-wrapper{inset:0;position:absolute}.branding-image{display:block;height:100%;object-fit:cover;width:100%}.login-keypad-section{align-items:center;display:flex;flex:6 1;flex-direction:column;gap:16px;justify-content:center;overflow:hidden;padding:24px 40px;position:relative}.keypad-top-brand{color:#fff;text-align:center}.keypad-main-title{font-size:2.4rem;font-weight:900;letter-spacing:5px;line-height:1.1;text-shadow:0 2px 10px #0000004d;text-transform:uppercase}.keypad-main-subtitle{font-size:1.1rem;font-weight:300;letter-spacing:2px;margin-bottom:6px;opacity:.9}.keypad-main-tagline{font-size:.85rem;font-weight:300;opacity:.7}.login-keypad-container{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffffbf;border:1px solid #ffffff4d;border-radius:18px;box-shadow:0 10px 50px #0000004d;max-width:380px;padding:24px 28px 22px;width:100%}.keypad-header{margin-bottom:14px;text-align:center}.keypad-logo{margin-bottom:6px}.keypad-logo svg{height:36px;width:36px}.keypad-header h3{color:#333;font-size:1.1rem;margin-bottom:2px}.keypad-header p{color:#888;font-size:.8rem}.login-footer-hint{color:#aaa;font-size:.7rem;margin-top:12px;text-align:center}.login-form{display:flex;flex-direction:column;gap:15px}.pin-display{align-items:center;cursor:pointer;justify-content:center;margin:4px 0 16px;-webkit-user-select:none;user-select:none}.pin-display,.pin-dots{display:flex;gap:12px}.pin-dot{align-items:center;background:#f9f9f9;border:2px solid #ddd;border-radius:50%;color:#333;display:flex;font-size:1rem;font-weight:700;height:42px;justify-content:center;transition:all .2s;width:42px}.pin-dot.filled{background:#2196f3;border-color:#2196f3;box-shadow:0 3px 10px #2196f359;color:#fff}.pin-toggle-hint{font-size:1.2rem;opacity:.5;transition:opacity .2s}.pin-toggle-hint:hover{opacity:1}.keypad{flex-direction:column}.keypad,.keypad-row{display:flex;gap:8px}.keypad-btn{-webkit-tap-highlight-color:transparent;background:#fafafa;border:1.5px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 4px #0000000a;color:#333;cursor:pointer;flex:1 1;font-size:1.6rem;font-weight:700;padding:16px 0;text-align:center;transition:all .1s;-webkit-user-select:none;user-select:none}.keypad-btn:hover{background:#f0f0f0;border-color:#ccc}.keypad-btn:active{background:#e8e8e8;box-shadow:inset 0 2px 6px #0000001a;transform:scale(.95)}.keypad-btn-clear{background:#fff3e0;border-color:#ffe0b2;color:#e65100;font-size:1rem;font-weight:700}.keypad-btn-clear:hover{background:#ffe0b2}.keypad-btn-back{background:#f3e5f5;border-color:#e1bee7;color:#6a1b9a;font-size:1.5rem}.keypad-btn-back:hover{background:#e1bee7}.keypad-btn-enter{background:#2196f3;border-color:#1976d2;border-radius:12px;box-shadow:0 4px 12px #2196f34d;color:#fff;font-size:1.1rem;font-weight:700;letter-spacing:3px;padding:14px 0}.keypad-btn-enter:hover{background:#1976d2;border-color:#1565c0;box-shadow:0 6px 16px #2196f366}.keypad-btn-enter:active{background:#1565c0}.keypad-btn-enter:disabled{background:#bbdefb;border-color:#90caf9;box-shadow:none;cursor:not-allowed;transform:none}.keypad-btn-enter.loading{background:#64b5f6;cursor:wait}.alert{border-radius:8px;font-size:.9rem;margin-bottom:10px;padding:12px 16px}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:#555;font-size:.85rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:8px;font-size:.95rem;outline:none;padding:10px 14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s}.btn:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-primary{background:#2196f3;color:#fff}.btn-primary:hover{background:#1976d2}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838}.btn-warning{background:#ffc107;color:#333}.btn-warning:hover{background:#e0a800}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-sm{font-size:.8rem;padding:5px 12px}.btn-block,.btn-logout{justify-content:center;width:100%}.btn-logout{background:#ffffff1a;border:1px solid #fff3;color:#fff}.btn-logout:hover{background:#fff3}.btn-close{background:none;border:none;color:#999;cursor:pointer;font-size:1.5rem;line-height:1;padding:0}.btn-close:hover{color:#333}.app-layout{display:flex;min-height:100vh}.main-content{background:#f0f2f5;flex:1 1;margin-left:250px;margin-right:0;min-height:100vh;padding:20px}.sidebar{background:linear-gradient(180deg,#1a237e,#283593);color:#fff;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;width:250px;z-index:100}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:20px}.sidebar-header h3{font-size:1.3rem;margin-bottom:5px}.sidebar-staff{font-size:.8rem;opacity:.8}.sidebar-role-badge{background:#ffffff1f;border-radius:20px;color:#ffffffe6;display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.5px;margin-top:6px;padding:2px 10px;text-transform:uppercase}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:10px 0}.sidebar-link{align-items:center;color:#fffc;display:flex;font-size:.9rem;gap:12px;padding:12px 20px;text-decoration:none;transition:all .2s}.sidebar-link:hover{background:#ffffff1a;color:#fff}.sidebar-link.active{background:#ffffff26;border-right:3px solid #64b5f6;color:#fff}.sidebar-icon{font-size:1.2rem;text-align:center;width:24px}.sidebar-footer{border-top:1px solid #ffffff1a;padding:15px 20px}.sidebar-collapse-btn{align-items:center;background:#ffffff0d;border:1px solid #ffffff14;border-left:none;border-right:none;color:#ffffffb3;cursor:pointer;display:none;flex-shrink:0;justify-content:center;padding:10px 0;transition:all .2s;width:100%}.sidebar-collapse-btn:hover{background:#ffffff1a;color:#fff}.sidebar-collapsed{width:70px!important}.sidebar-collapsed .sidebar-footer .btn-logout span,.sidebar-collapsed .sidebar-header .sidebar-role-badge,.sidebar-collapsed .sidebar-header h3,.sidebar-collapsed .sidebar-header p,.sidebar-collapsed .sidebar-keyboard-btn span,.sidebar-collapsed .sidebar-link span:last-child{display:none}.sidebar-collapsed .sidebar-header{padding:14px 10px;text-align:center}.sidebar-collapsed .sidebar-link{gap:0;justify-content:center;padding:14px 0}.sidebar-collapsed .sidebar-icon{font-size:1.3rem;margin:0}.sidebar-collapsed .sidebar-footer{align-items:center;display:flex;flex-direction:column;gap:6px;padding:10px 8px}.sidebar-collapsed .sidebar-footer .btn-logout{font-size:1.2rem}.sidebar-collapsed .sidebar-footer .btn-logout,.sidebar-collapsed .sidebar-keyboard-btn{border-radius:10px;height:44px;justify-content:center;padding:10px;width:44px}.sidebar-collapsed .sidebar-keyboard-btn svg{margin:0}.sidebar-collapsed .sidebar-collapse-btn svg{transform:rotate(180deg)}.main-content-collapsed{margin-left:70px!important}@media (min-width:901px){.sidebar-collapse-btn{display:flex}}.page-container{margin:0 auto;max-width:1400px}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:25px}.page-header h2{color:#333;font-size:1.5rem}.page-header p{color:#666;font-size:.9rem;margin-top:4px}.search-box{flex:1 1;max-width:350px;min-width:200px}.search-box input{border:1px solid #ddd;border-radius:8px;font-size:.9rem;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s;width:100%}.search-box input:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.search-box input::placeholder{color:#aaa}.page-breadcrumb{align-items:center;background:linear-gradient(135deg,#1a237e,#283593);border-radius:16px;box-shadow:0 4px 20px #1a237e40;display:flex;justify-content:space-between;margin-bottom:24px;padding:22px 28px}.breadcrumb-left{align-items:center;display:flex;gap:18px}.breadcrumb-icon{align-items:center;background:#ffffff26;border-radius:12px;color:#fff;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.breadcrumb-text{display:flex;flex-direction:column;gap:2px}.breadcrumb-links{align-items:center;display:flex;font-size:.8rem;gap:6px}.breadcrumb-link{color:#fff9}.breadcrumb-sep{color:#ffffff59}.breadcrumb-current{color:#fffffff2;font-weight:600}.breadcrumb-subtitle{color:#ffffffb3;font-size:.85rem;margin:0}.btn-add{background:#fff;border-radius:10px;box-shadow:0 4px 12px #00000026;color:#1a237e;font-weight:700;gap:8px;padding:10px 22px}.btn-add:hover{background:#f0f2ff;box-shadow:0 6px 20px #0003;transform:translateY(-2px)}.customers-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px}.search-wrapper{flex:1 1;max-width:480px;min-width:280px;position:relative}.search-icon,.search-wrapper{align-items:center;display:flex}.search-icon{color:#94a3b8;left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#334155;font-size:.9rem;outline:none;padding:12px 40px 12px 42px;transition:all .25s ease;width:100%}.search-input:focus{border-color:#6366f1;box-shadow:0 0 0 4px #6366f11a}.search-input::placeholder{color:#94a3b8}.search-clear{align-items:center;background:#f1f5f9;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:all .2s}.search-clear:hover{background:#e2e8f0;color:#334155}.toolbar-stats{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;display:flex;flex-shrink:0;gap:8px;padding:8px 16px}.toolbar-count{color:#1e293b;font-size:1.2rem;font-weight:800;line-height:1}.toolbar-label{color:#64748b;font-size:.85rem;font-weight:500}.toolbar-filter-badge{background:#eef2ff;border-radius:6px;color:#6366f1;font-size:.7rem;font-weight:700;letter-spacing:.5px;padding:3px 8px;text-transform:uppercase}.filter-select{-webkit-appearance:auto;appearance:auto;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#334155;cursor:pointer;font-size:.88rem;min-width:160px;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s}.filter-select:focus{border-color:#6366f1;box-shadow:0 0 0 4px #6366f114}.filter-select:hover{border-color:#cbd5e1}.customers-card{border:1px solid #f1f5f9;border-radius:16px;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;transition:box-shadow .3s}.customers-card:hover{box-shadow:0 4px 12px #00000014}.empty-state{flex-direction:column;padding:60px 20px;text-align:center}.empty-icon,.empty-state{align-items:center;display:flex;justify-content:center}.empty-icon{background:#f1f5f9;border-radius:50%;color:#94a3b8;height:96px;margin-bottom:20px;width:96px}.empty-title{color:#334155;font-size:1.2rem;font-weight:700;margin-bottom:8px}.empty-desc{color:#94a3b8;font-size:.9rem;line-height:1.5;margin-bottom:24px;max-width:360px}.table-wrapper{overflow-x:auto}.customers-table{border-collapse:initial;border-spacing:0;font-size:.88rem;width:100%}.customers-table thead th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#64748b;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-transform:uppercase;white-space:nowrap}.th-content{align-items:center;display:flex;gap:6px}.th-content svg{opacity:.6}.th-actions{text-align:center;width:100px}.customers-table tbody tr{transition:all .2s}.customers-table tbody tr:hover{background:#f8fafc}.customers-table tbody tr:not(:last-child) td{border-bottom:1px solid #f1f5f9}.customers-table td{padding:14px 16px;vertical-align:middle}.customer-name-cell{align-items:center;display:flex;gap:10px}.customer-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:10px;box-shadow:0 2px 8px #6366f14d;color:#fff;display:flex;flex-shrink:0;font-size:.85rem;font-weight:700;height:36px;justify-content:center;width:36px}.customer-name{color:#1e293b;font-weight:600}.customer-phone{color:#6366f1;font-weight:500;text-decoration:none;transition:color .2s}.customer-phone:hover{color:#4f46e5;text-decoration:underline}.vehicle-reg{background:#f1f5f9;border-radius:6px;color:#334155;display:inline-block;font-family:Courier New,monospace;font-size:.82rem;font-weight:600;letter-spacing:.3px;padding:4px 10px}.date-cell{font-size:.85rem}.created-by,.date-cell{color:#64748b}.action-btns,.btn-action{justify-content:center}.btn-action{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;height:34px;transition:all .2s;width:34px}.btn-action-edit{background:#eef2ff;color:#6366f1}.btn-action-edit:hover{background:#e0e7ff;box-shadow:0 2px 8px #6366f133;transform:translateY(-1px)}.btn-action-delete{background:#fef2f2;color:#ef4444}.btn-action-delete:hover{background:#fee2e2;box-shadow:0 2px 8px #ef444433;transform:translateY(-1px)}.modal-customer{border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 20px 60px #00000026;max-width:480px;overflow:hidden}.modal-customer .modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;padding:20px 24px}.modal-header-left{align-items:center;display:flex;gap:14px}.modal-header-icon{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:10px;box-shadow:0 2px 8px #6366f14d;color:#fff;display:flex;flex-shrink:0;height:42px;justify-content:center;width:42px}.modal-customer .modal-header h3{color:#1e293b;font-size:1.05rem;font-weight:700}.modal-subtitle{color:#94a3b8;font-size:.8rem;margin:2px 0 0}.modal-customer .modal-body{display:flex;flex-direction:column;gap:18px;padding:24px}.modal-customer .form-group label{align-items:center;color:#475569;display:flex;font-size:.8rem;font-weight:600;gap:6px;letter-spacing:.3px;text-transform:uppercase}.modal-customer .form-group label svg{opacity:.6}.modal-customer .form-group input{background:#fafbfc;border:2px solid #e2e8f0;border-radius:10px;font-size:.9rem;outline:none;padding:12px 14px;transition:all .2s}.modal-customer .form-group input:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 4px #6366f114}.modal-customer .form-group select{-webkit-appearance:auto;appearance:auto;background:#fafbfc;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;font-size:.9rem;outline:none;padding:12px 14px;transition:all .2s}.modal-customer .form-group select:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 4px #6366f114}.modal-customer .form-group input::placeholder{color:#94a3b8}.modal-customer .modal-footer{background:#fafbfc;border-top:1px solid #e2e8f0;display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.btn-cancel{background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#64748b;font-weight:600;padding:10px 20px}.btn-cancel:hover{background:#f1f5f9;border-color:#cbd5e1;box-shadow:none;transform:none}.btn-save{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:10px;box-shadow:0 4px 12px #6366f14d;color:#fff;font-weight:700;gap:8px;padding:10px 22px}.btn-save:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed);box-shadow:0 6px 16px #6366f166;transform:translateY(-1px)}@media (max-width:768px){.page-breadcrumb{align-items:flex-start;flex-direction:column;gap:14px;padding:18px 20px}.breadcrumb-left,.btn-add{width:100%}.btn-add{justify-content:center}.customers-toolbar{align-items:stretch;flex-direction:column}.search-wrapper{max-width:100%;min-width:0;min-width:auto}.customers-table thead th{font-size:.7rem;padding:10px 12px}.customers-table td{padding:10px 12px}.customer-avatar{font-size:.75rem;height:30px;width:30px}}.pin-input-wrapper{align-items:center;display:flex;position:relative}.pin-input-wrapper input{background:#fafbfc;border:2px solid #e2e8f0;border-radius:10px;font-family:Courier New,monospace;font-size:.95rem;letter-spacing:4px;outline:none;padding:12px 40px 12px 14px;transition:all .2s;width:100%}.pin-input-wrapper input:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 4px #6366f114}.pin-input-wrapper input::placeholder{color:#cbd5e1;letter-spacing:2px}.pin-toggle{align-items:center;background:none;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;padding:6px;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:all .2s}.pin-toggle:hover{background:#f1f5f9;color:#64748b}.pin-mismatch{color:#ef4444;font-size:.75rem;font-weight:600;margin-top:2px}.edit-pin-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:10px;padding:18px}.edit-pin-header{align-items:center;color:#475569;display:flex;font-size:.9rem;font-weight:700;gap:8px}.edit-pin-header svg{color:#6366f1}.edit-pin-description{color:#94a3b8;font-size:.82rem;line-height:1.4;margin:0}.btn-reset-pin{align-items:center;background:#fff3e0;border:1px solid #ffcc80;border-radius:10px;color:#e65100;cursor:pointer;display:inline-flex;font-size:.88rem;font-weight:700;gap:8px;padding:10px 20px;transition:all .2s}.btn-reset-pin:hover{background:#ffe0b2;border-color:#ffb74d;box-shadow:0 4px 12px #ff980033;transform:translateY(-1px)}.btn-reset-pin:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.btn-reset-pin svg{stroke:#e65100}.reset-pin-result{align-items:flex-start;border-radius:10px;display:flex;gap:12px;margin-top:8px;padding:14px}.reset-pin-result.success{background:#f0fdf4;border:1px solid #bbf7d0}.reset-pin-result.error{background:#fef2f2;border:1px solid #fecaca}.reset-pin-result-icon{align-items:center;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.reset-pin-result.success .reset-pin-result-icon{color:#16a34a}.reset-pin-result.error .reset-pin-result-icon{color:#dc2626}.reset-pin-result-text{display:flex;flex:1 1;flex-direction:column;gap:6px}.reset-pin-result-text strong{color:#166534;font-size:.85rem}.new-pin-display{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:10px;padding:8px 14px}.new-pin-label{color:#64748b;font-size:.8rem;font-weight:600}.new-pin-value{color:#166534;font-family:Courier New,monospace;font-size:1.3rem;font-weight:800;letter-spacing:3px}.copy-pin-btn{align-items:center;background:#e2e8f0;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;margin-left:auto;padding:5px 7px;transition:all .2s}.copy-pin-btn:hover{background:#cbd5e1;color:#334155}.reset-pin-message{color:#94a3b8;font-size:.78rem;line-height:1.4;margin:0}.reset-pin-error{color:#dc2626;font-size:.85rem;font-weight:600}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:30px}.stat-card{align-items:center;background:#fff;border-left:4px solid;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:20px;padding:24px;transition:transform .2s}.stat-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.stat-icon{align-items:center;background:#f8f9fa;border-radius:12px;display:flex;font-size:2rem;height:50px;justify-content:center;width:50px}.stat-info h3{font-size:1.5rem;margin-bottom:4px}.stat-info p{color:#666;font-size:.85rem}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;overflow:hidden}.card-header{border-bottom:1px solid #eee;padding:16px 20px}.card-header h3{color:#333;font-size:1.1rem}.card-body{overflow-x:auto;padding:20px}.data-table{border-collapse:collapse;font-size:.9rem;width:100%}.data-table th{background:#f8f9fa;border-bottom:2px solid #eee;color:#555;font-weight:600;padding:12px 16px;text-align:left;white-space:nowrap}.data-table td{border-bottom:1px solid #f0f0f0;padding:12px 16px}.data-table tbody tr:hover{background:#f8f9fa}.data-table .no-data{color:#999;padding:30px;text-align:center}.action-btns{display:flex;gap:6px}.badge{border-radius:20px;display:inline-block;font-size:.8rem;font-weight:600;padding:4px 12px}.badge-success{background:#d4edda;color:#155724}.badge-danger{background:#f8d7da;color:#721c24}.badge-warning{background:#fff3cd;color:#856404}.badge-info{background:#d1ecf1;color:#0c5460}.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:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-lg{max-width:700px}.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:20px}.modal-header h3{font-size:1.2rem}.modal-body{display:flex;flex-direction:column;gap:15px;padding:20px}.modal-footer{border-top:1px solid #eee;display:flex;gap:10px;justify-content:flex-end;padding:15px 20px}.packages-enhanced-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.package-enhanced-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;display:flex;flex-direction:column;gap:12px;padding:24px;transition:all .25s ease}.package-enhanced-card:hover{border-color:#e2e8f0;box-shadow:0 8px 25px #0000001a;transform:translateY(-3px)}.package-enhanced-top{align-items:flex-start;display:flex;justify-content:space-between}.package-enhanced-name{color:#1e293b;font-size:1.15rem;font-weight:700;line-height:1.3}.package-enhanced-actions{display:flex;flex-shrink:0;gap:4px}.package-enhanced-rate{color:#6366f1;font-size:2rem;font-weight:800;line-height:1.1}.package-enhanced-commission{align-items:center;background:#f8fafc;border:1px solid #f1f5f9;border-radius:10px;display:flex;flex-wrap:wrap;gap:8px;padding:10px 14px}.commission-label{color:#64748b;font-size:.82rem;font-weight:500}.commission-value{font-size:.95rem;font-weight:700}.commission-pct{color:#0891b2}.commission-fixed{color:#059669}.commission-type-badge{background:#eef2ff;border-radius:6px;color:#6366f1;font-size:.7rem;font-weight:700;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.package-enhanced-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding-top:8px}.package-enhanced-meta{align-items:center;color:#94a3b8;display:flex;font-size:.8rem;gap:5px}.package-enhanced-meta svg{flex-shrink:0}.filter-form{border-bottom:1px solid #eee;margin-bottom:20px;padding-bottom:20px}.report-summary{background:#f8f9fa;border-radius:8px;display:flex;gap:30px;margin-bottom:20px;padding:15px}.summary-item{align-items:center;display:flex;gap:10px}.summary-item span{color:#666;font-size:.9rem}.summary-item strong{color:#333;font-size:1.2rem}.no-data{color:#999;font-size:.95rem;padding:40px;text-align:center}@media (max-width:1024px){.login-page{background:linear-gradient(135deg,#0d47a1,#1565c0,#1976d2)}.login-page,.login-split{height:auto;min-height:100vh}.login-split{flex-direction:column}.login-branding{display:none}.login-keypad-section{flex:1 1;gap:12px;justify-content:center;padding:16px}.keypad-main-title{font-size:1.6rem}.keypad-main-subtitle{font-size:.9rem}.login-keypad-container{border-radius:14px;max-width:100%;padding:20px}.keypad-btn{font-size:1.4rem;padding:14px 0}.login-footer-hint{font-size:.65rem}}@media (max-width:480px){.login-keypad-section{padding:10px}.login-keypad-container{border-radius:12px;padding:16px 14px}.keypad-main-title{font-size:1.3rem;letter-spacing:3px}.keypad-btn{font-size:1.3rem;padding:12px 0}}.mobile-hamburger{align-items:center;background:linear-gradient(135deg,#1a237e,#283593);border:none;border-radius:10px;box-shadow:0 3px 12px #0003;color:#fff;cursor:pointer;display:none;height:42px;justify-content:center;left:12px;position:fixed;top:12px;transition:transform .2s,box-shadow .2s;width:42px;z-index:99}.mobile-hamburger:hover{box-shadow:0 4px 16px #0000004d;transform:scale(1.05)}.mobile-hamburger svg{height:22px;width:22px}.mobile-sidebar-overlay{animation:fadeInOverlay .25s ease;background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:98}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.sidebar-mobile-close{align-items:center;background:#ffffff1a;border:none;border-radius:8px;color:#fff;cursor:pointer;display:none;height:36px;justify-content:center;position:absolute;right:12px;top:12px;transition:background .2s;width:36px}.sidebar-mobile-close:hover{background:#fff3}@media (max-width:1024px){.main-content{margin-left:0;padding:16px}.page-container{margin-left:0}.dashboard-charts-row{grid-template-columns:1fr}.dashboard-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.mobile-hamburger{display:flex}.mobile-sidebar-overlay{display:block}.sidebar,.sidebar.sidebar-collapsed{transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:250px!important;z-index:100}.sidebar-mobile-open,.sidebar-mobile-open.sidebar-collapsed{transform:translateX(0)}.sidebar-mobile-close{display:flex}.sidebar-header h3{font-size:1.1rem}.main-content{margin-left:0;padding:64px 16px 16px}.page-container{margin-left:0;max-width:100%}.page-header{align-items:flex-start;flex-direction:column;gap:10px}.page-header h2{font-size:1.2rem}.page-breadcrumb{align-items:flex-start;flex-direction:column;gap:10px;padding:16px 18px}.breadcrumb-left{gap:12px;width:100%}.breadcrumb-icon{height:38px;width:38px}.dashboard-stats-grid,.form-row,.packages-enhanced-grid,.packages-grid,.stats-grid{grid-template-columns:1fr}.report-summary{flex-direction:column;gap:10px}.data-table{font-size:.8rem}.data-table td,.data-table th{padding:8px 10px}.action-btns{flex-direction:column;gap:4px}.search-box{max-width:100%;min-width:0;min-width:auto}.card-body{overflow-x:auto;padding:14px}.modal{margin:0 10px;max-width:95%}.modal-body{padding:16px}.dashboard-charts-row{grid-template-columns:1fr}.dashboard-card-header{align-items:flex-start;flex-direction:column;gap:8px}.chart-controls{width:100%}.chart-year-select{flex:1 1}.data-table thead th{font-size:.7rem;padding:8px 6px}.data-table td{font-size:.78rem;padding:8px 6px}.dashboard-banner{padding:20px 16px}.banner-text h1{font-size:1.25rem}.banner-date{font-size:.8rem}.banner-icon{display:none}.dashboard-section-title h2{font-size:1rem}.insights-list{gap:10px}.insight-item{font-size:.82rem;padding:10px 12px}.commission-summary-bar{align-items:flex-start;flex-direction:column;gap:10px}.commission-export-group{margin-left:0;width:100%}.commission-export-group .btn-export{flex:1 1;justify-content:center}.services-filter-row{grid-template-columns:1fr 1fr}.services-table thead th{font-size:.65rem;padding:8px 6px}.services-table td{font-size:.75rem;padding:8px 6px}.staff-tabs{gap:0;overflow-x:auto}.staff-tab{font-size:.78rem;padding:10px 14px;white-space:nowrap}.staff-tab-content{padding:14px}.profile-row{align-items:flex-start;flex-direction:column;gap:4px;padding:10px 14px}.profile-value{text-align:left}}@media (max-width:480px){.dashboard-stats-grid,.services-filter-row,.stats-grid{grid-template-columns:1fr}.page-container{padding:0}.main-content{padding-left:10px;padding-right:10px}.stat-card{gap:14px;padding:16px}.stat-info h3{font-size:1.2rem}}.btn-keyboard-toggle{align-items:center;background:#eef2ff;border:1px solid #c7d2fe;border-radius:10px;color:#4338ca;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:600;justify-content:center;padding:8px 16px;transition:all .2s}.btn-keyboard-toggle:hover{background:#e0e7ff;border-color:#a5b4fc;box-shadow:0 2px 8px #6366f133;transform:translateY(-1px)}.btn-keyboard-toggle svg{opacity:.9}.sidebar-keyboard-btn{align-items:center;display:flex!important;font-size:.88rem;gap:10px}.onscreen-keyboard-overlay{align-items:flex-end;animation:oskFadeIn .2s ease;background:#0006;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.onscreen-keyboard{animation:oskSlideUp .25s ease;background:#1e293b;border-radius:16px 16px 0 0;box-shadow:0 -8px 30px #0000004d;max-width:900px;padding:12px 16px 20px;width:100%}.osk-row{gap:5px;margin-bottom:5px}.osk-key,.osk-row{display:flex;justify-content:center}.osk-key{-webkit-tap-highlight-color:transparent;align-items:center;background:#334155;border:none;border-radius:8px;color:#f1f5f9;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;height:46px;min-width:42px;padding:0 8px;transition:all .1s;-webkit-user-select:none;user-select:none}.osk-key:hover{background:#475569}.osk-key:active{background:#64748b;transform:scale(.95)}.osk-key-fn{background:#475569;color:#cbd5e1;flex:1.2 1;font-size:.8rem;font-weight:700;min-width:58px}.osk-key-fn:hover{background:#64748b}.osk-key-wide{flex:1.8 1;min-width:72px}.osk-key-space{flex:4 1;min-width:140px}.osk-key-active{background:#6366f1!important;box-shadow:0 0 10px #6366f166;color:#fff!important}.osk-key-danger{color:#fca5a5}.osk-key-close{background:#ef4444!important;color:#fff!important;flex:0.8 1;min-width:50px}.osk-key-close:hover{background:#dc2626!important}@keyframes oskFadeIn{0%{opacity:0}to{opacity:1}}@keyframes oskSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.card-status-active{background:linear-gradient(135deg,#f0fdf4,#dcfce7)!important;border-color:#bbf7d0!important}.card-status-active:hover{border-color:#86efac!important;box-shadow:0 8px 25px #22c55e26!important}.card-status-inactive{background:linear-gradient(135deg,#fef2f2,#fee2e2)!important;border-color:#fecaca!important}.card-status-inactive:hover{border-color:#fca5a5!important;box-shadow:0 8px 25px #ef44441f!important}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.modal-services{max-width:1000px!important}.modal-services .modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}.modal-services .modal-header h3{color:#1e293b;font-size:1.05rem;font-weight:700}.modal-services .modal-body{max-height:70vh;overflow-y:auto;padding:0}.modal-services .modal-body .table-wrapper{overflow-x:auto}.services-filters{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:16px 20px}.services-filter-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr 1fr}.services-filter-row .form-group{margin-bottom:0}.services-filter-row .form-group label{color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.3px;margin-bottom:4px;text-transform:uppercase}.services-filter-row .form-group input,.services-filter-row .form-group select{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.82rem;outline:none;padding:8px 10px;transition:border-color .2s;width:100%}.services-filter-row .form-group input:focus,.services-filter-row .form-group select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f114}.services-table{border-collapse:collapse;font-size:.85rem;width:100%}.services-table thead th{background:#1e293b;border-bottom:2px solid #334155;color:#f1f5f9;font-size:.75rem;font-weight:600;letter-spacing:.4px;padding:10px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.services-table thead th:first-child{padding-left:16px}.services-table thead th:last-child{padding-right:16px}.services-table tbody tr{transition:background .15s}.services-table tbody tr:nth-child(2n){background:#f8fafc}.services-table tbody tr:hover{background:#eef2ff}.services-table tbody tr td{border-bottom:1px solid #f1f5f9}.services-table td{color:#334155;padding:10px 12px;vertical-align:middle}.services-table td:first-child{padding-left:16px}.services-table td:last-child{padding-right:16px}.service-id{color:#6366f1;font-family:Courier New,monospace;font-size:.8rem;font-weight:700}.service-package{color:#1e293b;font-weight:600}.service-amount{color:#059669;font-size:.88rem;font-weight:700;white-space:nowrap}.service-addons-list{display:flex;flex-direction:column;gap:2px}.service-addon-tag{color:#475569;font-size:.8rem;line-height:1.4}.service-addon-tag small{color:#94a3b8;font-weight:500}.no-addons{color:#94a3b8;font-style:italic}.service-staff{color:#475569;font-size:.85rem}.btn-action-view{background:#ecfeff;color:#0891b2}.btn-action-view:hover{background:#cffafe;box-shadow:0 2px 8px #0891b233;transform:translateY(-1px)}.modal-staff-view{max-width:1000px!important}.modal-staff-view .modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}.modal-staff-view .modal-header h3{color:#1e293b;font-size:1.05rem;font-weight:700}.modal-staff-view .modal-body{max-height:70vh;overflow-y:auto;padding:0}.modal-staff-view .modal-body .table-wrapper{overflow-x:auto}.staff-tabs{background:#f1f5f9;border-bottom:1px solid #e2e8f0;display:flex;gap:0;position:-webkit-sticky;position:sticky;top:0;z-index:5}.staff-tab{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:6px;padding:12px 20px;transition:all .2s;white-space:nowrap}.staff-tab:hover{background:#6366f10d;color:#334155}.staff-tab.active{background:#fff;border-bottom-color:#6366f1;color:#6366f1}.staff-tab svg{flex-shrink:0;height:16px;width:16px}.staff-tab-content{padding:20px}.profile-tab-content{max-width:600px}.profile-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.profile-card-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;color:#1e293b;font-size:.85rem;font-weight:700;letter-spacing:.5px;padding:12px 20px;text-transform:uppercase}.profile-details{padding:0}.profile-row{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:12px 20px}.profile-row:last-child{border-bottom:none}.profile-label{color:#64748b;font-size:.82rem;font-weight:600}.profile-value{color:#1e293b;font-size:.88rem;font-weight:600;text-align:right}.staff-tab-date-filters{border-bottom:1px solid #e2e8f0;margin-bottom:16px;padding:0 0 16px}.staff-tab-date-filters .services-filter-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr .5fr}.staff-tab-date-filters .form-group{margin-bottom:0}.staff-tab-date-filters .form-group label{color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.3px;margin-bottom:4px;text-transform:uppercase}.staff-tab-date-filters .form-group input{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.82rem;outline:none;padding:8px 10px;transition:border-color .2s;width:100%}.staff-tab-date-filters .form-group input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f114}.filter-btn-group{display:flex;flex-direction:column;justify-content:flex-end}.btn-sm{align-items:center;display:inline-flex;font-size:.82rem;gap:6px;padding:8px 16px}.commission-summary-bar{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:10px;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:16px;padding:12px 16px}.commission-summary-item{display:flex;flex-direction:column;gap:2px}.commission-summary-label{color:#94a3b8;font-size:.7rem;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.commission-summary-value{color:#1e293b;font-size:1rem;font-weight:700}.commission-summary-highlight{color:#6366f1}.commission-export-group{display:flex;gap:8px;margin-left:auto}.btn-export{align-items:center;background:#fff;border:1.5px solid;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.78rem;font-weight:600;gap:6px;padding:6px 14px;transition:all .2s}.btn-export:hover{box-shadow:0 3px 10px #00000014;transform:translateY(-1px)}.btn-export-csv{border-color:#a7f3d0;color:#059669}.btn-export-csv:hover{background:#ecfdf5}.btn-export-pdf{border-color:#fca5a5;color:#dc2626}.btn-export-pdf:hover{background:#fef2f2}@media (max-width:768px){.modal-services{margin:0 10px;max-width:100%!important}.services-filter-row{grid-template-columns:1fr 1fr}.services-table thead th{font-size:.65rem;padding:8px 6px}.services-table td{font-size:.75rem;padding:8px 6px}}.dashboard-banner{background:linear-gradient(135deg,#6366f1,#8b5cf6,#a78bfa);border-radius:16px;box-shadow:0 8px 30px #6366f140;margin-bottom:28px;overflow:hidden;padding:32px 36px;position:relative}.dashboard-banner:before{height:400px;right:-20%;top:-50%;width:400px}.dashboard-banner:after,.dashboard-banner:before{background:#ffffff0d;border-radius:50%;content:"";pointer-events:none;position:absolute}.dashboard-banner:after{bottom:-30%;height:250px;left:10%;width:250px}.banner-content{align-items:center;display:flex;justify-content:space-between;position:relative;z-index:1}.banner-text h1{color:#fff;font-size:1.8rem;font-weight:700;letter-spacing:-.3px;margin:0 0 6px}.banner-date{color:#fffc;font-size:1rem;font-weight:400;margin:0}.banner-icon{color:#ffffff4d;flex-shrink:0}.dashboard-section-title{align-items:center;display:flex;gap:12px;margin-bottom:18px}.dashboard-section-title h2{color:#1e293b;font-size:1.25rem;font-weight:700;margin:0}.section-badge{background:#eef2ff;border-radius:20px;color:#6366f1;font-size:.75rem;font-weight:600;padding:4px 12px;white-space:nowrap}.dashboard-stats-grid{margin-bottom:28px}.stat-card-accent{border-left:4px solid;transition:transform .2s ease,box-shadow .2s ease}.stat-card-accent:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-3px)}.stat-accent-blue{border-left-color:#3b82f6}.stat-accent-blue .stat-icon{background:#eff6ff;color:#3b82f6}.stat-accent-blue:hover{box-shadow:0 8px 25px #3b82f626}.stat-accent-green{border-left-color:#22c55e}.stat-accent-green .stat-icon{background:#f0fdf4;color:#22c55e}.stat-accent-green:hover{box-shadow:0 8px 25px #22c55e26}.stat-accent-amber{border-left-color:#f59e0b}.stat-accent-amber .stat-icon{background:#fffbeb;color:#f59e0b}.stat-accent-amber:hover{box-shadow:0 8px 25px #f59e0b26}.stat-accent-purple{border-left-color:#a855f7}.stat-accent-purple .stat-icon{background:#faf5ff;color:#a855f7}.stat-accent-purple:hover{box-shadow:0 8px 25px #a855f726}.dashboard-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;overflow:hidden;transition:box-shadow .2s ease}.dashboard-card:hover{box-shadow:0 4px 16px #00000014}.dashboard-card-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:16px 20px}.dashboard-card-header h3{color:#1e293b;font-size:1rem;font-weight:700;margin:0}.dashboard-card-body{padding:16px 20px 20px}.dashboard-charts-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:24px}.chart-card-half,.chart-card-wide{grid-column:span 1}.chart-controls{align-items:center;display:flex;gap:8px}.chart-controls label{color:#64748b;font-size:.8rem;font-weight:600}.chart-year-select{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;font-size:.85rem;font-weight:600;outline:none;padding:5px 10px;transition:border-color .2s}.chart-year-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f114}.pie-chart-body{align-items:center;display:flex;flex-direction:column}.pie-legend{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:12px}.pie-legend-item{align-items:center;color:#475569;display:flex;font-size:.85rem;gap:6px}.pie-legend-dot{border-radius:50%;flex-shrink:0;height:12px;width:12px}.pie-legend-label{font-weight:500}.pie-legend-value{color:#1e293b;font-weight:700}.insights-list{display:flex;flex-direction:column;gap:14px}.insight-item{align-items:flex-start;background:#f8fafc;border:1px solid #f1f5f9;border-radius:10px;color:#475569;display:flex;font-size:.9rem;gap:12px;line-height:1.5;padding:12px 14px}.insight-item strong{color:#1e293b;font-weight:700}.insight-icon{flex-shrink:0;font-size:1.2rem;margin-top:2px}.dashboard-loading{align-items:center;color:#94a3b8;display:flex;font-size:1.1rem;font-weight:500;justify-content:center;min-height:400px}.chart-card-info .dashboard-card-body{padding:16px 20px}@media (max-width:1024px){.dashboard-charts-row{grid-template-columns:1fr}}@media (max-width:768px){.dashboard-banner{padding:24px 20px}.banner-text h1{font-size:1.4rem}.banner-date{font-size:.85rem}.banner-icon{display:none}.dashboard-stats-grid{grid-template-columns:1fr 1fr}.dashboard-section-title h2{font-size:1.05rem}}@media (max-width:480px){.dashboard-stats-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.8a1935c5.css.map*/