@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--primary: #4F46E5;--primary-light: #6366F1;--primary-dark: #4338CA;--primary-soft: rgba(79, 70, 229, .1);--success: #10B981;--success-bg: #D1FAE5;--success-text: #065F46;--warning: #F59E0B;--warning-bg: #FEF3C7;--warning-text: #92400E;--danger: #EF4444;--danger-bg: #FEE2E2;--danger-text: #991B1B;--info: #3B82F6;--info-bg: #DBEAFE;--info-text: #1E40AF;--bg-app: #F3F4F6;--bg-card: #FFFFFF;--bg-sidebar: #FFFFFF;--text-primary: #111827;--text-secondary: #6B7280;--text-tertiary: #9CA3AF;--border-color: #E5E7EB;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-card: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .03);--shadow-hover: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);--radius-lg: 16px;--radius-md: 12px;--radius-sm: 8px;--font-main: "Outfit", sans-serif;--transition: all .2s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);background-color:var(--bg-app);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden}.app-container{display:flex;height:100vh;width:100vw;overflow:hidden}.sidebar{width:260px;background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:24px 16px;flex-shrink:0;z-index:20}.brand{display:flex;align-items:center;gap:12px;padding:0 12px 32px}.brand-logo{width:36px;height:36px;background:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px;box-shadow:0 4px 12px #4f46e54d}.brand-name{font-size:20px;font-weight:700;letter-spacing:-.5px;color:var(--text-primary)}.nav-menu{display:flex;flex-direction:column;gap:4px;flex:1;overflow-y:auto}.nav-section{margin-bottom:24px}.nav-section-title{font-size:11px;text-transform:uppercase;color:var(--text-tertiary);font-weight:600;letter-spacing:.8px;padding:0 16px;margin-bottom:8px}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:var(--transition);font-weight:500;font-size:14px}.nav-link:hover{background:var(--bg-app);color:var(--primary)}.nav-link.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #4f46e540}.nav-link.active .nav-icon{filter:brightness(0) invert(1)}.nav-icon{font-size:18px;width:24px;text-align:center}.sidebar-footer{margin-top:auto;padding-top:20px;border-top:1px solid var(--border-color)}.user-profile{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-app);border-radius:var(--radius-md)}.user-info{display:flex;align-items:center;gap:10px;overflow:hidden}.user-avatar{width:36px;height:36px;background:var(--primary-light);border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-weight:600;font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--text-secondary)}.btn-logout{background:none;border:none;cursor:pointer;color:var(--text-tertiary);font-size:12px;padding:4px 8px;border-radius:4px;transition:var(--transition)}.btn-logout:hover{background:var(--danger-bg);color:var(--danger)}.main-content{flex:1;overflow-y:auto;padding:32px 40px;background-color:var(--bg-app)}h1,h2,h3,h4{color:var(--text-primary);line-height:1.2}p{color:var(--text-secondary)}.page-header{margin-bottom:32px;display:flex;justify-content:space-between;align-items:flex-end}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-card);border:none;margin-bottom:24px;transition:var(--transition)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-title{font-size:16px;font-weight:600;color:var(--text-primary)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-bottom:32px}.kpi-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;display:flex;align-items:center;gap:20px;box-shadow:var(--shadow-card);transition:var(--transition);border:none}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.kpi-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.kpi-icon.purple{background:#eef2ff;color:#4f46e5}.kpi-icon.cyan{background:#ecfeff;color:#06b6d4}.kpi-icon.green{background:#ecfdf5;color:#10b981}.kpi-icon.orange{background:#fff7ed;color:#f97316}.kpi-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1.1;margin-bottom:4px}.kpi-label{font-size:13px;color:var(--text-secondary);font-weight:500}.charts-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:24px}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}}.data-table-wrap{width:100%;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th{text-align:left;padding:12px 20px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-color);background-color:#fafafa;white-space:nowrap}.data-table td{padding:16px 20px;color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle}.data-table tbody tr{transition:background-color .15s}.data-table tbody tr:hover{background-color:#f9fafb}.empty-state{text-align:center;padding:40px 20px}.empty-icon{font-size:40px;margin-bottom:12px;opacity:.5}.empty-state h3{color:var(--text-primary);margin-bottom:4px;font-size:16px}.badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;line-height:1}.badge-entry{background:var(--success-bg);color:var(--success-text)}.badge-exit{background:var(--danger-bg);color:var(--danger-text)}.badge-transfer{background:var(--info-bg);color:var(--info-text)}.attachment-badge{background:#f3f4f6;color:#4b5563;padding:4px 10px;border-radius:12px;font-size:11px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border-radius:var(--radius-md);font-weight:600;font-size:14px;border:none;cursor:pointer;transition:var(--transition);gap:8px}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 6px -1px #4f46e566}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary{background:#fff;border:1px solid var(--border-color);color:var(--text-secondary)}.btn-secondary:hover{background:#f9fafb;border-color:#d1d5db;color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{background:transparent;border:none;width:32px;height:32px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:var(--transition);color:var(--text-secondary);font-size:16px}.btn-icon:hover{background:#f3f4f6;color:var(--primary)}.toolbar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--text-primary)}.form-control{width:100%;padding:12px 16px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:inherit;color:var(--text-primary);font-size:14px;transition:var(--transition)}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.search-input{position:relative;width:300px}.search-input input{width:100%;padding:12px 16px 12px 42px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);transition:var(--transition);box-shadow:var(--shadow-sm)}.search-input input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);opacity:.5;pointer-events:none}.filter-select{padding:10px 16px;border-radius:var(--radius-md);background:#fff;border:1px solid var(--border-color);color:var(--text-primary);font-size:14px;cursor:pointer;box-shadow:var(--shadow-sm);outline:none}.filter-select:focus{border-color:var(--primary)}.form-row{display:flex;gap:20px}.form-row .form-group{flex:1}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-app);padding:20px}.login-card{width:100%;max-width:400px;background:#fff;border-radius:24px;padding:40px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid #F3F4F6;text-align:center}.login-logo{width:64px;height:64px;background:var(--primary);color:#fff;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;font-size:32px;border-radius:20px;box-shadow:0 10px 20px #4f46e54d}.login-title{font-size:24px;font-weight:800;margin-bottom:8px;color:var(--text-primary)}.login-subtitle{color:var(--text-secondary);font-size:14px;margin-bottom:32px}.login-footer{margin-top:24px;padding:16px;background:#f9fafb;border-radius:var(--radius-md);font-size:13px;color:var(--text-secondary);text-align:left}.login-footer div{margin-bottom:4px;font-family:monospace}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .2s}.modal-overlay.active{opacity:1;visibility:visible}.modal{background:#fff;border-radius:20px;width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;transform:translateY(20px);transition:transform .3s cubic-bezier(.16,1,.3,1)}.modal-overlay.active .modal{transform:translateY(0)}.modal.modal-lg{max-width:800px}.modal-header{padding:24px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:18px;font-weight:700;color:var(--text-primary)}.modal-close{background:transparent;border:none;font-size:24px;cursor:pointer;color:var(--text-tertiary);transition:color .1s}.modal-close:hover{color:var(--danger)}.modal-body{padding:24px;overflow-y:auto}.modal-footer{padding:20px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px;background:#fdfdfd;border-radius:0 0 20px 20px}.file-upload-area{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:24px;text-align:center;cursor:pointer;background:#fff;transition:var(--transition)}.file-upload-area:hover{border-color:var(--primary);background:var(--bg-app)}.upload-icon{font-size:32px;margin-bottom:8px;color:var(--primary);opacity:.8}.upload-text{color:var(--text-secondary);font-size:14px}.upload-text span{color:var(--primary);font-weight:600}.file-list{margin-top:16px;display:flex;flex-direction:column;gap:8px}.file-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#f9fafb;border:1px solid var(--border-color);border-radius:8px}.file-name{flex:1;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size{font-size:11px;color:var(--text-tertiary)}.file-remove{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:18px;line-height:1}.file-remove:hover{color:var(--danger)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:10px}.toast{background:#fff;color:var(--text-primary);padding:16px 20px;border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;display:flex;align-items:center;gap:12px;min-width:280px;animation:slideIn .3s cubic-bezier(.16,1,.3,1);border-left:4px solid var(--primary)}.toast.error{border-left-color:var(--danger)}.toast.success{border-left-color:var(--success)}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px}.detail-item label{font-size:12px;color:var(--text-secondary);display:block;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.detail-item .value{font-size:15px;font-weight:500;color:var(--text-primary)}
