:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.home-page{width:100vw;display:block;min-height:100vh;padding:0;padding-left:5vw;padding-right:10vw;margin:0;background:linear-gradient(135deg,#f8fafc,#e2e8f0);box-sizing:border-box}.home-container{width:100%;max-width:100%;margin:0;padding:60px;background:#fff;border-radius:0;border:none;box-shadow:none;position:relative;min-height:100vh}.home-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#1d4ed8,#1e40af);border-radius:0}.home-title{text-align:center;color:#1e293b;margin-bottom:50px;font-size:2.5rem;font-weight:700;letter-spacing:-.025em}.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;margin-top:40px}.home-btn{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:40px 30px;text-align:center;cursor:pointer;transition:all .3s ease;text-decoration:none;color:inherit;position:relative;overflow:hidden}.home-btn:hover{transform:translateY(-5px);border-color:#3b82f6;box-shadow:0 10px 25px #3b82f626;background:#f8fafc}.entry-btn:hover{border-color:#059669;box-shadow:0 10px 25px #05966926}.reports-btn:hover{border-color:#dc2626;box-shadow:0 10px 25px #dc262626}.reporting-btn:hover{border-color:#7c3aed;box-shadow:0 10px 25px #7c3aed26}.home-icon{font-size:3rem;margin-bottom:20px;display:block}.home-btn h3{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:15px}.home-btn p{color:#64748b;font-size:1rem;line-height:1.5;margin-bottom:0}@media(max-width:768px){.home-container{padding:40px 30px;max-width:95%}.home-title{font-size:2rem}.home-grid{grid-template-columns:1fr;gap:20px}.home-btn{padding:30px 20px}}body{background:linear-gradient(135deg,#f8fafc,#e2e8f0);min-height:100vh;margin:0;padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;display:flex;align-items:center;justify-content:center}.violation-page{width:100%;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.violation-container{width:100%;max-width:800px;margin:20px auto;padding:40px;background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;position:relative}.violation-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#1d4ed8,#1e40af);border-radius:12px 12px 0 0}.violation-title{text-align:center;color:#1e293b;margin-bottom:20px;font-size:1.8rem;font-weight:700;letter-spacing:-.025em}.violation-form{display:flex;flex-direction:column;gap:16px;align-items:stretch}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-weight:600;color:#374151;font-size:.9rem;margin-bottom:2px}.form-control{padding:12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:.9rem;background:#fff;color:#1f2937;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.form-control.violation-type-select{padding:10px 14px;font-size:.85rem;max-width:300px}.form-control[type=date]{max-width:200px;padding:12px}.form-control::placeholder{color:#9ca3af}.form-control:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-control:hover{border-color:#9ca3af}.form-control:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.radio-group{display:flex;flex-direction:column;gap:8px;margin-top:6px}.radio-option{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:all .2s ease}.radio-option:hover{background:#f1f5f9;border-color:#cbd5e1}.radio-option input[type=radio]:checked+label{color:#1e40af;font-weight:600}.radio-option:has(input[type=radio]:checked){background:#eff6ff;border-color:#3b82f6}.radio-option input[type=radio]{margin:0;width:18px;height:18px;accent-color:#3b82f6}.radio-option label{margin:0;cursor:pointer;font-size:1rem;color:#374151;flex:1}.submit-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;padding:12px 24px;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:15px;box-shadow:0 2px 4px #3b82f633;max-width:200px;align-self:flex-start}.submit-btn:hover{background:linear-gradient(135deg,#2563eb,#1e40af);transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.submit-btn:active{transform:translateY(0)}.back-btn{background:#dc2626!important;margin-top:15px!important;border:2px solid #dc2626!important}.back-btn:hover{background:#b91c1c!important;transform:translateY(-1px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.back-btn-top{position:absolute;top:20px;left:20px;background:#6b7280;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;z-index:10}.back-btn-top:hover{background:#4b5563;transform:translateY(-1px)}.search-dropdown{position:relative}.dropdown-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #d1d5db;border-top:none;border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 6px -1px #0000001a;width:100%}.dropdown-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:background-color .2s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;box-sizing:border-box}.dropdown-item:hover{background-color:#f8fafc}.dropdown-item:last-child{border-bottom:none}.search-dropdown{position:relative;width:100%}.search-dropdown input{width:100%;box-sizing:border-box}.search-dropdown input:focus+.dropdown-list{border-color:#3b82f6}.employee-id{font-weight:600;color:#3b82f6}.employee-name{color:#374151}@media(max-width:768px){body{padding:15px}.violation-container{margin:10px auto;padding:40px 30px;max-width:95%}.violation-title{font-size:2rem}.form-control{padding:14px 16px;font-size:1rem}.submit-btn{padding:14px 24px;font-size:1rem}.radio-option{padding:14px 16px}}.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;margin-top:40px}.report-btn{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:40px 30px;text-align:center;cursor:pointer;transition:all .3s ease;text-decoration:none;color:inherit;position:relative;overflow:hidden}.report-btn:hover{transform:translateY(-5px);border-color:#3b82f6;box-shadow:0 10px 25px #3b82f626;background:#f8fafc}.attendance-btn:hover{border-color:#dc2626;box-shadow:0 10px 25px #dc262626}.performance-btn:hover{border-color:#059669;box-shadow:0 10px 25px #05966926}.report-icon{font-size:3rem;margin-bottom:20px;display:block}.report-btn h3{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:15px}.report-btn p{color:#64748b;font-size:1rem;line-height:1.5;margin-bottom:0}@media(max-width:768px){.reports-grid{grid-template-columns:1fr;gap:20px}.report-btn{padding:30px 20px}}body{margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#dcf0fa}.violation-page{width:100vw;min-height:100vh;padding:20px;margin:0;box-sizing:border-box}.violation-container{width:100%;max-width:1200px;margin:0 auto;padding:20px;background:#b9e2f5;border-radius:8px;box-shadow:0 2px 8px #6b728026;position:relative;min-height:calc(100vh - 40px)}.table-container{overflow-x:auto;margin-top:20px;border-radius:12px;border:1px solid #e2e8f0;width:100%;height:calc(100vh - 300px);overflow-y:auto;background:#fff;box-shadow:0 4px 6px #0000000d}.violations-table{width:100%;border-collapse:collapse;background:#fff;min-width:1000px}.violations-table th{background:#f8fafc;color:#374151;font-weight:600;padding:20px 16px;text-align:left;border-bottom:2px solid #e2e8f0;font-size:.9rem;position:sticky;top:0;z-index:10}.violations-table td{padding:18px 16px;border-bottom:1px solid #f1f5f9;font-size:.9rem;background:#fff}.violations-table tr:hover{background:#f8fafc;transform:translateY(-1px);transition:all .2s ease}.employee-info{display:flex;flex-direction:column;gap:4px}.employee-id{font-weight:600;color:#3b82f6;font-size:.8rem}.employee-name{color:#374151;font-size:.85rem}.violation-type{padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:500;text-transform:capitalize}.violation-type.late,.violation-type.leave-early,.violation-type.call-out,.violation-type.no-show{background:#fef2f2;color:#dc2626}.violation-type.verbal,.violation-type.coaching,.violation-type.written,.violation-type.written-terminable{background:#f0fdf4;color:#059669}.details-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading,.error,.no-data{text-align:center;padding:40px;color:#64748b;font-size:1.1rem}.error{color:#dc2626}.summary{margin-top:30px;padding:25px;background:#f8fafc;border-radius:12px;text-align:center;border:1px solid #e2e8f0;box-shadow:0 2px 4px #0000000d}.summary p{margin:0;color:#374151;font-size:1rem}.actions-cell{display:flex;gap:8px;justify-content:center}.action-btn{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.edit-btn:hover{background:#eff6ff}.delete-btn:hover{background:#fef2f2}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:30px;border-radius:8px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto}.modal-content h2{margin-top:0;margin-bottom:20px;color:#374151}.modal-content .form-group{margin-bottom:15px}.modal-content label{display:block;margin-bottom:5px;font-weight:600;color:#374151}.modal-content input,.modal-content textarea{width:100%;padding:8px 12px;border:2px solid #d1d5db;border-radius:4px;font-size:1rem;box-sizing:border-box}.modal-content input:focus,.modal-content textarea:focus{outline:none;border-color:#3b82f6}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.btn-primary{background:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-weight:600}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#6b7280;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-weight:600}.btn-secondary:hover{background:#4b5563}@media(max-width:768px){.violations-table{font-size:.8rem}.violations-table th,.violations-table td{padding:12px 8px}.details-cell{max-width:150px}}.back-btn-external{background:#3b82f6;color:#fff;border:none;padding:12px 20px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;margin-bottom:20px;margin-left:20px;margin-top:10px;display:flex;align-items:center;gap:8px;transition:all .3s ease;box-shadow:0 2px 4px #3b82f633;position:absolute;top:10px;left:10px}.back-btn-external:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.header-with-filter{display:flex;justify-content:space-between;align-items:center;width:100%}.column-filter-btn{background:none;border:none;cursor:pointer;font-size:.8rem;padding:2px 4px;border-radius:3px;opacity:.6;transition:all .2s ease}.column-filter-btn:hover{background:#e2e8f0;opacity:1}.column-filter{margin-top:8px;animation:slideDown .2s ease}.column-filter-input{width:100%;padding:6px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:.8rem;background:#fff}.column-filter-input:focus{outline:none;border-color:#3b82f6}.column-filter-input::placeholder{color:#9ca3af;font-size:.75rem}.date-range-filter{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.date-input{flex:1;min-width:100px}.date-separator{font-size:.75rem;color:#6b7280;font-weight:500}.filter-with-clear{position:relative;display:flex;align-items:center}.clear-filter-btn{position:absolute;right:6px;background:none;border:none;cursor:pointer;color:#9ca3af;font-size:.8rem;padding:2px;border-radius:2px;transition:all .2s ease}.clear-filter-btn:hover{color:#ef4444;background:#fef2f2}.date-range-filter .clear-filter-btn{position:static;margin-left:8px}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.header-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.clear-all-filters-btn{background:#ef4444;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;box-shadow:0 2px 4px #ef444433}.clear-all-filters-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 8px #ef44444d}.filter-group{display:flex;gap:15px;flex-wrap:wrap}.filter-input{flex:1;min-width:200px;padding:10px 12px;border:2px solid #d1d5db;border-radius:6px;font-size:.9rem;background:#fff}.filter-input:focus{outline:none;border-color:#3b82f6}.filter-input::placeholder{color:#9ca3af}@media(max-width:768px){.violation-page{padding:10px}.violation-container{padding:20px;border-radius:12px}.filter-group{flex-direction:column}.filter-input{min-width:100%}.header-section{flex-direction:column;gap:15px;align-items:stretch}.clear-all-filters-btn{align-self:center;width:auto}.column-filter-btn{font-size:.7rem}.column-filter-input{font-size:.75rem}.date-range-filter{flex-direction:column;gap:4px}.date-input{min-width:100%}.date-separator{align-self:center}}.violation-reporting-container{padding:20px}.filters-section{background:#f8fafc;padding:20px;border-radius:8px;margin-bottom:20px;border:1px solid #e2e8f0}.points-high{color:#dc2626!important;font-weight:700}.points-medium{color:#f59e0b!important;font-weight:700}.points-low{color:#059669!important;font-weight:700}.summary-stats{background:#f8fafc;padding:20px;border-radius:8px;margin-top:20px;border:1px solid #e2e8f0;text-align:center}@media(max-width:768px){.violation-reporting-container{padding:10px}.filters-section{padding:15px}}
