@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.navbar{border-bottom:1px solid var(--gray-200);z-index:100;height:60px;box-shadow:var(--shadow);background:#fff;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.navbar-brand{align-items:center;gap:10px;display:flex}.navbar-logo{background:var(--primary);color:#fff;letter-spacing:2px;border-radius:6px;padding:4px 12px;font-size:18px;font-weight:700}.navbar-title{color:var(--gray-800);font-size:16px;font-weight:600}.navbar-toggle{cursor:pointer;background:0 0;border:none;padding:8px;display:none}.hamburger{background:var(--gray-700);width:24px;height:2px;transition:var(--transition);display:block;position:relative}.hamburger:before,.hamburger:after{content:"";background:var(--gray-700);width:24px;height:2px;transition:var(--transition);position:absolute}.hamburger:before{top:-7px}.hamburger:after{top:7px}.hamburger.open{background:0 0}.hamburger.open:before{top:0;transform:rotate(45deg)}.hamburger.open:after{top:0;transform:rotate(-45deg)}.navbar-menu{align-items:center;gap:4px;display:flex}.navbar-link{color:var(--gray-600);cursor:pointer;border-radius:var(--radius);transition:var(--transition);background:0 0;border:none;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:14px;font-weight:500;display:flex}.navbar-link:hover{background:var(--gray-100);color:var(--gray-800)}.navbar-link.active{background:var(--primary-light);color:var(--primary)}.nav-icon{font-size:16px}.navbar-user{border-left:1px solid var(--gray-200);flex-direction:column;align-items:center;margin-left:16px;padding-left:16px;display:flex}.user-name{color:var(--gray-800);white-space:nowrap;font-size:14px;font-weight:600;line-height:1.2}.user-role-badge{border-radius:12px;margin-top:2px;padding:1px 8px;font-size:10px;font-weight:600;display:inline-block}.user-role-badge.badge-superadmin{color:#92400e;background:#fef3c7}.user-role-badge.badge-manager{background:var(--primary-light);color:var(--primary)}.user-role-badge.badge-employee{background:var(--gray-100);color:var(--gray-600)}.navbar-logout{border:1px solid var(--gray-300);color:var(--gray-600);cursor:pointer;border-radius:var(--radius);transition:var(--transition);background:#fff;margin-left:8px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500}.navbar-logout:hover{background:var(--danger-light);color:var(--danger);border-color:#fecaca}@media (width<=768px){.navbar-toggle{display:block}.navbar-menu{border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-md);background:#fff;flex-direction:column;padding:16px;display:none;position:absolute;top:60px;left:0;right:0}.navbar-menu.show{display:flex}.navbar-link{justify-content:flex-start;width:100%;padding:12px}.navbar-user{border-left:none;border-top:1px solid var(--gray-200);align-items:center;width:100%;margin-top:8px;margin-left:0;padding-top:12px;padding-left:0}.navbar-logout{text-align:center;width:100%;margin-top:8px;margin-left:0}}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:24px}@media (width<=768px){.main-content{padding:16px}}.loading-container{min-height:100vh;color:var(--gray-500);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-container{background:linear-gradient(135deg,#1e3a5f 0%,#2563eb 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:40px;box-shadow:0 20px 60px #0003}.auth-header{text-align:center;margin-bottom:32px}.auth-header h1{color:var(--primary);letter-spacing:4px;margin-bottom:4px;font-size:42px;font-weight:700}.auth-header p{color:var(--gray-500);font-size:14px}.auth-form{flex-direction:column;display:flex}.auth-form .form-group input{padding:12px 14px;font-size:15px}.auth-footer{text-align:center;margin-top:20px}.auth-footer a{color:var(--primary);font-size:14px;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-description{color:var(--gray-500);margin-bottom:20px;font-size:14px;line-height:1.5}.auth-success{text-align:center}.auth-success p{color:var(--gray-600);margin-bottom:20px;font-size:14px}.expense-table-container{width:100%}.expense-table td.actions{white-space:nowrap;align-items:center;gap:6px;display:flex}.comment-indicator{cursor:help;font-size:16px}@media (width<=768px){.expense-table thead{display:none}.expense-table tbody tr{border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:12px;padding:12px;display:block}.expense-table tbody td{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:6px 0;display:flex}.expense-table tbody td:before{content:attr(data-label);color:var(--gray-600);text-transform:uppercase;font-size:12px;font-weight:600}.expense-table tbody td:last-child{border-bottom:none}.expense-table td.actions{justify-content:flex-end}}.attachment-cell{text-align:center;min-width:80px}.btn-attachment{color:#2563eb;cursor:pointer;background:#f0f4ff;border:1px solid #c7d2fe;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;transition:all .2s;display:inline-flex}.btn-attachment:hover{color:#fff;background:#2563eb;border-color:#2563eb}.attachment-badge{letter-spacing:.3px;background:#2563eb26;border-radius:3px;justify-content:center;align-items:center;width:28px;height:20px;font-size:10px;font-weight:700;display:inline-flex}.btn-attachment:hover .attachment-badge{background:#ffffff40}.attachment-label{font-weight:600}.no-attachment{color:#d1d5db}.attachment-preview-container{text-align:center;max-height:70vh;margin:16px 0;overflow:auto}.attachment-preview-image{border-radius:8px;max-width:100%;max-height:60vh;box-shadow:0 2px 8px #0000001a}.attachment-actions{justify-content:center;align-items:center;gap:4px;display:flex}.btn-attachment-delete{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;padding:4px 8px;font-size:11px;font-weight:700;line-height:1;transition:all .2s}.btn-attachment-delete:hover{color:#fff;background:#dc2626;border-color:#dc2626}.page-container{animation:.3s fadeIn}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h2{color:var(--gray-900);font-size:24px;font-weight:700}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow);border-top:3px solid var(--gray-300);transition:var(--transition);background:#fff;padding:20px}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-value{color:var(--gray-800);font-variant-numeric:tabular-nums;margin-bottom:4px;font-size:28px;font-weight:700}.stat-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.stat-pending{border-top-color:var(--warning)}.stat-pending .stat-value{color:var(--warning)}.stat-approved{border-top-color:var(--success)}.stat-approved .stat-value{color:var(--success)}.stat-rejected{border-top-color:var(--danger)}.stat-rejected .stat-value{color:var(--danger)}.stat-amount{border-top-color:var(--primary)}.stat-amount .stat-value{color:var(--primary);font-size:22px}.stat-amount-approved{border-top-color:var(--success)}.stat-amount-approved .stat-value{color:var(--success);font-size:22px}.tab-nav{border-radius:var(--radius-lg);box-shadow:var(--shadow);background:#fff;flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:24px;padding:6px;display:flex}.tab-btn{color:var(--gray-500);cursor:pointer;border-radius:var(--radius);transition:var(--transition);background:0 0;border:none;align-items:center;gap:6px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;display:flex}.tab-btn:hover{background:var(--gray-100);color:var(--gray-700)}.tab-btn.active{background:var(--primary);color:#fff}.tab-action{margin-left:auto}.tab-content{animation:.2s fadeIn}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.filter-bar label{color:var(--gray-600);font-size:14px;font-weight:500}.filter-bar select{border:1px solid var(--gray-300);border-radius:var(--radius);cursor:pointer;background:#fff;padding:8px 12px;font-family:inherit;font-size:14px}.filter-bar select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header h3{color:var(--gray-800);font-size:18px;font-weight:600}.pagination{border-top:1px solid var(--gray-100);justify-content:center;align-items:center;gap:16px;margin-top:20px;padding-top:16px;display:flex}.page-info{color:var(--gray-500);font-size:13px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (width<=768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:22px}.stat-amount .stat-value,.stat-amount-approved .stat-value{font-size:18px}.tab-nav{gap:2px;padding:4px}.tab-btn{padding:8px 12px;font-size:13px}.page-header{flex-direction:column;align-items:flex-start}}.stat-card.clickable{cursor:pointer;position:relative}.stat-card.clickable:after{content:"→";color:var(--gray-400);opacity:0;font-size:14px;transition:opacity .2s,transform .2s;position:absolute;bottom:8px;right:12px}.stat-card.clickable:hover:after{opacity:1;transform:translate(2px)}.stat-card.clickable:hover{border-top-width:4px;transform:translateY(-3px);box-shadow:0 4px 12px #0000001f}.stat-card.clickable:active{transform:translateY(-1px)}.stats-panel{width:100%}.stats-section{margin-top:24px}.stats-section h3{color:var(--gray-800);border-bottom:1px solid var(--gray-200);margin-bottom:16px;padding-bottom:8px;font-size:18px;font-weight:600}.stats-table-container{overflow-x:auto}.simple-chart{margin-top:20px}.chart-bar-row{align-items:center;gap:12px;margin-bottom:10px;display:flex}.chart-label{min-width:120px;color:var(--gray-700);text-align:right;font-size:13px}.chart-bar-container{background:var(--gray-100);border-radius:4px;flex:1;height:24px;overflow:hidden}.chart-bar{background:linear-gradient(90deg, var(--primary), #60a5fa);border-radius:4px;min-width:4px;height:100%;transition:width .5s}.chart-value{min-width:80px;color:var(--gray-700);font-size:13px;font-weight:600}@media (width<=768px){.chart-label{min-width:80px;font-size:12px}.chart-value{min-width:60px;font-size:12px}}.employee-form{max-width:600px}.employee-form .form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.label-hint{color:var(--primary);font-size:12px;font-style:italic;font-weight:400}.field-warning{background:var(--warning-light);color:var(--warning);border-radius:var(--radius);border:1px solid #fde68a;margin-top:4px;padding:8px 12px;font-size:12px;line-height:1.4;display:block}@media (width<=600px){.employee-form .form-row{grid-template-columns:1fr}}.delete-section{border-top:2px solid #fecaca;margin-top:24px;padding-top:24px}.btn-danger{color:#fff;border-radius:var(--radius,8px);cursor:pointer;background-color:#dc2626;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-danger:hover{background-color:#b91c1c;transform:translateY(-1px);box-shadow:0 2px 8px #dc26264d}.btn-danger:active{transform:translateY(0)}.btn-danger:disabled{cursor:not-allowed;box-shadow:none;background-color:#fca5a5;transform:none}.delete-confirm-box{border-radius:var(--radius,8px);background:#fef2f2;border:1px solid #fecaca;padding:16px;animation:.2s fadeInSlide}.delete-confirm-text{color:#991b1b;margin:0 0 16px;font-size:14px;line-height:1.5}.delete-confirm-text strong{color:#7f1d1d}.delete-confirm-actions{flex-wrap:wrap;gap:12px;display:flex}.delete-confirm-actions .btn-secondary{color:#374151;background:#fff;border:1px solid #d1d5db}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (width<=600px){.delete-confirm-actions{flex-direction:column}.delete-confirm-actions .btn-danger,.delete-confirm-actions .btn-secondary{justify-content:center;width:100%}}.sa-actions{flex-wrap:wrap;gap:4px;display:flex}.sa-role-summary{gap:24px;margin-top:12px;display:flex}.sa-role-item{align-items:center;gap:8px;display:flex}.badge-superadmin{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.badge-action{color:#6d28d9;background:#ede9fe;font-size:11px}.modal-lg{width:95%;max-width:700px}.audit-date{white-space:nowrap;color:var(--gray-500);font-size:12px}.audit-details{color:var(--gray-600);text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-size:12px;overflow:hidden}@media (width<=768px){.sa-actions{flex-direction:column}.sa-role-summary{flex-direction:column;gap:8px}}.dynamic-form{max-width:600px}.dynamic-form .form-group{margin-bottom:18px}.dynamic-form select{border:1px solid var(--gray-300);border-radius:var(--radius);cursor:pointer;width:100%;transition:var(--transition);background:#fff;padding:10px 12px;font-family:inherit;font-size:14px}.dynamic-form select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.dynamic-form textarea{border:1px solid var(--gray-300);border-radius:var(--radius);resize:vertical;width:100%;transition:var(--transition);padding:10px 12px;font-family:inherit;font-size:14px}.dynamic-form textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.attachment-section{border-top:1px dashed #d1d5db;margin-top:8px;padding-top:12px}.attachment-hint{color:#6b7280;margin:4px 0 8px;font-size:12px}.attachment-input{cursor:pointer;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;width:100%;padding:10px;font-size:14px;transition:border-color .2s}.attachment-input:hover{border-color:#2563eb}.attachment-input::file-selector-button{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;margin-right:12px;padding:8px 16px;font-weight:600}.attachment-input::file-selector-button:hover{background:#1d4ed8}.attachment-preview{background:#f0f4ff;border:1px solid #c7d2fe;border-radius:8px;align-items:center;gap:12px;margin-top:12px;padding:10px;display:flex}.attachment-thumb{object-fit:cover;border:1px solid #e5e7eb;border-radius:6px;width:60px;height:60px}.attachment-file-icon{color:#fff;background:#dc2626;border-radius:6px;justify-content:center;align-items:center;width:60px;height:60px;font-size:14px;font-weight:700;display:flex}.attachment-info{flex-direction:column;flex:1;gap:2px;display:flex}.attachment-name{color:#1f2937;word-break:break-all;font-size:14px;font-weight:600}.attachment-size{color:#6b7280;font-size:12px}.attachment-remove{padding:4px 10px;font-size:12px}:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#dbeafe;--success:#16a34a;--success-light:#dcfce7;--danger:#dc2626;--danger-light:#fee2e2;--warning:#d97706;--warning-light:#fef3c7;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--radius:8px;--radius-lg:12px;--shadow:0 1px 3px #0000001a;--shadow-md:0 4px 6px #00000012;--shadow-lg:0 10px 15px #0000001a;--transition:all .2s ease}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--gray-50);color:var(--gray-800);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.btn{border-radius:var(--radius);cursor:pointer;transition:var(--transition);border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;line-height:1.4;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border-color:var(--gray-300)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-sm{padding:4px 10px;font-size:12px}.btn-block{width:100%}.form-group{margin-bottom:16px}.form-group label{color:var(--gray-700);margin-bottom:4px;font-size:14px;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--gray-300);border-radius:var(--radius);width:100%;transition:var(--transition);background:#fff;padding:10px 12px;font-family:inherit;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-actions{gap:12px;margin-top:20px;display:flex}.card{border-radius:var(--radius-lg);box-shadow:var(--shadow);background:#fff;margin-bottom:20px;padding:24px}.alert{border-radius:var(--radius);margin-bottom:16px;padding:12px 16px;font-size:14px}.alert-error{background:var(--danger-light);color:var(--danger);border:1px solid #fecaca}.alert-success{background:var(--success-light);color:var(--success);border:1px solid #bbf7d0}.alert-warning{background:var(--warning-light);color:var(--warning);border:1px solid #fde68a}.badge{white-space:nowrap;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:600;display:inline-block}.badge-pending{background:var(--warning-light);color:var(--warning)}.badge-approved{background:var(--success-light);color:var(--success)}.badge-rejected{background:var(--danger-light);color:var(--danger)}.badge-active{background:var(--success-light);color:var(--success)}.badge-inactive{background:var(--danger-light);color:var(--danger)}.badge-manager{background:var(--primary-light);color:var(--primary)}.badge-employee{background:var(--gray-100);color:var(--gray-600)}.table-responsive{overflow-x:auto}.data-table,.expense-table,.stats-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th,.expense-table th,.stats-table th{background:var(--gray-50);text-align:left;color:var(--gray-600);border-bottom:2px solid var(--gray-200);white-space:nowrap;padding:12px 16px;font-weight:600}.data-table td,.expense-table td,.stats-table td{border-bottom:1px solid var(--gray-100);vertical-align:middle;padding:12px 16px}.data-table tbody tr:hover,.expense-table tbody tr:hover{background:var(--gray-50)}.amount{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.amount-approved{color:var(--success);font-weight:600}.amount-pending{color:var(--warning);font-weight:600}.empty-state{text-align:center;color:var(--gray-400);padding:40px}.empty-state p{font-size:16px}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-lg);width:90%;max-width:500px;box-shadow:var(--shadow-lg);background:#fff;padding:24px}.modal-content h3{margin-bottom:16px}.modal-content textarea{border:1px solid var(--gray-300);border-radius:var(--radius);resize:vertical;width:100%;margin-bottom:16px;padding:10px;font-family:inherit;font-size:14px}.modal-actions{justify-content:flex-end;gap:12px;display:flex}
