*{box-sizing:border-box}
html,body{min-height:100%}
body{margin:0;background:#eef2f7;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#152238;-webkit-font-smoothing:antialiased}
a{text-decoration:none}.text-app{color:var(--app-primary)!important}
.app-shell{width:100%;max-width:520px;margin:0 auto;min-height:100vh;background:#f8fafc;position:relative;box-shadow:0 0 50px rgba(15,23,42,.12);overflow:hidden}
.app-content{padding:18px 16px 100px;min-height:100vh;overflow-x:hidden}.login-content{padding:22px 18px;display:flex;align-items:center;min-height:100vh}
.mobile-topbar{position:sticky;top:0;z-index:30;padding:18px 16px;background:linear-gradient(135deg,var(--app-primary),#111827);color:#fff;border-bottom-left-radius:28px;border-bottom-right-radius:28px;display:flex;align-items:center;justify-content:space-between;gap:14px;box-shadow:0 12px 28px rgba(37,99,235,.22)}
.mobile-topbar strong{line-height:1.15}.desktop-sidebar{display:none}.desktop-brand{display:flex;align-items:center;gap:10px;padding:24px 20px 18px}.desktop-nav{padding:8px 12px 24px}.desktop-nav a{display:flex;align-items:center;gap:11px;padding:12px 14px;margin-bottom:6px;border-radius:16px;color:#64748b;font-weight:750;letter-spacing:.01em}.desktop-nav a i{font-size:1.05rem;min-width:18px;text-align:center}.desktop-nav a.active,.desktop-nav a:hover{background:rgba(13,110,253,.10);color:var(--app-primary)}
.app-logo,.app-logo-placeholder{width:44px;height:44px;border-radius:16px;object-fit:cover;background:#fff;flex:0 0 auto}.app-logo-placeholder{display:grid;place-items:center;color:var(--app-primary);font-size:1.35rem}.desktop-sidebar .app-logo,.desktop-sidebar .app-logo-placeholder{width:42px;height:42px;border-radius:14px;background:#eef6ff}
.hero-card{background:linear-gradient(135deg,var(--app-primary),var(--app-accent));color:#fff;border-radius:28px;padding:22px;box-shadow:0 18px 40px rgba(15,23,42,.18)}
.card-soft{border:0;border-radius:24px;background:#fff;box-shadow:0 10px 30px rgba(15,23,42,.07)}
.card-soft .card-header{background:transparent;border:0;padding:18px 18px 0}.card-soft .card-body{padding:18px}.rounded-5{border-radius:24px!important}
.metric-card{background:#fff;border-radius:22px;padding:16px;box-shadow:0 10px 25px rgba(15,23,42,.06);height:100%;position:relative;overflow:hidden;border:1px solid rgba(226,232,240,.65)}.metric-card .icon{width:42px;height:42px;border-radius:16px;background:rgba(13,110,253,.1);color:var(--app-primary);display:grid;place-items:center;font-size:1.25rem}.metric-value{font-size:1.45rem;font-weight:850;line-height:1.1}.metric-label{font-size:.8rem;color:#64748b;font-weight:700}.metric-sub{font-size:.75rem;color:#64748b}.metric-card::after{content:"";position:absolute;right:-22px;bottom:-24px;width:82px;height:82px;border-radius:999px;background:rgba(13,110,253,.06)}
.btn-app{background:var(--app-primary);border-color:var(--app-primary);color:#fff;border-radius:18px;font-weight:750;padding:12px 16px}.btn-app:hover{filter:brightness(.94);color:#fff}.btn-outline-app{border-color:var(--app-primary);color:var(--app-primary);border-radius:18px;font-weight:750}.btn-outline-app:hover{background:var(--app-primary);color:#fff}
.form-control,.form-select{border-radius:16px;padding:12px 14px;border-color:#dbe3ef}.form-control:focus,.form-select:focus{border-color:var(--app-primary);box-shadow:0 0 0 .2rem rgba(13,110,253,.12)}
.badge{font-weight:750}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.bottom-nav{position:fixed;left:50%;transform:translateX(-50%);bottom:0;z-index:40;max-width:520px;width:100%;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);border-top:1px solid #e5e7eb;display:grid;grid-template-columns:repeat(5,1fr);padding:8px 8px calc(8px + env(safe-area-inset-bottom));box-shadow:0 -12px 30px rgba(15,23,42,.08)}
.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:2px;color:#64748b;font-size:.72rem;padding:7px 3px;border-radius:16px}.bottom-nav a i{font-size:1.15rem}.bottom-nav a.active{color:var(--app-primary);background:rgba(13,110,253,.09);font-weight:850}
.table-mobile{font-size:.86rem}.table-mobile td,.table-mobile th{vertical-align:middle}.table-responsive{border-radius:18px}.list-row{background:#fff;border-radius:20px;padding:14px;margin-bottom:10px;box-shadow:0 8px 22px rgba(15,23,42,.05)}
.login-card{width:100%;background:#fff;border-radius:32px;padding:24px;box-shadow:0 24px 60px rgba(15,23,42,.14)}.brand-circle{width:74px;height:74px;border-radius:26px;display:grid;place-items:center;background:linear-gradient(135deg,var(--app-primary),var(--app-accent));color:#fff;font-size:2rem;margin:0 auto 14px}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.menu-item{background:#fff;border-radius:24px;padding:18px;color:#0f172a;box-shadow:0 10px 25px rgba(15,23,42,.06);border:1px solid rgba(226,232,240,.75)}.menu-item i{font-size:1.65rem;color:var(--app-primary)}.menu-item span{display:block;margin-top:10px;font-weight:850}.menu-item small{color:#64748b}
.photo-preview{width:100%;border-radius:22px;display:none;margin-top:10px}.qr-box{background:#fff;border-radius:24px;padding:16px;text-align:center}.qr-token{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#f1f5f9;border-radius:14px;padding:10px;word-break:break-all}
.camera-box{border:1px solid #e2e8f0;background:#f8fafc;border-radius:26px;padding:12px}.camera-frame{border-radius:24px;overflow:hidden;background:#0f172a;min-height:260px;display:grid;place-items:center;position:relative}.camera-frame::before{content:"Kamera selfie";position:absolute;color:rgba(255,255,255,.6);font-weight:700;z-index:0}.camera-video,.camera-canvas{width:100%;height:auto;display:block;position:relative;z-index:1}.camera-video{min-height:260px;object-fit:cover;transform:scaleX(-1)}.camera-canvas{background:#0f172a}.fallback-upload{background:#fff;border-radius:20px;padding:12px;border:1px dashed #cbd5e1}.selfie-ok{border-color:rgba(22,163,74,.35);background:#f0fdf4}.selfie-warning{border-color:rgba(245,158,11,.45);background:#fffbeb}
.map-box{height:470px;border-radius:24px;overflow:hidden;border:1px solid #e2e8f0;background:#e2e8f0}.map-box-sm{height:280px}.leaflet-container{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;z-index:1}.leaflet-popup-content{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}.popup-photo{width:160px;height:110px;object-fit:cover;border-radius:14px;margin-top:6px}.chart-card{min-height:300px}.progress-soft{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.progress-soft span{display:block;height:100%;background:linear-gradient(90deg,var(--app-primary),var(--app-accent));border-radius:999px}.admin-grid{display:grid;gap:12px}.page-footer{display:none}
@media(min-width:800px) and (max-width:991.98px){body{background:#dbe4f0}.app-shell{margin:20px auto;border-radius:34px;min-height:calc(100vh - 40px)}.bottom-nav{bottom:20px;border-bottom-left-radius:34px;border-bottom-right-radius:34px}.app-content{min-height:calc(100vh - 40px)}}
@media(min-width:992px){
  body{background:#dbe4f0}.app-shell{width:calc(100% - 32px);max-width:1440px;margin:16px auto;min-height:calc(100vh - 32px);display:grid;grid-template-columns:280px minmax(0,1fr);grid-template-rows:auto 1fr auto;border-radius:30px;overflow:hidden;background:#f8fafc;box-shadow:0 22px 70px rgba(15,23,42,.12)}
  .desktop-sidebar{display:block;grid-column:1;grid-row:1 / 4;background:#fff;border-right:1px solid #e2e8f0;min-height:calc(100vh - 32px);overflow-y:auto}
  .mobile-topbar{grid-column:2;grid-row:1;position:sticky;top:0;z-index:20;align-self:start;min-height:74px;border-radius:0;background:#fff;color:#152238;padding:15px 26px;box-shadow:0 1px 0 #e2e8f0}.mobile-topbar .small{color:#64748b;opacity:1!important}.mobile-topbar .btn-light{background:#f8fafc;border:1px solid #e2e8f0;color:#0f172a}.mobile-topbar .app-logo-placeholder{background:#eef6ff}
  .app-content{grid-column:2;grid-row:2;padding:24px 28px 36px;min-height:auto}.login-content{grid-column:1/3;grid-row:1/4;max-width:480px;margin:0 auto;width:100%;min-height:calc(100vh - 32px)}
  .page-footer{display:flex;grid-column:2;grid-row:3;align-items:center;justify-content:space-between;gap:12px;padding:14px 28px;background:#fff;border-top:1px solid #e2e8f0;color:#64748b;font-size:.86rem}.bottom-nav{display:none}
  .menu-grid{grid-template-columns:repeat(4,1fr)}.admin-grid{grid-template-columns:minmax(0,1.2fr) minmax(340px,.8fr)}.metric-value{font-size:1.75rem}.map-box{height:560px}.camera-frame{min-height:360px}.camera-video{min-height:360px}.table-desktop{font-size:.92rem}.hero-card{padding:26px 28px}.card-soft .card-body{padding:20px}.card-soft .card-header{padding:20px 20px 0}.row.g-2{--bs-gutter-x:.75rem;--bs-gutter-y:.75rem}
}
@media(min-width:1200px){.app-content{padding:28px 34px 40px}.page-footer{padding-left:34px;padding-right:34px}.map-box{height:610px}}
/* Revisi 3: data karyawan, QR scanner kegiatan, dan kalender aktivitas */
.employee-photo{width:64px;height:64px;border-radius:22px;object-fit:cover;border:2px solid #e2e8f0;flex:0 0 auto;background:#f8fafc}.employee-photo-empty{display:grid;place-items:center;color:#94a3b8;font-size:1.7rem}.employee-row{height:100%}.avatar-preview{max-width:160px;max-height:160px;object-fit:cover;border-radius:24px}
.qr-scanner-box{border:1px solid #e2e8f0;background:#f8fafc;border-radius:26px;padding:12px}.qr-scanner-frame{height:260px;background:#0f172a;border-radius:22px;overflow:hidden;position:relative;display:grid;place-items:center}.qr-scanner-frame::before{content:"Scanner QR";position:absolute;color:rgba(255,255,255,.62);font-weight:800;letter-spacing:.04em}.qr-scanner-frame video{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}.qr-scan-line{position:absolute;left:12%;right:12%;top:50%;height:2px;background:var(--app-accent);box-shadow:0 0 18px var(--app-accent);z-index:2;animation:qrscan 1.8s ease-in-out infinite}.qr-ok{border-color:rgba(22,163,74,.35);background:#f0fdf4}@keyframes qrscan{0%,100%{transform:translateY(-80px);opacity:.45}50%{transform:translateY(80px);opacity:1}}
.activity-legend{display:flex;flex-wrap:wrap;gap:10px 16px;font-size:.82rem;color:#64748b}.legend-dot{width:12px;height:12px;border-radius:999px;display:inline-block;margin-right:6px;vertical-align:-1px}.activity-calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.calendar-head{text-align:center;font-size:.75rem;font-weight:850;color:#64748b;padding:6px 0}.calendar-empty{min-height:74px}.calendar-day{min-height:74px;border:0;border-radius:18px;padding:9px;text-align:left;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 8px 18px rgba(15,23,42,.05);transition:.15s transform,.15s box-shadow}.calendar-day:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(15,23,42,.09)}.calendar-date{font-weight:900;font-size:1rem}.calendar-count{font-size:.72rem;font-weight:800}.calendar-ok{background:#dcfce7;color:#166534}.calendar-warn{background:#fef3c7;color:#92400e}.calendar-miss{background:#fee2e2;color:#991b1b}.calendar-future{background:#e2e8f0;color:#64748b}.calendar-day.calendar-future{opacity:.78}
@media(min-width:992px){.qr-scanner-frame{height:360px}.activity-calendar{gap:10px}.calendar-day{min-height:96px;border-radius:22px}.calendar-empty{min-height:96px}.employee-photo{width:72px;height:72px}}
@media(max-width:420px){.activity-calendar{gap:5px}.calendar-day{min-height:62px;border-radius:14px;padding:7px}.calendar-count{font-size:.64rem}.calendar-date{font-size:.9rem}.calendar-empty{min-height:62px}.qr-scanner-frame{height:220px}}
/* Revisi 4: popup peta pegawai dan kalender target hari kerja */
.popup-profile{min-width:250px;max-width:340px}.popup-title{font-weight:850;font-size:1rem;margin-top:6px}.popup-muted{color:#64748b;font-size:.82rem;line-height:1.35}.popup-badges{display:flex;gap:4px;flex-wrap:wrap;margin:8px 0}.popup-badges span{background:#eef2ff;color:#1e40af;border-radius:999px;padding:3px 8px;font-size:.72rem;font-weight:800}.popup-detail{font-size:.8rem;line-height:1.4;margin-top:7px;border-top:1px solid #e2e8f0;padding-top:7px}.popup-photos{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.popup-photo-box{display:inline-block}.popup-photo-label{font-size:.72rem;color:#64748b;font-weight:800;margin:4px 0}.popup-map-link{display:inline-block;margin-top:8px;background:var(--app-primary);color:#fff!important;padding:7px 10px;border-radius:12px;font-size:.8rem;font-weight:800}.leaflet-popup-content{margin:12px 14px!important}.calendar-plus{background:#ecfdf5!important;border-color:#16a34a!important;color:#166534!important}.calendar-off{background:#f8fafc!important;border-color:#cbd5e1!important;color:#94a3b8!important}.legend-dot.calendar-plus{background:#16a34a}.legend-dot.calendar-off{background:#94a3b8}
