:root{--bg:#f4f7ff;--bg-soft:#eef3ff;--surface:#ffffff;--text:#0f172a;--muted:#64748b;--primary:#0f2cff;--primary-2:#2f57ff;--success:#16a34a;--warning:#f59e0b;--danger:#dc2626;--border:#e2e8f0;--shadow:0 10px 30px rgba(15,23,42,.08);--radius:14px}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:linear-gradient(180deg,#f8faff 0,#f3f7ff)}a{color:var(--primary)}h1,h2,h3,h4,p{margin:0}input,select,textarea,button{font:inherit}input,select,textarea{width:100%;border:1px solid var(--border);background:#fff;color:var(--text);border-radius:10px;padding:10px 12px;outline:none}input:focus,select:focus,textarea:focus{border-color:#9db0ff;box-shadow:0 0 0 3px #0f2cff1f}textarea{min-height:90px;resize:vertical}label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#334155;font-weight:700}.btn{border:none;border-radius:12px;padding:10px 14px;font-weight:800;cursor:pointer;text-transform:uppercase;letter-spacing:.04em}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}.btn-secondary{background:#fff;color:var(--text);border:1px solid var(--border)}.btn-danger{background:var(--danger);color:#fff}.auth-shell{min-height:100vh;display:grid;grid-template-columns:1.2fr 1fr}.auth-hero{background:linear-gradient(145deg,#00f,#2d4dff 45%,#6f8fff);color:#fff;padding:54px;display:flex;flex-direction:column;justify-content:space-between}.auth-hero h1{font-size:40px;line-height:1.1;text-transform:uppercase}.auth-hero p{opacity:.92;max-width:480px;margin-top:14px}.auth-panel{display:grid;place-items:center;padding:20px;background:var(--bg-soft)}.auth-card{width:100%;max-width:420px;background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:24px}.auth-card h2{color:var(--primary);margin-bottom:6px;text-transform:uppercase}.auth-sub{color:var(--muted);margin-bottom:14px}.alert{padding:10px 12px;border-radius:10px;font-size:14px;margin-bottom:10px}.alert-error{background:#fee2e2;color:#991b1b}.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:#071338;color:#fff;padding:18px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}.brand{font-weight:800;font-size:19px;display:flex;align-items:center;gap:10px;margin-bottom:18px;text-transform:uppercase}.brand-dot{width:10px;height:10px;border-radius:999px;background:#4c7bff;box-shadow:0 0 0 5px #4c7bff40}.side-user{background:#ffffff14;border:1px solid rgba(255,255,255,.15);padding:10px;border-radius:12px;margin-bottom:14px}.avatar{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;font-weight:700;background:#3253ff;color:#fff}.side-nav{display:grid;gap:8px;margin-top:8px}.side-item{text-align:left;border:none;background:transparent;color:#dbe7ff;padding:11px 12px;border-radius:10px;cursor:pointer;font-weight:700;text-transform:uppercase}.side-item.active,.side-item:hover{background:#4c7bff3d;color:#fff}.side-footer{margin-top:auto}.main{padding:16px 18px 90px}.topbar{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:12px 14px;display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.kpi{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow)}.kpi .label{color:var(--muted);font-size:12px;text-transform:uppercase}.kpi .value{font-size:28px;font-weight:800;margin-top:8px}.panel{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:14px;margin-top:12px}.panel h3{margin-bottom:10px;text-transform:uppercase}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.table-wrap{overflow:auto}table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden}th,td{border-bottom:1px solid var(--border);padding:10px;font-size:13px;text-align:left}th{background:#f8fbff;color:#1e3a8a;text-transform:uppercase;letter-spacing:.05em;font-size:11px}tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:800;text-transform:uppercase}.badge.warn{background:#fff7ed;color:#9a3412}.badge.ok{background:#dcfce7;color:#166534}.employee-shell{max-width:560px;margin:0 auto;min-height:100vh;background:linear-gradient(180deg,#f7f9ff 0,#f1f6ff)}.employee-header{background:linear-gradient(145deg,#00f,#3a64ff);color:#fff;padding:16px;border-radius:0 0 18px 18px}.employee-head-row{display:flex;justify-content:space-between;align-items:center;gap:10px}.employee-clock{font-size:34px;font-weight:800;letter-spacing:.5px}.employee-content{padding:12px}.big-btn{border:none;border-radius:14px;padding:16px;font-weight:800;font-size:18px;cursor:pointer;color:#fff;text-transform:uppercase}.btn-masuk{background:linear-gradient(145deg,#16a34a,#22c55e)}.btn-pulang{background:linear-gradient(145deg,#dc2626,#ef4444)}.bottom-nav{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(4,1fr)}.bottom-item{border:none;background:#fff;padding:10px;color:#334155;font-weight:800;cursor:pointer;text-transform:uppercase;font-size:11px}.bottom-item.active{color:#00f}.profile-card{border:1px solid var(--border);border-radius:16px;padding:14px;background:linear-gradient(180deg,#fff,#f8fbff)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a6b;display:grid;place-items:center;z-index:9999}.modal{width:min(520px,92vw);background:#fff;border-radius:16px;box-shadow:0 20px 55px #02061747;border:1px solid #dbeafe;padding:18px}.modal h4{margin:0 0 8px;text-transform:uppercase}.modal p{color:#334155;margin-bottom:12px}.modal .actions{display:flex;justify-content:flex-end;gap:8px}.modal.success{border-top:6px solid var(--success)}.modal.error{border-top:6px solid var(--danger)}.modal.info{border-top:6px solid var(--primary)}@media (max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:1fr}}@media (max-width:900px){.auth-shell{grid-template-columns:1fr}.auth-hero{display:none}.layout{grid-template-columns:1fr}.sidebar{display:none}.main{padding:10px 10px 90px}.topbar{position:sticky;top:0;z-index:20}.grid-2{grid-template-columns:1fr}}
