:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}body{background:#f5f5f5;min-height:100vh;margin:0;padding:0}*{box-sizing:border-box}.login-container{background:linear-gradient(135deg,#1e293b 0%,#334155 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-box{background:#fff;border-radius:16px;width:100%;max-width:440px;padding:48px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:40px}.logo-circle{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 20px;display:flex;box-shadow:0 8px 24px #3b82f64d}.logo-circle svg{color:#fff;font-size:40px}.login-header h1{color:#1e293b;margin-bottom:8px;font-size:28px;font-weight:700}.login-header p{color:#64748b;margin:0;font-size:14px}.form-group{margin-bottom:24px}.form-group label{color:#1e293b;margin-bottom:8px;font-size:14px;font-weight:600;display:block}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#94a3b8;pointer-events:none;font-size:20px;position:absolute;left:16px}.form-group input{box-sizing:border-box;background:#f8f9fa;border:2px solid #e2e8f0;border-radius:10px;width:100%;padding:14px 16px 14px 48px;font-size:15px;transition:all .3s}.form-group input:focus{background:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 4px #3b82f61a}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:10px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #3b82f64d}.login-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.login-btn:active{transform:translateY(0)}.login-hint{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:12px;margin-top:32px;padding:20px}.hint-header{color:#1e293b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:14px;font-weight:700}.hint-content p{color:#64748b;margin:8px 0;font-size:14px}.hint-content strong{color:#1e293b;font-weight:600}.dashboard-layout{background:#f1f5f9;min-height:100vh;display:flex;overflow-x:hidden}.sidebar{color:#fff;z-index:100;background:#1e293b;flex-shrink:0;width:260px;height:100vh;position:fixed;overflow:hidden auto;box-shadow:2px 0 10px #0000001a}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:24px 20px}.logo{align-items:center;gap:12px;display:flex}.logo-icon{color:#3b82f6;font-size:28px}.sidebar-header h2{color:#fff;margin:0;font-size:22px;font-weight:700}.sidebar-nav{padding:16px 12px}.nav-item{color:#94a3b8;cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:12px;margin-bottom:6px;padding:12px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .3s;display:flex}.nav-item:hover{color:#3b82f6;background:#3b82f626}.nav-item.active{color:#fff;background:#3b82f6;box-shadow:0 4px 12px #3b82f64d}.nav-icon{flex-shrink:0;font-size:20px}.main-content{flex-direction:column;flex:1;min-width:0;margin-left:260px;display:flex;overflow:hidden}.top-header{z-index:10;background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 32px;display:flex;position:sticky;top:0;box-shadow:0 1px 3px #00000014}.header-left h3{color:#1e293b;margin:0 0 3px;font-size:22px;font-weight:700}.header-subtitle{color:#64748b;margin:0;font-size:13px}.header-right{align-items:center;gap:20px;display:flex}.user-info{background:#f8fafc;border-radius:10px;align-items:center;gap:10px;padding:6px 14px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.user-details{flex-direction:column;display:flex;overflow:hidden}.user-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-email{color:#64748b;white-space:nowrap;text-overflow:ellipsis;max-width:150px;font-size:11px;overflow:hidden}.logout-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ef4444;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .3s;display:flex;box-shadow:0 2px 4px #ef444433}.logout-btn:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 8px #ef44444d}.logout-btn svg{font-size:16px}.content-area{flex:1;min-width:0;padding:0;overflow:hidden auto}@media (width<=1024px){.sidebar{width:80px}.sidebar-header h2,.nav-item span{display:none}.nav-item{justify-content:center;padding:14px}.main-content{margin-left:80px}.user-info{padding:6px 10px}.user-details{display:none}}@media (width<=768px){.top-header{flex-direction:column;align-items:flex-start;gap:16px;padding:16px 20px}.header-left h3{font-size:20px}.header-right{justify-content:space-between;width:100%}}.dashboard-content{max-width:100%;min-height:calc(100vh - 80px);margin:0 auto;padding:20px 28px 32px;overflow-x:hidden}.dashboard-header{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.dashboard-header h1{color:#1e293b;letter-spacing:-.5px;margin:0 0 4px;font-size:26px;font-weight:700}.dashboard-subtitle{color:#64748b;margin:0;font-size:14px;font-weight:500}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 20px;display:flex}.spinner{border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#64748b;font-size:14px;font-weight:600}.stats-grid{flex-shrink:0;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:14px;min-width:0;padding:18px;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 1px 3px #00000014}.stat-card:before{content:"";opacity:0;background:linear-gradient(90deg,#0000,currentColor,#0000);height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.stat-card:hover{border-color:#cbd5e1;transform:translateY(-3px);box-shadow:0 6px 16px #0000001a}.stat-card:hover:before{opacity:1}.stat-icon-wrapper{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .3s;display:flex}.stat-card:hover .stat-icon-wrapper{transform:scale(1.1)}.stat-icon-wrapper svg{font-size:24px}.stat-info{flex:1;min-width:0;overflow:hidden}.stat-info h3{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;margin:0 0 2px;font-size:24px;font-weight:700;line-height:1;overflow:hidden}.stat-info p{color:#64748b;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:11px;font-weight:600;line-height:1.3;overflow:hidden}.stat-subtitle{color:#94a3b8;text-transform:none;letter-spacing:0;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:10px;font-weight:500;display:block;overflow:hidden}.dashboard-sections{flex-direction:column;gap:20px;min-width:0;display:flex;overflow:hidden}.section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;min-width:0;padding:20px;transition:box-shadow .3s;overflow:hidden;box-shadow:0 1px 3px #00000014}.section:hover{box-shadow:0 4px 12px #0000001a}.section-header{border-bottom:2px solid #f1f5f9;flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:14px;display:flex}.section-header h2{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;margin:0 0 3px;font-size:17px;font-weight:700;overflow:hidden}.section-title-with-icon{align-items:center;gap:12px;min-width:0;display:flex}.section-title-with-icon>div{min-width:0;overflow:hidden}.section-icon{border-radius:10px;flex-shrink:0;padding:8px;font-size:28px}.medical-icon{color:#ec4899;background:#fce7f3}.police-icon{color:#8b5cf6;background:#ede9fe}.section-subtitle{color:#64748b;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:12px;font-weight:500;overflow:hidden}.view-all-btn{color:#64748b;cursor:pointer;white-space:nowrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .3s;display:flex}.view-all-btn:hover{color:#fff;background:#3b82f6;border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.view-all-btn svg{font-size:16px;transition:transform .3s}.view-all-btn:hover svg{transform:translate(3px)}.empty-state{text-align:center;background:#f8fafc;border:2px dashed #e2e8f0;border-radius:10px;padding:40px 20px}.empty-icon{color:#10b981;opacity:.8;margin-bottom:12px;font-size:56px}.empty-state p{color:#64748b;margin:0;font-size:13px;font-weight:500}.table-container{border:1px solid #e2e8f0;border-radius:10px;max-width:100%;max-height:400px;overflow:auto}.table-container::-webkit-scrollbar{width:6px;height:8px}.table-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.table-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.table-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}table{border-collapse:collapse;background:#fff;width:100%;min-width:max-content}thead{z-index:1;background:#f8fafc;border-bottom:2px solid #e2e8f0;position:sticky;top:0}th{text-align:left;color:#475569;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;background:#f8fafc;padding:10px 12px;font-size:11px;font-weight:700}td{color:#1e293b;white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:12px;font-size:13px;font-weight:500}tbody tr{transition:background .2s}.employee-cell{align-items:center;gap:10px;min-width:150px;display:flex}.employee-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex;box-shadow:0 2px 6px #3b82f64d}.medical-avatar{background:linear-gradient(135deg,#ec4899 0%,#db2777 100%);box-shadow:0 2px 6px #ec48994d}.police-avatar{background:linear-gradient(135deg,#8b5cf6 0%,#7c3aed 100%);box-shadow:0 2px 6px #8b5cf64d}.employee-cell span{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:13px;font-weight:600;overflow:hidden}.emp-id{color:#3b82f6;white-space:nowrap;background:#dbeafe;border-radius:6px;padding:5px 8px;font-family:Courier New,monospace;font-size:12px;font-weight:700}.gate-pass-number{color:#64748b;white-space:nowrap;background:#f1f5f9;border-radius:6px;padding:5px 8px;font-family:Courier New,monospace;font-size:12px;font-weight:600}.report-number{color:#ec4899;white-space:nowrap;background:#fce7f3;border-radius:6px;padding:5px 8px;font-family:Courier New,monospace;font-size:12px;font-weight:600}.days-left-badge{text-align:center;white-space:nowrap;border-radius:6px;min-width:70px;padding:5px 10px;font-size:12px;font-weight:700;display:inline-block}.action-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#3b82f6;border:none;border-radius:7px;flex-shrink:0;padding:7px 14px;font-size:12px;font-weight:600;transition:all .3s}.action-btn:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.medical-btn{background:#ec4899}.medical-btn:hover{background:#db2777;box-shadow:0 4px 12px #ec489966}.police-btn{background:#8b5cf6}.police-btn:hover{background:#7c3aed;box-shadow:0 4px 12px #8b5cf666}@media (width<=1400px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=1024px){.dashboard-content{padding:18px 20px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:14px}}@media (width<=768px){.dashboard-content{padding:16px}.dashboard-header h1{font-size:22px}.dashboard-subtitle{font-size:13px}.stats-grid{grid-template-columns:1fr;gap:12px}.stat-card{padding:16px}.stat-icon-wrapper{width:44px;height:44px}.stat-icon-wrapper svg,.stat-info h3{font-size:22px}.stat-info p{font-size:11px}.section{border-radius:10px;padding:16px}.section-header{flex-direction:column;align-items:flex-start;gap:12px;padding-bottom:12px}.section-header h2{font-size:16px}.section-title-with-icon{gap:10px}.section-icon{padding:7px;font-size:26px}.view-all-btn{justify-content:center;width:100%;padding:10px 16px}.empty-state{padding:36px 16px}.empty-icon{font-size:48px}.empty-state h3{font-size:16px}th,td{padding:10px;font-size:12px}.employee-avatar{width:32px;height:32px;font-size:12px}.employee-cell{min-width:140px}.employee-cell span{max-width:100px;font-size:12px}.emp-id,.gate-pass-number,.report-number{padding:4px 7px;font-size:11px}.days-left-badge{min-width:60px;padding:4px 8px;font-size:11px}.action-btn{padding:6px 12px;font-size:11px}}@media (width<=480px){.dashboard-header h1,.stat-info h3{font-size:20px}.section-header h2{font-size:15px}.section-icon{font-size:24px}}.gatepass-content{padding:32px 40px}.refresh-btn:hover:not(:disabled){color:#fff;background:#3b82f6;transform:translateY(-2px)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.refresh-btn .spinning{animation:1s linear infinite spin}.filter-group{background:#fff;border:2px solid #e2e8f0;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;display:flex}.filter-icon{color:#64748b;font-size:20px}.filter-select{color:#1e293b;cursor:pointer;background:0 0;border:none;outline:none;font-size:14px;font-weight:500}.badge{text-transform:capitalize;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:600;display:inline-block}.badge.active{color:#065f46;background:#d1fae5}.badge.completed{color:#1e40af;background:#dbeafe}.badge.pending{color:#92400e;background:#fef3c7}.badge.rejected{color:#991b1b;background:#fee2e2}.view-btn{color:#1e40af;background:#dbeafe}.view-btn:hover{color:#fff;background:#3b82f6;transform:translateY(-2px)}.edit-btn{color:#92400e;background:#fef3c7}.view-btn svg,.edit-btn svg{font-size:16px}.pagination-section{background:#fff;border-top:1px solid #e2e8f0;border-radius:0 0 16px 16px;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.records-per-page{color:#64748b;align-items:center;gap:8px;font-size:14px;display:flex}.records-per-page select{cursor:pointer;color:#1e293b;background:#fff;border:2px solid #e2e8f0;border-radius:6px;padding:6px 10px;font-size:13px;font-weight:600}@media (width<=768px){.pagination-section{text-align:center;flex-direction:column;gap:16px}.pagination-info{flex-direction:column;gap:12px}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-container{background:#fff;border-radius:16px;width:100%;max-width:900px;max-height:90vh;animation:.3s slideUp;overflow-y:auto;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{z-index:10;background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-start;padding:24px 28px;display:flex;position:sticky;top:0}.modal-header h2{color:#1e293b;margin:0 0 4px;font-size:24px;font-weight:700}.modal-subtitle{color:#64748b;margin:0;font-size:14px}.close-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:all .3s;display:flex}.close-btn:hover{color:#fff;background:#ef4444;transform:rotate(90deg)}.close-btn svg{font-size:20px}.error-message{color:#dc2626;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:8px;margin-bottom:20px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.form-section-title{color:#1e293b;border-bottom:2px solid #e2e8f0;margin:0 0 16px;padding-bottom:8px;font-size:16px;font-weight:700}.form-group input,.form-group select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:10px 12px;font-size:14px;transition:all .3s}.form-group input::placeholder{color:#94a3b8}.modal-footer{background:#fff;border-top:1px solid #e2e8f0;justify-content:flex-end;gap:12px;padding:20px 28px;display:flex;position:sticky;bottom:0}.btn-cancel,.btn-save{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s;display:flex}.btn-cancel{color:#1e293b;background:#f1f5f9}.btn-cancel:hover{background:#e2e8f0}.btn-save{color:#fff;background:#3b82f6}.btn-save:hover:not(:disabled){background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.btn-save:disabled{opacity:.6;cursor:not-allowed}.btn-save svg{font-size:18px}.modal-container::-webkit-scrollbar{width:8px}.modal-container::-webkit-scrollbar-track{background:#f1f5f9}.modal-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.modal-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.edit-modal-content{background:#fff;border-radius:20px;width:100%;max-width:1000px;max-height:90vh;animation:.3s slideUp;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.form-group input,.form-group select{color:#1e293b;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:12px 16px;font-size:14px;transition:all .3s}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 4px #3b82f61a}.employee-detail-content{max-width:1400px;margin:0 auto;padding:24px 32px 40px}.header-actions{gap:10px;display:flex}.header-btn{cursor:pointer;border:2px solid #0000;border-radius:10px;align-items:center;gap:8px;padding:10px 22px;font-size:14px;font-weight:600;transition:all .25s;display:inline-flex}.header-btn-icon{border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;transition:transform .25s;display:flex}.header-btn:hover .header-btn-icon{transform:scale(1.15)}.edit-btn{color:#b45309;background:#fffbeb;border-color:#fde68a}.edit-btn .header-btn-icon{color:#d97706;background:#fef3c7}.edit-btn:hover{background:#fef3c7;border-color:#f59e0b;box-shadow:0 4px 14px #f59e0b2e}.edit-btn:active{transform:scale(.97)}.terminate-btn{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.terminate-btn .header-btn-icon{color:#dc2626;background:#fee2e2}.terminate-btn:hover{background:#fee2e2;border-color:#f87171;box-shadow:0 4px 14px #ef44442e}.terminate-btn:active{transform:scale(.97)}.form-xiv-btn{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.form-xiv-btn .header-btn-icon{color:#2563eb;background:#dbeafe}.form-xiv-btn:hover{background:#dbeafe;border-color:#60a5fa;box-shadow:0 4px 14px #2563eb29}.form-xiv-btn:active{transform:scale(.97)}.form-xv-btn{color:#9d174d;background:#fdf2f8;border-color:#fbcfe8}.form-xv-btn .header-btn-icon{color:#be185d;background:#fce7f3}.form-xv-btn:hover{background:#fce7f3;border-color:#f472b6;box-shadow:0 4px 14px #db277726}.form-xv-btn:active{transform:scale(.97)}.appointment-letter-btn{color:#047857;background:#ecfdf5;border-color:#a7f3d0}.appointment-letter-btn .header-btn-icon{color:#059669;background:#d1fae5}.appointment-letter-btn:hover{background:#d1fae5;border-color:#34d399;box-shadow:0 4px 14px #0596692e}.appointment-letter-btn:active{transform:scale(.97)}.employee-header-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;align-items:center;gap:24px;margin-bottom:24px;padding:32px;display:flex;box-shadow:0 1px 3px #0000001a}.employee-header-info h2{color:#1e293b;margin:0 0 12px;font-size:28px;font-weight:700}.meta-badge{color:#64748b;background:#f1f5f9;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;display:inline-flex}.meta-badge svg{color:#3b82f6;font-size:18px}.detail-section{background:#fff;border:1px solid #e2e8f0;border-radius:16px;margin-bottom:20px;padding:28px;box-shadow:0 1px 3px #0000001a}.detail-section h3{color:#1e293b;border-bottom:2px solid #e2e8f0;margin:0 0 20px;padding-bottom:12px;font-size:18px;font-weight:700}.detail-item{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:6px;padding:16px;display:flex}.detail-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.detail-value{color:#1e293b;word-break:break-word;font-size:15px;font-weight:500}.emp-photo-img{object-fit:cover;border:3px solid #e2e8f0;border-radius:50%;flex-shrink:0;width:100px;height:100px;box-shadow:0 4px 12px #0000001f}.docs-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.doc-item{gap:10px}.doc-photo-wrapper{flex-direction:column;gap:10px;display:flex}.emp-photo-large{object-fit:cover;border:2px solid #e2e8f0;border-radius:10px;width:140px;height:140px;box-shadow:0 2px 8px #0000001a}.emp-avatar-doc{border-radius:10px;width:140px;height:140px;font-size:40px}.doc-pdf-wrapper{align-items:flex-start;gap:10px;display:flex}.doc-pdf-icon{color:#ef4444;flex-shrink:0;margin-top:2px;font-size:40px}.doc-pdf-info{flex-direction:column;gap:6px;min-width:0;display:flex}.doc-filename{color:#1e293b;word-break:break-all;font-size:13px;font-weight:500}.doc-view-link{color:#3b82f6;align-items:center;gap:4px;width:fit-content;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.doc-view-link:hover{text-decoration:underline}.doc-empty{color:#94a3b8;font-size:14px;font-style:italic}@media (width<=768px){.employee-header-card{text-align:center;flex-direction:column}.detail-grid{grid-template-columns:1fr}}.detail-content{max-width:1400px;margin:0 auto;padding:24px 32px 40px}.page-header-section{margin-bottom:24px}.header-content{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.header-left h1{color:#1e293b;margin:0 0 4px;font-size:28px;font-weight:700}.add-gate-pass-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 12px #3b82f64d}.add-gate-pass-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.add-gate-pass-btn svg{font-size:20px}.employee-info-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;margin-bottom:24px;padding:28px;box-shadow:0 1px 3px #0000001a}.employee-header{border-bottom:1px solid #e2e8f0;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:24px;display:flex}.employee-avatar-large{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;font-size:28px;font-weight:700;display:flex;box-shadow:0 4px 12px #3b82f64d}.employee-details h2{color:#1e293b;margin:0 0 8px;font-size:24px;font-weight:700}.employee-meta{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.emp-id-badge{color:#3b82f6;background:#f1f5f9;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-family:monospace;font-size:13px;font-weight:600;display:inline-flex}.emp-id-badge svg{font-size:16px}.status-badge{text-transform:capitalize;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;display:inline-flex}.status-badge svg{font-size:14px}.status-badge.active{color:#065f46;background:#d1fae5}.status-badge.pending{color:#92400e;background:#fef3c7}.status-badge.rejected{color:#991b1b;background:#fee2e2}.employee-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;display:grid}.stat-item{flex-direction:column;gap:4px;display:flex}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.stat-value{color:#1e293b;font-size:20px;font-weight:700}.gate-passes-section{margin-top:24px}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header h3{color:#1e293b;margin:0;font-size:18px;font-weight:700}.record-count{color:#64748b;background:#f1f5f9;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.gate-pass-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:12px;transition:all .3s;overflow:hidden;box-shadow:0 1px 3px #0000001a}.gate-pass-card:hover{box-shadow:0 4px 12px #0000001a}.gate-pass-header{cursor:pointer;background:#f8f9fa;justify-content:space-between;align-items:center;padding:16px 20px;transition:background .3s;display:flex}.gate-pass-header:hover{background:#f1f5f9}.gate-pass-header-left{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.gate-pass-number-badge{color:#1e293b;align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.gate-pass-number-badge svg{color:#3b82f6;font-size:18px}.gate-pass-meta{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.meta-item{color:#64748b;align-items:center;gap:4px;font-size:13px;display:flex}.meta-item svg{font-size:14px}.gate-pass-header-right{align-items:center;gap:12px;display:flex}.expand-btn{color:#64748b;cursor:pointer;background:#e2e8f0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .3s;display:flex}.expand-btn:hover{color:#1e293b;background:#cbd5e1}.expand-btn svg{font-size:20px}.gate-pass-body{background:#fff;padding:24px}.gate-pass-actions{border-bottom:2px solid #e2e8f0;justify-content:flex-end;margin-bottom:24px;padding-bottom:16px;display:flex}.edit-record-btn{color:#fff;cursor:pointer;background:#f59e0b;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s;display:inline-flex}.edit-record-btn:hover{background:#d97706;transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b66}.edit-record-btn svg{font-size:18px}.info-section{margin-bottom:24px}.info-section:last-child{margin-bottom:0}.info-section-title{color:#1e293b;border-bottom:2px solid #e2e8f0;margin:0 0 12px;padding-bottom:8px;font-size:14px;font-weight:700}.info-grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;display:grid}.info-card{background:#f8f9fa;border-radius:10px;align-items:center;gap:12px;padding:16px;transition:all .3s;display:flex}.info-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.info-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.info-icon svg{font-size:20px}.info-text{flex-direction:column;min-width:0;display:flex}.info-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:11px;font-weight:600}.info-value{color:#1e293b;word-break:break-word;font-size:14px;font-weight:600}.info-grid-4{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.info-item{background:#f8f9fa;border-radius:8px;justify-content:space-between;gap:12px;padding:10px 14px;display:flex}.no-details{text-align:center;background:#fff;border:2px dashed #e2e8f0;border-radius:12px;padding:60px 20px}.no-details-icon{color:#cbd5e1;margin-bottom:16px;font-size:48px}.no-details p{color:#64748b;margin:0 0 20px;font-size:15px}.add-first-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s;display:inline-flex}.add-first-btn:hover{background:#2563eb;transform:translateY(-2px)}.add-first-btn svg{font-size:18px}.loading-container,.error-container{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:60px 20px;display:flex}.error-container h3{color:#1e293b;margin:0;font-size:18px;font-weight:600}.error-container p{color:#64748b;margin:0;font-size:14px}.error-actions{gap:12px;margin-top:8px;display:flex}.retry-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 20px;font-size:14px;font-weight:500;transition:background .2s;display:inline-flex}.btn-secondary{color:#1e293b;cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;margin-top:16px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s}.employee-header .emp-photo-img{width:80px;height:80px}.personal-details-block{margin-bottom:32px}.personal-details-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.personal-details-header h3{color:#1e293b;margin:0 0 6px;font-size:20px;font-weight:700}.personal-details-sub{color:#64748b;max-width:640px;margin:0;font-size:14px}.btn-edit-register{color:#b45309;cursor:pointer;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;flex-shrink:0;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-edit-register:hover{background:#fef3c7;border-color:#f59e0b}.btn-edit-register svg{font-size:18px}.gate-pass-register-missing{background:#f8fafc}.register-missing-text{color:#475569;margin:0;font-size:14px;line-height:1.6}.personal-details-collapsed,.personal-details-expanded{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px 20px 16px}.personal-summary-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px 20px;margin-bottom:16px;display:grid}.personal-summary-item{flex-direction:column;gap:4px;display:flex}.personal-summary-label{color:#64748b;text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.personal-summary-value{color:#1e293b;word-break:break-word;font-size:14px;font-weight:500}.personal-summary-empty{color:#64748b;margin:0 0 16px;font-size:14px;line-height:1.5}.see-more-toggle{color:#2563eb;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin:0;padding:0;font-size:14px;font-weight:600;transition:color .2s;display:inline-flex}.see-more-toggle:hover{color:#1d4ed8;text-decoration:underline}.see-more-toggle svg{font-size:20px}.see-more-toggle.see-less{margin-top:8px}.personal-details-expanded .see-less{padding-top:4px}.add-gatepass-content{max-width:1200px;margin:0 auto;padding:24px 32px 40px}.back-btn:hover{color:#1e293b;background:#e2e8f0;transform:translateY(-2px)}.steps-progress{background:#fff;border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:32px;padding:24px;display:flex;box-shadow:0 2px 12px #0000000f}.step-wrapper{flex:1;align-items:center;display:flex}.step-item{flex-direction:column;align-items:center;gap:8px;display:flex}.step-circle{color:#94a3b8;background:#f1f5f9;border:3px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;transition:all .3s;display:flex}.step-item.active .step-circle{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-color:#3b82f6;transform:scale(1.1);box-shadow:0 4px 12px #3b82f64d}.step-item.completed .step-circle{color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border-color:#10b981}.step-label{color:#94a3b8;text-align:center;font-size:12px;font-weight:600}.step-item.active .step-label{color:#3b82f6}.step-item.completed .step-label{color:#10b981}.step-line{background:#e2e8f0;flex:1;height:3px;margin:0 8px;transition:all .3s}.form-container{background:#fff;border:1px solid #e2e8f0;border-radius:16px;min-height:500px;overflow:hidden;box-shadow:0 4px 20px #00000014}.error-banner{color:#dc2626;background:#fee2e2;border:1px solid #fecaca;border-radius:12px;align-items:center;gap:12px;margin:20px;padding:14px 20px;font-size:14px;font-weight:600;display:flex}.error-icon{font-size:20px}.form-step{padding:32px;animation:.3s fadeIn}.step-header{border-bottom:2px solid #e2e8f0;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:20px;display:flex}.step-icon{color:#3b82f6;background:#dbeafe;border-radius:12px;padding:12px;font-size:40px}.step-header h2{color:#1e293b;margin:0 0 4px;font-size:22px;font-weight:700}.step-header p{color:#64748b;margin:0;font-size:14px}.form-group{flex-direction:column;gap:8px;display:flex}.employee-search-group{grid-column:1/-1;position:relative}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-input{padding-left:48px!important}.employee-dropdown{z-index:1000;background:#fff;border:2px solid #e2e8f0;border-radius:10px;max-height:300px;margin-top:4px;animation:.2s dropdownSlide;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001f}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{cursor:pointer;border-bottom:1px solid #f1f5f9;padding:12px 16px;transition:all .2s}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:#f8fafc}.dropdown-item.loading,.dropdown-item.no-results{cursor:default;color:#64748b;text-align:center;font-size:14px}.dropdown-item.loading:hover,.dropdown-item.no-results:hover{background:#fff}.employee-id{color:#3b82f6;margin-bottom:2px;font-size:13px;font-weight:700}.employee-name{color:#1e293b;font-size:14px;font-weight:600}.readonly-input{cursor:not-allowed;color:#64748b;background:#f8fafc!important}.form-label{color:#475569;font-size:14px;font-weight:600}.form-input,.form-select{color:#1e293b;background:#fff;border:2px solid #e2e8f0;border-radius:10px;padding:12px 16px;font-family:inherit;font-size:14px;transition:all .3s}.form-input:hover,.form-select:hover{border-color:#cbd5e1}.form-input:focus,.form-select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 4px #3b82f61a}.form-input::placeholder{color:#94a3b8}.form-select{cursor:pointer}.review-section{flex-direction:column;gap:20px;display:flex}.review-card{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:20px}.review-card h3{color:#1e293b;border-bottom:2px solid #e2e8f0;margin:0 0 16px;padding-bottom:12px;font-size:16px;font-weight:700}.review-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;display:grid}.review-item{flex-direction:column;gap:4px;display:flex}.review-item .label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.review-item .value{color:#1e293b;font-size:14px;font-weight:600}.form-actions{background:#f8fafc;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.step-indicator{color:#64748b;font-size:14px;font-weight:600}.btn-back,.btn-next,.btn-submit{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s;display:flex}.btn-back{color:#64748b;background:#f1f5f9}.btn-back:hover{color:#1e293b;background:#e2e8f0;transform:translateY(-2px)}.btn-next{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);box-shadow:0 4px 12px #3b82f64d}.btn-next:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.btn-submit{color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%);box-shadow:0 4px 12px #10b9814d}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-back svg,.btn-next svg,.btn-submit svg{font-size:18px}.success-container{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:80px 20px;box-shadow:0 4px 20px #00000014}.success-icon{color:#10b981;background:linear-gradient(135deg,#d1fae5 0%,#a7f3d0 100%);border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto 24px;font-size:50px;animation:.5s scaleIn;display:flex;box-shadow:0 8px 24px #10b98133}@keyframes scaleIn{0%{opacity:0;transform:scale(0)rotate(-180deg)}to{opacity:1;transform:scale(1)rotate(0)}}.success-container h2{color:#1e293b;margin:0 0 8px;font-size:26px;font-weight:700}.success-container p{color:#64748b;font-size:15px}@media (width<=1024px){.steps-progress{padding:16px;overflow-x:auto}.step-label{font-size:11px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (width<=768px){.add-gatepass-content{padding:16px}.page-header h1{font-size:24px}.steps-progress{padding:12px}.step-circle{width:40px;height:40px;font-size:20px}.step-label{font-size:10px}.form-container{border-radius:12px}.form-step{padding:20px 16px}.step-header{flex-direction:column;align-items:flex-start}.form-grid{grid-template-columns:1fr;gap:16px}.review-grid{grid-template-columns:1fr}.form-actions{flex-wrap:wrap;gap:12px;padding:16px}.step-indicator{text-align:center;order:-1;width:100%}.btn-back,.btn-next,.btn-submit{flex:1;justify-content:center}}.employee-list-content{padding:32px 40px}.add-employee-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 12px #3b82f64d}.add-employee-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.add-employee-btn svg{font-size:20px}.filters-section{flex-wrap:wrap;gap:16px;margin-bottom:24px;display:flex}.filter-actions{gap:12px;display:flex}.refresh-btn{color:#3b82f6;cursor:pointer;background:#fff;border:2px solid #3b82f6;border-radius:10px;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:600;transition:all .3s;display:flex}.refresh-btn:hover{color:#fff;background:#3b82f6;transform:translateY(-2px)}.refresh-btn svg{font-size:18px}.search-box{flex:1;align-items:center;min-width:300px;display:flex;position:relative}.search-icon{color:#94a3b8;pointer-events:none;font-size:20px;position:absolute;left:16px}.search-box input{background:#fff;border:2px solid #e2e8f0;border-radius:10px;width:100%;padding:12px 16px 12px 48px;font-size:14px;transition:all .3s}.search-box input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 4px #3b82f61a}.trash-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:2px solid #e2e8f0;border-radius:10px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s}.trash-btn:hover{color:#1e293b;background:#e2e8f0}table{border-collapse:collapse;width:100%}thead{background:#f8f9fa}th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:16px;font-size:13px;font-weight:600}td{color:#1e293b;border-bottom:1px solid #f1f5f9;padding:16px;font-size:14px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#f8f9fa}.action-buttons{gap:8px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .3s;display:flex}.view-more-btn:hover{color:#fff;background:#3b82f6;transform:translateY(-2px)}.view-more-btn svg{font-size:16px}.edit-btn{color:#92400e;background:#fef3c7;width:36px;height:36px}.edit-btn:hover{color:#fff;background:#f59e0b;transform:translateY(-2px)}.delete-btn{color:#991b1b;background:#fee2e2;width:36px;height:36px}.delete-btn:hover{color:#fff;background:#ef4444;transform:translateY(-2px)}.edit-btn svg,.delete-btn svg{font-size:18px}.pagination-section{background:#fff;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.pagination-info{align-items:center;gap:20px;display:flex}.records-count{color:#64748b;font-size:13px}.pagination-controls{align-items:center;gap:12px;display:flex}.pagination-btn{color:#1e293b;cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .3s;display:flex}.pagination-btn:hover:not(:disabled){color:#3b82f6;border-color:#3b82f6}.pagination-btn svg{font-size:18px}.page-indicator{color:#1e293b;background:#f8f9fa;border-radius:8px;align-items:center;gap:4px;padding:8px 12px;font-weight:600;display:flex}.page-current{font-size:14px}.terminate-modal{max-width:560px}.terminate-header h2{color:#dc2626}.terminate-warning{background:#fef3c7;border:1px solid #fde68a;border-radius:10px;align-items:flex-start;gap:12px;margin-bottom:24px;padding:14px 16px;display:flex}.terminate-warning svg{color:#d97706;flex-shrink:0;margin-top:1px;font-size:22px}.terminate-warning p{color:#92400e;margin:0;font-size:14px;line-height:1.5}.terminate-grid{grid-template-columns:1fr 1fr}.terminate-grid .full-width{grid-column:1/-1}.terminate-grid textarea{resize:vertical;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px;transition:all .3s}.terminate-grid textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.terminate-grid textarea::placeholder{color:#94a3b8}.required{color:#ef4444}.btn-terminate{cursor:pointer;color:#fff;background:#ef4444;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s;display:flex}.btn-terminate:hover:not(:disabled){background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.btn-terminate:disabled{opacity:.6;cursor:not-allowed}.btn-terminate svg{font-size:18px}@media (width<=540px){.terminate-grid{grid-template-columns:1fr}}.file-upload-field{flex-direction:column;gap:8px;display:flex}.file-upload-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.required-star{color:#ef4444}.file-upload-dropzone{cursor:pointer;text-align:center;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:10px;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;transition:border-color .2s,background .2s;display:flex}.file-upload-dropzone:hover:not(.uploading){background:#eff6ff;border-color:#3b82f6}.file-upload-dropzone.uploading{cursor:default;background:#eff6ff;border-color:#93c5fd}.dropzone-icon{color:#94a3b8;font-size:36px;line-height:1}.dropzone-text{color:#475569;margin:0;font-size:14px;font-weight:600}.dropzone-hint{color:#94a3b8;margin:0;font-size:12px}.btn-upload-trigger{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:7px;align-items:center;gap:6px;margin-top:4px;padding:8px 18px;font-size:13px;font-weight:600;transition:background .2s;display:inline-flex}.btn-upload-trigger:hover{background:#2563eb}.upload-progress-wrapper{flex-direction:column;align-items:center;gap:10px;width:100%;display:flex}.upload-spinner{border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.upload-progress-text{color:#3b82f6;font-size:13px;font-weight:600}.upload-progress-bar{background:#e2e8f0;border-radius:3px;width:100%;max-width:200px;height:6px;overflow:hidden}.upload-progress-fill{background:#3b82f6;border-radius:3px;height:100%;transition:width .2s}.file-upload-preview{background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:10px;padding:14px;display:flex}.image-preview-wrapper,.pdf-preview-wrapper{align-items:center;gap:12px;display:flex}.image-preview-thumb{object-fit:cover;background:#e2e8f0;border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;width:64px;height:64px}.pdf-icon{color:#ef4444;flex-shrink:0;font-size:48px}.preview-info{flex-wrap:wrap;flex:1;align-items:center;gap:8px;min-width:0;display:flex}.icon-success{color:#10b981;flex-shrink:0;font-size:18px}.preview-filename{color:#1e293b;word-break:break-all;flex:1;min-width:0;font-size:13px;font-weight:500}.preview-link{color:#3b82f6;white-space:nowrap;align-items:center;gap:4px;font-size:12px;font-weight:600;text-decoration:none;display:inline-flex}.preview-link:hover{text-decoration:underline}.file-upload-actions{gap:8px;display:flex}.btn-change-file,.btn-remove-file{cursor:pointer;border:none;border-radius:7px;align-items:center;gap:5px;padding:7px 14px;font-size:12px;font-weight:600;transition:all .2s;display:inline-flex}.btn-change-file{color:#1d4ed8;background:#dbeafe}.btn-change-file:hover:not(:disabled){background:#bfdbfe}.btn-remove-file{color:#dc2626;background:#fee2e2}.btn-remove-file:hover:not(:disabled){background:#fecaca}.btn-change-file:disabled,.btn-remove-file:disabled{opacity:.5;cursor:not-allowed}.upload-error{color:#991b1b;background:#fee2e2;border-radius:7px;align-items:center;gap:6px;padding:8px 12px;font-size:13px;font-weight:500;display:flex}.upload-error svg{flex-shrink:0;font-size:16px}.add-employee-content{max-width:1200px;margin:0 auto;padding:24px 32px 40px}.multi-step-form{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:32px;box-shadow:0 1px 3px #0000001a}.steps-indicator{justify-content:space-between;align-items:flex-start;margin-bottom:40px;display:flex;position:relative}.step-item{flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.step-circle{color:#94a3b8;z-index:2;background:#f1f5f9;border:3px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:700;transition:all .3s;display:flex;position:relative}.step-circle.active{color:#fff;background:#3b82f6;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f633}.step-circle.completed{color:#fff;background:#10b981;border-color:#10b981}.step-label{color:#64748b;text-align:center;white-space:nowrap;margin-top:12px;font-size:12px;font-weight:600}.step-line{z-index:1;background:#e2e8f0;height:3px;transition:all .3s;position:absolute;top:24px;left:50%;right:-50%}.step-line.completed{background:#10b981}.step-item:last-child .step-line{display:none}.step-form{min-height:400px}.step-content{animation:.3s fadeIn}.step-content h2{color:#1e293b;margin:0 0 8px;font-size:24px;font-weight:700}.step-subtitle{color:#64748b;margin:0 0 24px;font-size:14px}.form-section{margin-bottom:32px}.form-section h3{color:#1e293b;border-bottom:2px solid #e2e8f0;margin:0 0 16px;padding-bottom:8px;font-size:16px;font-weight:700}.form-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:24px;display:grid}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}@media (width<=768px){.steps-indicator{padding-bottom:16px;overflow-x:auto}.step-label{font-size:10px}.step-circle{width:40px;height:40px;font-size:16px}.form-grid{grid-template-columns:1fr}}.preview-section{max-height:600px;padding-right:8px;overflow-y:auto}.preview-section::-webkit-scrollbar{width:6px}.preview-section::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.preview-section::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.preview-section::-webkit-scrollbar-thumb:hover{background:#94a3b8}.preview-card{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:20px;padding:24px}.preview-card h3{color:#1e293b;border-bottom:2px solid #e2e8f0;margin:0 0 16px;padding-bottom:12px;font-size:18px;font-weight:700}.preview-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;display:grid}.preview-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:4px;padding:12px;display:flex}.preview-item.full-width{grid-column:1/-1}.preview-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.preview-value{color:#1e293b;word-break:break-word;font-size:14px;font-weight:500}.preview-value:empty:before{content:"N/A";color:#94a3b8;font-style:italic}.preview-doc{align-items:center;gap:6px;display:flex}.doc-icon{flex-shrink:0;font-size:16px}.doc-img{color:#3b82f6}.doc-pdf{color:#ef4444}.preview-na{color:#94a3b8;font-size:13px;font-style:italic}.employee-form-content{max-width:1400px;margin:0 auto;padding:24px 32px 40px}.form-header{margin-bottom:24px}.back-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;align-items:center;gap:6px;margin-bottom:16px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .3s;display:inline-flex}.back-btn:hover{color:#1e293b;background:#e2e8f0}.back-btn svg{font-size:18px}.form-header h1{color:#1e293b;margin:0;font-size:28px;font-weight:700}.employee-form{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:32px;box-shadow:0 1px 3px #0000001a}.error-banner{color:#991b1b;background:#fee2e2;border-left:4px solid #ef4444;border-radius:8px;margin-bottom:24px;padding:16px 20px;font-size:14px;font-weight:500}.form-section{border-bottom:2px solid #e2e8f0;margin-bottom:32px;padding-bottom:32px}.form-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section h2{color:#1e293b;margin:0 0 20px;font-size:18px;font-weight:700}.form-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.form-group label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:13px;font-weight:600}.form-group input,.form-group select,.form-group textarea{color:#1e293b;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:12px 16px;font-family:inherit;font-size:14px;transition:all .3s}.form-group input:disabled{cursor:not-allowed;color:#94a3b8;background:#f1f5f9}.btn-secondary{color:#1e293b;cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s}.btn-secondary:hover{background:#e2e8f0}.btn-primary{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s;display:inline-flex}.btn-primary:hover:not(:disabled){background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary svg{font-size:18px}.loading-container{text-align:center;padding:60px 20px}.loading-container .spinner{border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:40px;height:40px;margin:0 auto 16px;animation:1s linear infinite spin}.doc-section-hint{color:#64748b;margin:-12px 0 4px;font-size:13px}.trash-content{padding:32px 40px}.page-header{margin-bottom:32px}.badge{color:#64748b;background:#f1f5f9;border-radius:12px;padding:4px 12px;font-size:12px;font-weight:600}.loading-state,.empty-state{text-align:center;color:#64748b;flex-direction:column;align-items:center;gap:8px;padding:60px 20px;display:flex}.empty-state-icon.error-icon{color:#ef4444}.empty-state p{color:#64748b;margin:0;font-size:14px}.retry-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:8px;align-items:center;gap:6px;margin-top:8px;padding:8px 20px;font-size:14px;font-weight:500;transition:background .2s;display:inline-flex}.retry-btn:hover{background:#2563eb}.spinner{border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:40px;height:40px;margin:0 auto 16px;animation:1s linear infinite spin}.remark-cell{white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden}.trash-filters.filters-section{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:24px;display:flex}.trash-filters .search-box{flex:1;align-items:center;min-width:280px;display:flex;position:relative}.trash-filters .search-icon{color:#94a3b8;pointer-events:none;font-size:20px;position:absolute;left:16px}.trash-filters .search-box input{background:#fff;border:2px solid #e2e8f0;border-radius:10px;width:100%;padding:12px 16px 12px 48px;font-size:14px}.trash-filters .search-box input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 4px #3b82f61a}.trash-filters .refresh-btn{color:#3b82f6;cursor:pointer;background:#fff;border:2px solid #3b82f6;border-radius:10px;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:600;display:flex}.trash-filters .refresh-btn:hover{color:#fff;background:#3b82f6}.table-section table{border-collapse:collapse;width:100%}.table-section th{text-align:left;color:#64748b;text-transform:uppercase;background:#f8f9fa;padding:16px;font-size:13px;font-weight:600}.table-section td{color:#1e293b;border-bottom:1px solid #f1f5f9;padding:16px;font-size:14px}.employee-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:600;display:flex}.emp-id{color:#3b82f6;font-family:monospace;font-size:13px;font-weight:600}.action-btn.view-btn{color:#1e40af;cursor:pointer;background:#dbeafe;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-flex}.pagination-section{border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.pagination-btn{cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-weight:600;display:flex}.page-indicator{background:#f8f9fa;border-radius:8px;align-items:center;gap:4px;padding:8px 12px;font-weight:600;display:flex}.page-total{color:#64748b;font-size:13px}.medical-reports-content{padding:32px 40px}.page-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.page-header h1{color:#1e293b;margin:0 0 8px;font-size:32px;font-weight:700}.page-subtitle{color:#64748b;margin:0;font-size:14px}.add-medical-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 12px #10b9814d}.add-medical-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.add-medical-btn svg{font-size:20px}.add-form-section{margin-bottom:32px}.form-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:32px;box-shadow:0 4px 24px #00000014}.form-card h3{color:#1e293b;margin:0 0 24px;font-size:24px;font-weight:600}.form-row{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}.form-group{flex-direction:column;display:flex}.form-group.full-width{grid-column:1/-1}.form-group label{color:#374151;margin-bottom:8px;font-size:14px;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e5e7eb;border-radius:8px;padding:12px 16px;font-size:14px;transition:all .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#10b981;outline:none;box-shadow:0 0 0 3px #10b9811a}.form-group textarea{resize:vertical;min-height:80px}.form-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:24px;display:flex}.cancel-btn{color:#374151;cursor:pointer;background:#f3f4f6;border:2px solid #e5e7eb;border-radius:8px;padding:12px 24px;font-weight:600;transition:all .3s}.cancel-btn:hover{background:#e5e7eb;border-color:#d1d5db}.submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 12px #10b9814d}.submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #10b98166}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.table-section{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;box-shadow:0 4px 24px #00000014}.table-toolbar{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:16px 20px}.search-box{background:#fff;border:1px solid #d1d5db;border-radius:10px;align-items:center;gap:8px;max-width:420px;padding:10px 12px;display:flex}.search-box svg{color:#64748b;font-size:18px}.search-box input{color:#1e293b;border:none;outline:none;width:100%;font-size:14px}.table-container{overflow-x:auto}.table-container table{border-collapse:collapse;width:100%}.table-container thead{background:#f8fafc}.table-container th{text-align:left;color:#374151;border-bottom:2px solid #e2e8f0;padding:16px 20px;font-size:14px;font-weight:600}.table-container td{color:#374151;border-bottom:1px solid #f1f5f9;padding:16px 20px;font-size:14px}.table-container tbody tr:hover{background:#f8fafc}.pagination-bar{background:#f8fafc;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.pagination-bar p{color:#475569;margin:0;font-size:13px}.pagination-actions{align-items:center;gap:10px;display:flex}.pagination-btn{color:#334155;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.pagination-btn:disabled{opacity:.45;cursor:not-allowed}.page-indicator{color:#334155;font-size:13px;font-weight:600}.employee-cell{align-items:center;gap:12px;display:flex}.employee-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:600;display:flex}.emp-id{color:#2563eb;background:#eff6ff;border-radius:6px;padding:4px 8px;font-size:12px;font-weight:600}.status-badge{text-transform:uppercase;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.status-badge.fit{color:#166534;background:#dcfce7}.status-badge.unfit{color:#dc2626;background:#fef2f2}.status-badge.fit-with-monitoring{color:#92400e;background:#fef3c7}.status-badge.under-review{color:#3730a3;background:#e0e7ff}.action-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:600;transition:all .3s;display:flex}.view-more-btn{color:#2563eb;background:#eff6ff}.view-more-btn:hover{background:#dbeafe;transform:translateY(-1px)}.action-btn-group{gap:8px;display:flex}.add-more-btn{color:#059669;background:#ecfdf5}.add-more-btn:hover{background:#d1fae5;transform:translateY(-1px)}.loading-state,.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:80px 40px;display:flex}.loading-state .spinner{border:4px solid #e5e7eb;border-top-color:#10b981;border-radius:50%;width:40px;height:40px;margin-bottom:16px;animation:1s linear infinite spin}.loading-state p,.empty-state p{color:#6b7280;margin:8px 0 0}.empty-state-icon{color:#d1d5db;margin-bottom:16px;font-size:64px}.empty-state h3{color:#374151;margin:0 0 8px;font-size:20px;font-weight:600}.error-icon{color:#ef4444}.retry-btn{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:8px;align-items:center;gap:8px;margin-top:16px;padding:10px 20px;font-weight:600;transition:all .3s;display:flex}.retry-btn:hover{background:#059669;transform:translateY(-1px)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #00000026}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.modal-header h3{color:#1e293b;margin:0;font-size:24px;font-weight:600}.close-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:32px;transition:all .3s;display:flex}.close-btn:hover{color:#374151;background:#f3f4f6}.modal-body{padding:32px}.employee-info{background:#f8fafc;border-radius:12px;margin-bottom:24px;padding:20px}.info-row{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.info-row:last-child{margin-bottom:0}.info-row .label{color:#374151;font-weight:600}.info-row .value{color:#1e293b;font-weight:500}.medical-records-list h4{color:#1e293b;margin:0 0 16px;font-size:20px;font-weight:600}.modal-actions{justify-content:flex-end;margin-bottom:16px;display:flex}.medical-record-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:16px;padding:20px}.medical-record-card:last-child{margin-bottom:0}.record-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.record-header h5{color:#1e293b;margin:0;font-size:18px;font-weight:600}.record-details{margin-bottom:16px}.detail-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.detail-item{flex-direction:column;gap:4px;display:flex}.detail-item.full-width{grid-column:1/-1}.detail-item .label{color:#374151;font-size:14px;font-weight:600}.detail-item .value{color:#1e293b;background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:8px 12px;font-size:14px}.record-footer{border-top:1px solid #e5e7eb;padding-top:12px}.record-footer small{color:#6b7280;font-size:12px}*{box-sizing:border-box;margin:0;padding:0}#root{width:100%;min-height:100vh}
