.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f172a}.login-form{padding:24px 32px;border-radius:12px;background:#f9fafb;border:1px solid #e5e7eb;box-shadow:0 16px 30px #00000059;width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px}.login-title{margin:0 0 12px;text-align:center;color:#0f172a}.login-label{display:flex;flex-direction:column;font-size:14px;gap:4px;color:#4b5563}.login-input{padding:8px 10px;border-radius:6px;border:1px solid #9ca3af;font-size:14px;background:#fff;color:#111827}.login-input::placeholder{color:#9ca3af}.login-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 1px #2563eb59}.login-error{font-size:13px;color:#b91c1c}.login-button{margin-top:8px;padding:10px 14px;border-radius:6px;border:none;font-size:14px;font-weight:600;cursor:pointer;background:#2563eb;color:#fff;transition:background .15s ease,transform .05s ease}.login-button:disabled{opacity:.7;cursor:default}.login-button:not(:disabled):hover{background:#1d4ed8}.login-button:not(:disabled):active{transform:translateY(1px)}.dashboard-page{min-height:100vh;display:flex;flex-direction:column;background:#f3f4f6}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:#fff;border-bottom:1px solid #e5e7eb}.dashboard-title{margin:0;font-size:20px;font-weight:600;color:#111827}.dashboard-subtitle{margin:4px 0 0;font-size:14px;color:#6b7280}.dashboard-logout-button{padding:6px 10px;font-size:13px;border-radius:999px;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer;transition:background .15s ease,border-color .15s ease}.dashboard-logout-button:hover{background:#f3f4f6;border-color:#9ca3af}.dashboard-content{flex:1;padding:16px;display:flex;justify-content:center;align-items:stretch}.dashboard-main-card{width:100%;max-width:100%;background:#fff;border-radius:0;box-shadow:none;padding:16px 20px 20px}@media(max-width:767px){.dashboard-content{padding:16px;justify-content:center;align-items:flex-start}.dashboard-main-card{max-width:1000px;border-radius:12px;box-shadow:0 16px 30px #00000014}}.dashboard-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.dashboard-toolbar-left,.dashboard-toolbar-right{display:flex;align-items:center;gap:8px}.btn-primary,.btn-secondary{border-radius:6px;padding:8px 12px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease}.btn-primary{background:#2563eb;color:#fff;border-color:#2563eb}.btn-primary:hover{background:#1d4ed8;border-color:#1d4ed8}.btn-secondary{background:#fff;color:#374151;border-color:#d1d5db}.btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}.dashboard-error{margin-bottom:8px;padding:8px 10px;font-size:13px;border-radius:6px;background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.dashboard-placeholder{padding:16px;text-align:center;font-size:14px;color:#6b7280}.clients-table-wrapper{overflow-x:auto}.clients-table{width:100%;border-collapse:collapse;font-size:14px}.clients-table thead th{text-align:left;padding:8px 10px;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:500;color:#4b5563}.clients-table tbody td{padding:8px 10px;border-bottom:1px solid #e5e7eb}.clients-row{cursor:pointer;transition:background .1s ease}.clients-row:hover{background:#f3f4f6}.table-sort-button{padding:0;border:none;background:none;font:inherit;color:inherit;display:inline-flex;align-items:center;gap:4px;cursor:pointer}.sort-indicator{font-size:11px;color:#9ca3af}.dashboard-location-filter{position:relative}.location-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border-radius:8px;border:1px solid #e5e7eb;box-shadow:0 10px 25px #0000001a;min-width:180px;z-index:20;padding:4px 0}.location-dropdown-item{width:100%;padding:6px 10px;border:none;background:#fff;font-size:13px;text-align:left;cursor:pointer;color:#374151}.location-dropdown-item:hover{background:#f3f4f6}.modal-backdrop{position:fixed;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:12px;box-shadow:0 18px 35px #0003;padding:20px 24px;min-width:320px;max-width:480px}.modal-title{margin:0 0 12px;font-size:18px;font-weight:600;color:#111827}.modal-body{margin-bottom:14px;display:flex;flex-direction:column;gap:8px}.modal-row{display:flex;gap:8px;font-size:14px}.modal-label{min-width:150px;font-weight:500;color:#4b5563}.modal-hint{margin-top:4px;font-size:12px;color:#6b7280}.modal-footer{display:flex;justify-content:flex-end;gap:8px}.form-field{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}.form-label{font-size:14px;color:#4b5563}.form-input,.form-select{padding:8px 10px;border-radius:6px;border:1px solid #d1d5db;font-size:14px}.form-input:focus,.form-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 1px #2563eb59}.qr-wrapper{margin-top:8px;padding-top:8px;border-top:1px dashed #e5e7eb;text-align:center}.qr-label{margin:0 0 8px;font-size:13px;color:#4b5563}.qr-inner{display:inline-block;padding:8px;background:#f9fafb;border-radius:8px}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}
