.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{display:flex;flex-direction:column;padding:1.25rem;border-radius:0;border-top:none;border-bottom:none;border-left:none}.sidebar-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}.brand-icon{font-size:1.75rem}.sidebar-brand small{display:block;color:var(--text-muted);font-size:.75rem}.sidebar-nav{display:flex;flex-direction:column;gap:.35rem;flex:1}.nav-link{padding:.65rem .85rem;border-radius:var(--radius);color:var(--text-muted);font-weight:500;transition:background .15s,color .15s}.nav-link:hover{background:var(--surface-hover);color:var(--text)}.nav-link.active{background:#3b82f626;color:#93c5fd}.sidebar-user{margin-top:auto;padding-top:1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.35rem}.sidebar-user>div{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.sidebar-user small{color:var(--text-muted);font-size:.8rem}.logout-btn{margin-top:.5rem;width:100%}.main-content{padding:2rem;overflow-x:hidden}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-header h1{font-size:1.5rem;margin-bottom:.25rem}.page-header p{color:var(--text-muted);font-size:.95rem}.page-actions{display:flex;gap:.75rem;flex-wrap:wrap}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{padding:1.25rem}.stat-card span{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:.35rem}.stat-card strong{font-size:1.75rem}.filters-bar{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem;padding:1rem}.filters-bar input,.filters-bar select{padding:.55rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);min-width:140px}@media (max-width: 768px){.layout{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--border)}.main-content{padding:1rem}}.login-page{min-height:100vh;display:grid;place-items:center;padding:1.5rem;background:radial-gradient(circle at top right,rgba(59,130,246,.15),transparent 40%),var(--bg)}.login-card{width:min(420px,100%);padding:2rem}.login-header{text-align:center;margin-bottom:1.5rem}.login-icon{font-size:2.5rem;display:block;margin-bottom:.5rem}.login-header h1{font-size:1.5rem;margin-bottom:.35rem}.login-header p{color:var(--text-muted);font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-btn{width:100%;margin-top:.5rem;padding:.75rem}.login-hint{margin-top:1.25rem;text-align:center;font-size:.8rem;color:var(--text-muted)}.login-hint code{background:var(--bg);padding:.15rem .35rem;border-radius:4px;font-size:.75rem}.login-form .alert{margin-bottom:.25rem}:root{--bg: #0f1419;--surface: #1a2332;--surface-hover: #243044;--border: #2d3a4f;--text: #e7ecf3;--text-muted: #8b9cb3;--primary: #3b82f6;--primary-hover: #2563eb;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--radius: 10px;--shadow: 0 4px 24px rgba(0, 0, 0, .25);font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;color:var(--text);background:var(--bg)}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;background:var(--bg)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.page-loading{min-height:100vh;display:grid;place-items:center;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.1rem;border:none;border-radius:var(--radius);cursor:pointer;font-weight:600;transition:background .15s,opacity .15s}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--surface-hover);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:.35rem .75rem;font-size:.875rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.875rem;color:var(--text-muted);font-weight:500}.form-group input,.form-group select,.form-group textarea{padding:.65rem .85rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:2px solid var(--primary);outline-offset:1px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.alert{padding:.75rem 1rem;border-radius:var(--radius);font-size:.9rem}.alert-error{background:#ef444426;border:1px solid rgba(239,68,68,.4);color:#fca5a5}.alert-success{background:#22c55e26;border:1px solid rgba(34,197,94,.4);color:#86efac}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}th{font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:#00000026}tr:hover td{background:#ffffff05}.badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.badge-present{background:#22c55e33;color:#86efac}.badge-absent{background:#ef444433;color:#fca5a5}.badge-late{background:#f59e0b33;color:#fcd34d}.badge-half_day{background:#3b82f633;color:#93c5fd}.badge-leave{background:#a855f733;color:#d8b4fe}.badge-manager{background:#3b82f633;color:#93c5fd}.badge-employee{background:#6b728033;color:#d1d5db}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;padding:1rem;z-index:100}.modal{width:min(520px,100%);max-height:90vh;overflow-y:auto;padding:1.5rem}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.modal-header h2{font-size:1.15rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.empty-state{padding:2.5rem;text-align:center;color:var(--text-muted)}
