*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f5f6fa;--surface:#fff;--border:#e8eaed;--border-light:#f0f2f5;--text:#1a1d23;--text-secondary:#6b7280;--text-muted:#9ca3af;--primary:#2563eb;--primary-light:#eff6ff;--primary-hover:#1d4ed8;--success:#16a34a;--success-light:#f0fdf4;--danger:#dc2626;--danger-light:#fef2f2;--warning:#d97706;--warning-light:#fffbeb;--radius:8px;--radius-lg:12px;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #0000000f, 0 2px 4px #0000000a}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5}.layout{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;flex-shrink:0;width:220px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border-light);padding:20px 20px 16px}.sidebar-logo h1{color:var(--primary);font-size:15px;font-weight:700}.sidebar-logo span{color:var(--text-muted);font-size:11px}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-label{letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);padding:8px 10px 4px;font-size:10px;font-weight:600;display:block}.nav-item{border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 10px;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg);color:var(--text)}.nav-item.active{background:var(--primary-light);color:var(--primary)}.nav-item svg{flex-shrink:0;width:16px;height:16px}.sidebar-footer{border-top:1px solid var(--border-light);padding:12px 10px}.main{flex:1;min-height:100vh;margin-left:220px}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{font-size:15px;font-weight:600}.topbar-user{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.page-content{padding:24px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-title{font-size:14px;font-weight:600}.card-body{padding:20px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:18px 20px}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:600}.stat-value{font-size:28px;font-weight:700;line-height:1}.stat-card.primary .stat-value{color:var(--primary)}.stat-card.success .stat-value{color:var(--success)}.stat-card.warning .stat-value{color:var(--warning)}.stat-card.danger .stat-value{color:var(--danger)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg);padding:10px 14px;font-size:11.5px;font-weight:600}td{border-bottom:1px solid var(--border-light);color:var(--text);vertical-align:middle;padding:11px 14px;font-size:13.5px}tr:last-child td{border-bottom:none}tr:hover td{background:#fafbfc}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:2px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-light);color:var(--success)}.badge-primary{background:var(--primary-light);color:var(--primary)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-gray{color:#6b7280;background:#f3f4f6}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-outline{color:var(--text);border:1px solid var(--border);background:#fff}.btn-outline:hover{background:var(--bg)}.btn-danger{background:var(--danger-light);color:var(--danger)}.btn-danger:hover{background:#fecaca}.btn-success{background:var(--success-light);color:var(--success)}.btn-success:hover{background:#bbf7d0}.btn-sm{padding:4px 10px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:16px}.form-label{margin-bottom:5px;font-size:13px;font-weight:500;display:block}.form-control{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:#fff;outline:none;padding:8px 11px;font-size:13.5px;transition:border-color .15s}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb14}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:80px}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-4{margin-top:16px}.text-sm{font-size:12px}.text-muted{color:var(--text-muted)}.font-semibold{font-weight:600}.w-full{width:100%}.modal-overlay{z-index:200;background:#00000059;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-title{font-size:15px;font-weight:600}.modal-body{padding:20px}.modal-footer{border-top:1px solid var(--border-light);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.search-bar{align-items:center;gap:10px;margin-bottom:16px;display:flex}.search-input-wrap{flex:1;max-width:300px;position:relative}.search-input-wrap svg{color:var(--text-muted);width:15px;height:15px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input{border:1px solid var(--border);border-radius:var(--radius);background:#fff;outline:none;width:100%;padding:7px 11px 7px 32px;font-size:13px}.search-input:focus{border-color:var(--primary)}.empty-state{text-align:center;color:var(--text-muted);padding:48px 20px}.empty-state svg{opacity:.3;width:40px;height:40px;margin:0 auto 12px;display:block}.empty-state p{font-size:13.5px}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:380px;padding:40px 36px}.login-logo{text-align:center;margin-bottom:28px}.login-logo h1{color:var(--primary);font-size:20px;font-weight:700}.login-logo p{color:var(--text-muted);margin-top:4px;font-size:13px}.type-out{color:var(--danger);font-weight:600}.type-in{color:var(--success);font-weight:600}.divider{border:none;border-top:1px solid var(--border-light);margin:16px 0}.detail-history{border-top:1px solid var(--border-light);margin-top:20px;padding-top:16px}.history-item{border-bottom:1px solid var(--border-light);gap:12px;padding:10px 0;display:flex}.history-item:last-child{border-bottom:none}.history-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.history-dot.out{background:var(--danger)}.history-dot.in{background:var(--success)}
