:root{
  --bg:#f5f7fb;--panel:#fff;--text:#0f172a;--muted:#64748b;--line:#e5e7eb;--primary:#2563eb;--primary2:#7c3aed;--success:#16a34a;--danger:#dc2626;--warning:#d97706;--dark:#111827;--shadow:0 18px 40px rgba(15,23,42,.08);--radius:18px;
}
*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}button,input,select,textarea{font:inherit}.muted{color:var(--muted)}.small{font-size:12px}.full{width:100%}.text-right{text-align:right}.nowrap{white-space:nowrap}
.auth-body{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top left,#dbeafe,transparent 30%),radial-gradient(circle at bottom right,#ede9fe,transparent 28%),#f8fafc;padding:24px}.auth-card{width:100%;max-width:440px;background:rgba(255,255,255,.88);backdrop-filter:blur(20px);padding:34px;border-radius:26px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.6)}.auth-card.wide{max-width:620px}.auth-logo{height:58px;margin-bottom:16px}.auth-card h1{margin:0 0 8px;font-size:28px}.auth-card p{line-height:1.6}.auth-links{display:flex;gap:14px;margin-top:18px}.auth-links a{color:var(--primary);font-weight:700}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}.field label{font-weight:700;font-size:13px}.field input,.field select,.field textarea{border:1px solid var(--line);border-radius:12px;padding:12px 13px;background:#fff;outline:none;transition:.2s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,.1)}textarea{min-height:110px;resize:vertical}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:12px;padding:11px 15px;background:#eef2ff;color:#1e293b;font-weight:800;cursor:pointer;transition:.2s}.btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(15,23,42,.1)}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:white}.btn.success{background:#dcfce7;color:#166534}.btn.danger{background:#fee2e2;color:#991b1b}.btn.warning{background:#fef3c7;color:#92400e}.btn.dark{background:#111827;color:#fff}.btn.ghost{background:transparent;border:1px solid var(--line)}.btn.sm{padding:8px 11px;border-radius:10px;font-size:12px}
.alert{padding:13px 15px;border-radius:14px;margin:12px 0;font-weight:700}.alert.success{background:#dcfce7;color:#166534}.alert.danger{background:#fee2e2;color:#991b1b}.alert.info{background:#dbeafe;color:#1e40af}.alert.warning{background:#fef3c7;color:#92400e}
.layout{display:flex;min-height:100vh}.sidebar{width:286px;background:#0f172a;color:#cbd5e1;padding:22px 18px;position:fixed;inset:0 auto 0 0;overflow:auto}.brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.brand img{height:50px;background:white;border-radius:14px;padding:4px}.brand strong{color:white;display:block;font-size:16px}.brand span{font-size:12px;color:#94a3b8}.nav{display:flex;flex-direction:column;gap:7px}.nav a{display:flex;align-items:center;gap:11px;padding:12px 13px;border-radius:14px;color:#cbd5e1;font-weight:700}.nav a:hover,.nav a.active{background:rgba(255,255,255,.1);color:#fff}.main{margin-left:286px;width:calc(100% - 286px);padding:22px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:14px;background:rgba(255,255,255,.86);backdrop-filter:blur(16px);border:1px solid rgba(226,232,240,.8);border-radius:22px;padding:16px 18px;box-shadow:0 12px 30px rgba(15,23,42,.05);position:sticky;top:14px;z-index:10}.topbar h1{font-size:24px;margin:0}.topbar-actions{display:flex;align-items:center;gap:10px}.avatar{height:42px;width:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary2));display:grid;place-items:center;color:white;font-weight:900}.content{padding:22px 0}.grid{display:grid;gap:18px}.grid.cards{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:0 12px 28px rgba(15,23,42,.05)}.stat{position:relative;overflow:hidden}.stat:before{content:"";position:absolute;right:-30px;top:-35px;width:120px;height:120px;background:linear-gradient(135deg,rgba(37,99,235,.18),rgba(124,58,237,.18));border-radius:50%}.stat .icon{height:42px;width:42px;border-radius:14px;display:grid;place-items:center;background:#eff6ff;font-size:20px}.stat h3{font-size:13px;color:var(--muted);margin:14px 0 5px}.stat .num{font-size:30px;font-weight:900}.hero-card{background:linear-gradient(135deg,#0f172a,#1d4ed8 55%,#7c3aed);color:white;border:0;overflow:hidden;position:relative}.hero-card:after{content:"";position:absolute;right:-60px;bottom:-80px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.12)}.hero-card h2{font-size:28px;margin:0 0 8px}.hero-card p{max-width:720px;color:#dbeafe}.two-col{grid-template-columns:1.35fr .65fr}.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}.table-wrap{overflow:auto;border-radius:16px;border:1px solid var(--line)}table{width:100%;border-collapse:collapse;background:white}th,td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#64748b;background:#f8fafc}tr:last-child td{border-bottom:0}.badge{display:inline-flex;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900}.badge-present,.badge-approved,.badge-paid,.badge-open,.badge-published{background:#dcfce7;color:#166534}.badge-late,.badge-pending,.badge-scheduled,.badge-draft{background:#fef3c7;color:#92400e}.badge-absent,.badge-rejected,.badge-unpaid,.badge-closed,.badge-failed{background:#fee2e2;color:#991b1b}.badge-wfh,.badge-sick,.badge-half_day,.badge-manual,.badge-new{background:#dbeafe;color:#1e40af}.badge-selected,.badge-hired{background:#ede9fe;color:#5b21b6}.kpi-bars{display:flex;flex-direction:column;gap:12px}.bar-row{display:grid;grid-template-columns:140px 1fr 48px;gap:10px;align-items:center}.bar{height:12px;border-radius:999px;background:#e5e7eb;overflow:hidden}.bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--primary2))}.quick-actions{display:flex;flex-wrap:wrap;gap:10px}.footer-note{text-align:center;color:#94a3b8;padding:20px}.filters{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.filters .field{margin:0;min-width:180px}.print-area{background:#fff;border-radius:18px;padding:34px;line-height:1.75;border:1px solid var(--line)}
.employee-shell{max-width:1120px;margin:0 auto;padding:24px}.employee-header{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:24px;padding:16px 18px;box-shadow:var(--shadow);margin-bottom:20px}.employee-header img{height:50px}.time-card{background:linear-gradient(135deg,#111827,#2563eb);color:#fff;border:0}.time-card .clock{font-size:40px;font-weight:900;margin:8px 0}.attendance-buttons{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}.attendance-buttons .btn{min-width:150px}.profile-pill{background:#f1f5f9;border-radius:999px;padding:8px 12px;font-weight:800}
@media(max-width:1180px){.grid.cards{grid-template-columns:repeat(2,minmax(0,1fr))}.two-col,.three-col{grid-template-columns:1fr}.sidebar{width:245px}.main{margin-left:245px;width:calc(100% - 245px)}}
@media(max-width:860px){.layout{display:block}.sidebar{position:relative;width:100%;height:auto}.main{margin-left:0;width:100%;padding:14px}.topbar{position:relative;top:0;align-items:flex-start;flex-direction:column}.grid.cards{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.employee-header{flex-direction:column;align-items:flex-start;gap:12px}.bar-row{grid-template-columns:1fr}.auth-card{padding:24px}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}}
@media print{.sidebar,.topbar,.no-print,.btn{display:none!important}.main{margin:0;width:100%;padding:0}.card,.print-area{box-shadow:none;border:0}.content{padding:0}body{background:white}}
