:root{--primary: #1a56db;--primary-dark: #1240a8;--green: #057a55;--red: #c81e1e;--yellow: #b45309;--bg: #f3f4f6;--card: #ffffff;--text: #111827;--muted: #6b7280;--border: #e5e7eb}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:15px}.app-header{background:var(--primary);color:#fff;padding:12px 20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.app-header h1{font-size:18px}.app-header .sub{font-size:12px;opacity:.85}.container{max-width:1100px;margin:0 auto;padding:16px}.tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:16px;background:var(--card);padding:6px;border-radius:10px;border:1px solid var(--border)}@media (max-width: 640px){.tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tabs button{white-space:nowrap;flex-shrink:0}}.tabs button{border:none;background:transparent;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:14px;color:var(--muted);font-weight:500}.tabs button.active{background:var(--primary);color:#fff}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;margin-bottom:16px}.card h2{font-size:16px;margin-bottom:12px}.card h3{font-size:14px;margin-bottom:8px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media (max-width: 640px){.grid2,.grid3{grid-template-columns:1fr}}label{display:block;font-size:13px;color:var(--muted);margin-bottom:4px;font-weight:500}input,select,textarea{width:100%;padding:9px 10px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:#fff}textarea{resize:vertical;min-height:70px}.field{margin-bottom:12px}.btn{display:inline-block;padding:10px 18px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-size:14px;font-weight:600;cursor:pointer}.btn:hover{background:var(--primary-dark)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-green{background:var(--green)}.btn-red{background:var(--red)}.btn-outline{background:transparent;color:var(--primary);border:1px solid var(--primary)}.btn-sm{padding:5px 10px;font-size:12px}.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge-green{background:#def7ec;color:var(--green)}.badge-red{background:#fde8e8;color:var(--red)}.badge-yellow{background:#fef3c7;color:var(--yellow)}.badge-blue{background:#e1effe;color:var(--primary)}.badge-gray{background:#f3f4f6;color:var(--muted)}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border)}th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em}.table-wrap{overflow-x:auto}.alert{padding:10px 14px;border-radius:8px;font-size:14px;margin-bottom:12px}.alert-error{background:#fde8e8;color:var(--red)}.alert-success{background:#def7ec;color:var(--green)}.alert-info{background:#e1effe;color:var(--primary)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}.login-card{background:var(--card);border-radius:14px;padding:32px;width:100%;max-width:380px;border:1px solid var(--border)}.login-card h1{font-size:22px;margin-bottom:4px;text-align:center;color:var(--primary)}.login-card p{text-align:center;color:var(--muted);font-size:13px;margin-bottom:20px}.clock{font-size:34px;font-weight:700;text-align:center}.clock-date{text-align:center;color:var(--muted);margin-bottom:14px}.absen-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:10px}.absen-btns .btn{min-width:150px;padding:14px 20px;font-size:15px}.stat{text-align:center;padding:10px}.stat .num{font-size:24px;font-weight:700;color:var(--primary)}.stat .lbl{font-size:12px;color:var(--muted)}.muted{color:var(--muted);font-size:13px}.row-actions{display:flex;gap:6px;flex-wrap:wrap}.mt{margin-top:12px}.header-actions{display:flex;align-items:center;gap:10px}.header-actions .btn{background:#ffffff26}@media (max-width: 640px){body{font-size:14px}.container{padding:10px}.card{padding:14px;border-radius:10px}.app-header{padding:10px 14px;position:sticky;top:0;z-index:20}.app-header h1{font-size:16px}.clock{font-size:42px}.absen-btns{flex-direction:column}.absen-btns .btn{width:100%;min-width:0;padding:16px;font-size:16px}input,select,textarea{padding:12px;font-size:16px}.btn{padding:12px 18px}.btn-sm{padding:7px 12px;font-size:13px}th,td{padding:8px 6px;font-size:12px}.login-card{padding:22px}}@supports (padding: env(safe-area-inset-top)){.app-header{padding-top:calc(10px + env(safe-area-inset-top))}}
