:root{--primary: #4f46e5;--primary-hover: #4338ca;--secondary: #ec4899;--accent: #8b5cf6;--background: #f8fafc;--surface: #ffffff;--text-main: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--info: #3b82f6;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--background);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{color:var(--text-main);font-weight:700;margin-bottom:.5em}a{color:var(--primary);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-hover)}button{cursor:pointer;font-family:inherit}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1rem}.text-muted{color:var(--text-muted)}.text-white{color:#fff}.text-white-70{color:#ffffffb3}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.font-bold{font-weight:700}.font-medium{font-weight:500}.text-sm{font-size:.875rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-4xl{font-size:2.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.p-0{padding:0}.p-6{padding:1.5rem}.p-8{padding:2rem}.w-full{width:100%}.h-full{height:100%}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.grid-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.col-span-2{grid-column:span 2}@media(max-width:768px){.col-span-2{grid-column:span 1}}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem;border:1px solid var(--border);transition:transform .2s,box-shadow .2s;overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.bg-accent-gradient{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%)}.bg-success-light{background:#dcfce7}.text-success-dark{color:#166534}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;transition:all .2s;border:none}.btn-lg{padding:1rem 2rem;font-size:1.125rem}.btn-sm{padding:.375rem .75rem;font-size:.875rem}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 6px -1px #4f46e533}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 8px -1px #4f46e54d}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-main)}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:#4f46e50d}.btn-white{background:#fff;color:var(--primary)}.btn-white:hover{background:#f8fafc}.btn-icon{background:none;border:none;font-size:1.25rem;color:var(--text-muted);cursor:pointer;padding:.25rem;transition:color .2s}.btn-icon:hover{color:var(--text-main)}.badge{padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-success{background:#22c55e1a;color:var(--success)}.badge-info{background:#3b82f61a;color:var(--info)}.badge-warning{background:#f59e0b1a;color:var(--warning)}.badge-danger{background:#ef44441a;color:var(--danger)}.badge-pending{background:#f59e0b1a;color:var(--warning)}.badge-active,.badge-approved,.badge-present{background:#22c55e1a;color:var(--success)}.badge-rejected,.badge-absent{background:#ef44441a;color:var(--danger)}.badge-late{background:#eab3081a;color:#ca8a04}.badge-white{background:#fff3;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;padding:1rem;border-bottom:1px solid var(--border);color:var(--text-muted);font-size:.875rem;font-weight:600}td{padding:1rem;border-bottom:1px solid var(--border);vertical-align:middle}.hover-row:hover td{background:#f8fafc80}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500}.form-control{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:.95rem}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.full-width{grid-column:span 2}.progress-bar{height:.5rem;background:var(--border);border-radius:1rem;overflow:hidden}.progress-value{height:100%;background:var(--primary);border-radius:1rem;transition:width .3s ease}.avatar-sm{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;color:var(--primary)}.bg-primary-light{background:#4f46e51a}.fade-in{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;padding:2rem;border-radius:1rem;width:100%;max-width:600px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid var(--border)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
