*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top left,rgba(59,130,246,.18),transparent 30%),linear-gradient(135deg,#f8fafc,#dbeafe);font-family:"Segoe UI",system-ui,sans-serif;color:#0f172a}.hidden{display:none!important}.splash-screen{position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,#2563eb,#1e40af);color:white;display:grid;place-content:center;text-align:center;transition:opacity .55s ease,visibility .55s ease}.splash-screen.hide{opacity:0;visibility:hidden}.splash-logo{width:112px;height:112px;border-radius:32px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;margin:0 auto 18px;font-size:58px;box-shadow:0 18px 55px rgba(0,0,0,.22)}.splash-screen h1{font-size:34px;font-weight:900;margin:0}.splash-screen p{margin:8px 0 22px;color:rgba(255,255,255,.84)}.splash-loader{width:54px;height:54px;border-radius:50%;border:5px solid rgba(255,255,255,.25);border-top-color:white;animation:spin .9s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.page-shell{width:min(980px,100%);margin:0 auto;padding:24px}.app-header-card{background:linear-gradient(135deg,#2563eb,#1e40af);border-radius:30px;padding:30px;color:white;box-shadow:0 24px 60px rgba(37,99,235,.28);margin-bottom:18px;display:flex;justify-content:space-between;align-items:center;overflow:hidden;position:relative}.badge-soft{display:inline-flex;gap:8px;align-items:center;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);padding:8px 14px;border-radius:999px;font-size:14px;margin-bottom:14px;position:relative;z-index:1}.app-header-card h1{font-size:clamp(30px,4vw,46px);font-weight:900;margin:0}.app-header-card p{max-width:620px;margin:8px 0 0;color:rgba(255,255,255,.88)}.header-icon{width:108px;height:108px;display:grid;place-items:center;border-radius:30px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);font-size:50px}.panel-card,.user-card{background:rgba(255,255,255,.93);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.65);border-radius:28px;padding:24px;box-shadow:0 18px 50px rgba(15,23,42,.08);margin-bottom:18px}.security-note{display:flex;gap:10px;align-items:start;background:#eff6ff;color:#1e40af;border-radius:16px;padding:12px 14px;margin-bottom:18px;font-weight:600}.user-card{display:flex;justify-content:space-between;align-items:center}.user-card span,.user-card small{color:#64748b;font-size:13px;display:block}.user-card b{font-size:20px}.user-card button{border:0;border-radius:14px;padding:10px 14px;background:#fff1f2;color:#e11d48;font-weight:800}.section-title{display:flex;justify-content:space-between;align-items:start;gap:16px;margin-bottom:20px}.section-title.compact{margin-bottom:14px}.section-title h4{margin:0;font-weight:850}.section-title p{margin:4px 0 0;color:#64748b}.section-title>i{width:46px;height:46px;display:grid;place-items:center;border-radius:16px;background:#eff6ff;color:#2563eb;font-size:22px}label{font-weight:700;color:#334155;margin-bottom:8px;font-size:14px}.input-icon{position:relative}.input-icon>i{position:absolute;top:50%;left:15px;transform:translateY(-50%);color:#64748b;z-index:2}.form-control{min-height:52px;border-radius:16px;border:1px solid #dbe3ef;padding-left:44px;background-color:#fff;color:#0f172a}.btn-register{width:100%;margin-top:24px;min-height:56px;border-radius:18px;border:0;background:linear-gradient(135deg,#2563eb,#3b82f6);color:white;font-weight:900}.checktype-buttons{display:grid;grid-template-columns:1fr 1fr;gap:14px}.check-btn{min-height:112px;border:2px solid #e2e8f0;border-radius:26px;background:#fff;color:#334155;display:grid;place-items:center;gap:2px;font-weight:900;transition:.2s ease}.check-btn i{font-size:34px}.check-btn span{font-size:22px}.check-btn small{color:#64748b;font-weight:700}.check-btn.active{color:white;transform:translateY(-2px);box-shadow:0 16px 36px rgba(15,23,42,.16)}.check-btn.active small{color:rgba(255,255,255,.82)}.check-btn.datang.active{background:linear-gradient(135deg,#2563eb,#3b82f6);border-color:transparent}.check-btn.pulang.active{background:linear-gradient(135deg,#f97316,#ef4444);border-color:transparent}.action-row{display:grid;grid-template-columns:1fr 1.4fr;gap:14px;margin-top:20px}.btn{min-height:54px;border-radius:18px;font-weight:850;border:none}.btn-location{background:#eff6ff;color:#2563eb}.btn-execute{background:linear-gradient(135deg,#16a34a,#22c55e);color:white;box-shadow:0 12px 28px rgba(34,197,94,.28)}#map{height:420px;width:100%;border-radius:24px;overflow:hidden;border:4px solid white;box-shadow:0 12px 36px rgba(15,23,42,.10)}.swal2-popup{border-radius:24px!important}@media(max-width:768px){.page-shell{padding:14px}.app-header-card{padding:24px;border-radius:24px}.header-icon{display:none}.panel-card,.user-card{padding:20px;border-radius:24px}.user-card{align-items:flex-start;gap:14px}.check-btn{min-height:96px;border-radius:22px}.check-btn i{font-size:28px}.check-btn span{font-size:18px}.action-row{grid-template-columns:1fr}#map{height:310px}}
