:root{--bg:#eef4ff;--card:#fff;--text:#0f172a;--muted:#64748b;--line:#dbeafe;--primary:#2563eb;--primary2:#7c3aed;--success:#16a34a;--danger:#dc2626;--warning:#f59e0b;--dark:#172033;--shadow:0 18px 45px rgba(15,23,42,.10);--radius:22px}
*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at top left,#dbeafe 0,#eef4ff 35%,#f8fafc 100%);color:var(--text);font-size:14px}a{text-decoration:none;color:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;width:286px;background:linear-gradient(180deg,#0f172a,#1e3a8a 55%,#312e81);color:#fff;padding:18px;z-index:20;overflow:auto;transition:.25s}.brand{display:flex;gap:12px;align-items:center;padding:12px;border-radius:18px;background:rgba(255,255,255,.10);margin-bottom:16px}.brand-logo{width:48px;height:48px;border-radius:16px;background:#fff;color:#1d4ed8;display:grid;place-items:center;font-weight:900;overflow:hidden}.brand-logo img{width:100%;height:100%;object-fit:contain}.brand b{display:block;font-size:14px}.brand span{display:block;color:#cbd5e1;font-size:12px}.nav-menu{display:grid;gap:7px}.nav-menu a{padding:11px 12px;border-radius:14px;color:#e5edff;font-weight:700;font-size:13px}.nav-menu a:hover,.nav-menu a.active{background:rgba(255,255,255,.16);color:#fff}.main-content{margin-left:286px;width:calc(100% - 286px);min-height:100vh}.topbar{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.78);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px;border-bottom:1px solid rgba(148,163,184,.25)}.hamburger{display:none;border:0;background:var(--primary);color:#fff;width:42px;height:42px;border-radius:13px;font-size:22px}.top-title b{display:block;font-size:17px}.top-title span{font-size:12px;color:var(--muted)}.top-actions{display:flex;align-items:center;gap:12px}.notif{position:relative;width:42px;height:42px;border-radius:14px;background:#fff;display:grid;place-items:center;box-shadow:0 8px 20px rgba(15,23,42,.06)}.notif em{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;border-radius:999px;font-style:normal;font-size:10px;padding:2px 6px}.user-chip{display:flex;gap:8px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 11px;box-shadow:0 8px 20px rgba(15,23,42,.06)}.user-chip span{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chip b{font-size:10px;background:#dbeafe;color:#1d4ed8;padding:4px 8px;border-radius:999px}.content-wrap{padding:22px;max-width:1450px;margin:0 auto}.hero-card{position:relative;overflow:hidden;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border-radius:28px;padding:26px;box-shadow:var(--shadow);display:flex;justify-content:space-between;gap:18px;align-items:center}.hero-card h1{margin:6px 0;font-size:31px;line-height:1.08}.hero-card p{max-width:750px;margin:0;color:#e0e7ff}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-weight:900;font-size:11px;color:#bfdbfe}.hero-actions{display:flex;flex-wrap:wrap;gap:10px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:16px 0}.stat-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:0 12px 24px rgba(15,23,42,.05)}.stat-card span{display:block;color:var(--muted);font-weight:800;font-size:12px}.stat-card b{display:block;font-size:24px;margin:5px 0}.stat-card small{color:var(--muted)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin:16px 0;box-shadow:0 12px 28px rgba(15,23,42,.06)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.card-head h2,.card-head h3{margin:0}.card-head span{color:var(--muted);font-size:12px}.btn{border:0;border-radius:14px;padding:11px 14px;background:#eef2ff;color:#1e40af;font-weight:900;display:inline-flex;align-items:center;gap:8px;cursor:pointer;justify-content:center}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff}.btn.success{background:var(--success);color:#fff}.btn.danger{background:var(--danger);color:#fff}.btn.warn{background:var(--warning);color:#fff}.btn.ghost{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.25)}.btn.small{padding:7px 10px;border-radius:10px;font-size:12px}.btn.full{width:100%}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}.form-grid.two{grid-template-columns:repeat(2,1fr)}.form-stack{display:grid;gap:13px}.filter-row{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.filter-row>div{min-width:190px}.span-2{grid-column:span 2}.span-3{grid-column:span 3}label{display:block;font-weight:900;font-size:12px;margin-bottom:7px;color:#334155}input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:14px;padding:12px;background:#fff;color:#111827;outline:none}textarea{min-height:90px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:#2563eb;box-shadow:0 0 0 4px rgba(37,99,235,.10)}.hint{font-size:12px;color:var(--muted);margin-top:6px}.table-wrap{overflow:auto;border-radius:16px;border:1px solid var(--line)}table{width:100%;border-collapse:collapse;min-width:850px;background:#fff}th,td{padding:12px;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:top}th{background:#f1f5ff;color:#1e3a8a;font-size:12px;text-transform:uppercase;letter-spacing:.03em}tr:hover td{background:#fafcff}.badge{display:inline-flex;border-radius:999px;padding:5px 9px;font-weight:900;font-size:11px;background:#e2e8f0;color:#334155}.badge.ok,.badge.approved,.badge.paid{background:#dcfce7;color:#166534}.badge.warn,.badge.pending,.badge.terlambat{background:#fef3c7;color:#92400e}.badge.danger,.badge.rejected,.badge.diluar_radius{background:#fee2e2;color:#991b1b}.badge.info{background:#dbeafe;color:#1d4ed8}.alert{padding:13px 15px;border-radius:16px;margin-bottom:12px;border:1px solid}.alert.success{background:#dcfce7;color:#166534;border-color:#bbf7d0}.alert.danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}.alert.info{background:#dbeafe;color:#1e40af;border-color:#bfdbfe}.alert.warning{background:#fef3c7;color:#92400e;border-color:#fde68a}.empty{text-align:center;color:var(--muted);padding:24px}.notice{border:1px solid var(--line);border-radius:16px;padding:13px;margin-bottom:10px;background:#f8fbff}.notice b{display:block}.notice p{margin:6px 0;color:#475569}.gps-card{max-width:780px}.gps-status{padding:14px;border-radius:16px;background:#eff6ff;color:#1d4ed8;font-weight:900;margin-bottom:12px}.map-note{padding:13px;border:1px dashed #93c5fd;border-radius:16px;margin-bottom:13px;background:#f8fbff}.photo-thumb{width:62px;height:62px;border-radius:14px;object-fit:cover;border:1px solid #cbd5e1}.profile-list{display:grid;gap:8px}.profile-list p{margin:0;padding:10px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px}.login-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at top,#bfdbfe,#eef2ff 45%,#fff)}.login-card{width:min(460px,100%);background:#fff;border-radius:30px;padding:28px;box-shadow:0 24px 70px rgba(15,23,42,.18);border:1px solid #dbeafe}.login-card h1{margin:0 0 8px}.login-card p{color:var(--muted);margin:0 0 20px}.slip-card{max-width:820px;margin:25px auto;background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:28px}.slip-title{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid #e2e8f0;padding-bottom:15px}.slip-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}.slip-row{display:flex;justify-content:space-between;gap:12px;border-bottom:1px dashed #cbd5e1;padding:9px 0}.total-pay{font-size:26px;color:#16a34a}.print-body{background:#f8fafc}.tabs{display:flex;gap:8px;flex-wrap:wrap}.tabs a{padding:10px 13px;background:#eef2ff;border-radius:13px;font-weight:900;color:#1e40af}.tabs a.active{background:#1d4ed8;color:#fff}.pill-grid{display:flex;gap:8px;flex-wrap:wrap}.pill{padding:8px 10px;border-radius:999px;background:#f1f5f9;color:#334155;font-weight:800;font-size:12px}.camera-note{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:16px;padding:12px}.selfie-panel{border:1px solid #dbeafe;border-radius:18px;background:#f8fbff;padding:13px;display:grid;gap:10px}.selfie-stage{position:relative;overflow:hidden;border-radius:18px;background:#0f172a;min-height:310px;display:grid;place-items:center;border:1px solid #bfdbfe}.selfie-stage video,.selfie-stage img{width:100%;max-height:440px;object-fit:cover;display:none}.selfie-stage video{transform:scaleX(-1)}.selfie-placeholder{position:absolute;inset:0;display:grid;place-items:center;color:#cbd5e1;text-align:center;padding:18px;font-weight:900}.selfie-status{padding:11px 12px;border-radius:14px;background:#eef2ff;color:#1e40af;font-weight:800}.selfie-status.ok{background:#dcfce7;color:#166534;border:1px solid #86efac}.selfie-status.warn{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.selfie-status.danger{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.camera-actions{display:flex;gap:8px;flex-wrap:wrap}
.no-print{display:inline-flex}@media (max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{grid-template-columns:1fr}.form-grid{grid-template-columns:repeat(2,1fr)}.span-3{grid-column:span 2}}@media (max-width:800px){body{font-size:13px}.sidebar{transform:translateX(-105%);width:284px}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0;width:100%}.hamburger{display:block}.topbar{padding:12px}.top-title span{display:none}.user-chip span{display:none}.content-wrap{padding:13px}.hero-card{display:block;padding:20px;border-radius:22px}.hero-card h1{font-size:24px}.hero-actions{margin-top:16px}.stats-grid{grid-template-columns:1fr}.form-grid,.form-grid.two{grid-template-columns:1fr}.span-2,.span-3{grid-column:auto}.card{padding:14px;border-radius:18px}.card-head{display:block}.card-head span{display:block;margin-top:5px}.filter-row{display:grid}.filter-row>div{min-width:100%}.btn{width:100%}.top-actions{gap:7px}.notif{width:38px;height:38px}.slip-grid{grid-template-columns:1fr}.no-mobile{display:none}}@media print{.sidebar,.topbar,.no-print{display:none!important}.main-content{margin:0;width:100%}.content-wrap{padding:0}.card,.slip-card{box-shadow:none;border:0;margin:0}.btn{display:none!important}}
.radius-status{padding:13px 14px;border-radius:16px;margin:-3px 0 12px 0;font-weight:900;line-height:1.45;background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.radius-status.ok{background:#dcfce7;color:#166534;border-color:#86efac}.radius-status.warn{background:#fef3c7;color:#92400e;border-color:#fcd34d}.radius-status.danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}


.gps-toolbar{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 12px 0}.gps-toolbar .btn{width:auto}.map-card{border:1px solid #dbeafe;border-radius:18px;background:#f8fbff;padding:12px;margin-bottom:12px}.map-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}.map-card-head b{display:block}.map-card-head span{color:#64748b;font-size:12px}.gps-map{width:100%;height:320px;border-radius:16px;overflow:hidden;border:1px solid #bfdbfe;background:#e2e8f0}.map-meta{margin-top:10px;padding:11px 12px;border-radius:14px;background:#eff6ff;color:#1e40af;font-weight:800;line-height:1.45}.leaflet-container{font:inherit}.leaflet-control-attribution{font-size:10px}@media (max-width:800px){.gps-toolbar{display:grid;grid-template-columns:1fr 1fr}.map-card-head{display:block}.gps-map{height:280px}}


/* ===== V7 PROFESSIONAL FRONT LOGIN ===== */
.pro-login-page{position:relative;overflow:hidden;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px;background:linear-gradient(135deg,#07111f 0%,#0f172a 42%,#1d4ed8 100%);color:#e5e7eb}.login-bg-shape{position:fixed;border-radius:999px;filter:blur(12px);opacity:.7;pointer-events:none;animation:floatShape 9s ease-in-out infinite}.shape-a{width:320px;height:320px;background:rgba(59,130,246,.38);left:-90px;top:-80px}.shape-b{width:420px;height:420px;background:rgba(124,58,237,.30);right:-120px;bottom:-130px;animation-delay:-2.5s}.shape-c{width:220px;height:220px;background:rgba(34,197,94,.20);left:48%;bottom:8%;animation-delay:-5s}@keyframes floatShape{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(18px,-18px,0) scale(1.05)}}.pro-login-wrap{position:relative;z-index:1;width:min(1180px,100%);display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:stretch}.login-showcase,.login-panel-pro{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.10);backdrop-filter:blur(22px);box-shadow:0 30px 90px rgba(0,0,0,.32);border-radius:34px}.login-showcase{padding:28px;min-height:650px;display:flex;flex-direction:column;justify-content:space-between}.login-showcase:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.18),transparent 28%),radial-gradient(circle at 82% 18%,rgba(96,165,250,.25),transparent 30%),linear-gradient(135deg,rgba(37,99,235,.18),rgba(15,23,42,.22));pointer-events:none}.showcase-top,.showcase-copy,.feature-mosaic,.showcase-bottom{position:relative;z-index:1}.showcase-top{display:flex;justify-content:space-between;align-items:center;gap:14px}.login-brand-pro{display:flex;gap:12px;align-items:center}.login-logo-pro{width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,#fff,#dbeafe);display:grid;place-items:center;color:#1d4ed8;font-weight:1000;box-shadow:0 16px 30px rgba(0,0,0,.18);overflow:hidden}.login-logo-pro img{width:100%;height:100%;object-fit:contain}.login-brand-pro b{display:block;font-size:16px;color:#fff}.login-brand-pro span{display:block;color:#cbd5e1;font-size:12px;margin-top:2px}.secure-chip{white-space:nowrap;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.12);color:#e0f2fe;border-radius:999px;padding:10px 13px;font-weight:900;font-size:12px}.pro-eyebrow{display:inline-flex;letter-spacing:.14em;font-size:11px;font-weight:1000;color:#bfdbfe;margin-bottom:12px}.showcase-copy{max-width:760px;margin:54px 0 24px}.showcase-copy h1{font-size:48px;line-height:1.02;letter-spacing:-.04em;color:#fff;margin:0 0 16px}.showcase-copy p{font-size:16px;line-height:1.72;color:#dbeafe;margin:0;max-width:690px}.feature-mosaic{display:grid;grid-template-columns:1.2fr 1fr;gap:14px;margin-top:22px}.mosaic-card{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.16);border-radius:24px;padding:18px;min-height:142px;display:flex;flex-direction:column;gap:7px}.mosaic-card.main{grid-row:span 2;justify-content:flex-end;background:linear-gradient(145deg,rgba(37,99,235,.45),rgba(124,58,237,.25));min-height:298px}.mosaic-icon{width:46px;height:46px;border-radius:16px;background:rgba(255,255,255,.14);display:grid;place-items:center;font-size:22px}.mosaic-card b{color:#fff;font-size:16px}.mosaic-card span{color:#cbd5e1;font-size:13px;line-height:1.45}.showcase-bottom{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}.showcase-bottom div{padding:14px;border-radius:18px;background:rgba(15,23,42,.26);border:1px solid rgba(255,255,255,.12)}.showcase-bottom b{display:block;color:#fff;font-size:15px}.showcase-bottom span{display:block;color:#cbd5e1;font-size:12px;margin-top:4px}.login-panel-pro{background:rgba(255,255,255,.95);color:#0f172a;padding:30px;display:flex;flex-direction:column;justify-content:center}.panel-glow{position:absolute;width:260px;height:260px;border-radius:999px;background:rgba(37,99,235,.12);right:-80px;top:-80px;pointer-events:none}.panel-head-pro{position:relative;z-index:1;margin-bottom:22px}.login-badge{display:inline-flex;background:#dbeafe;color:#1d4ed8;border-radius:999px;padding:8px 12px;font-weight:1000;font-size:12px;margin-bottom:14px}.panel-head-pro h2{font-size:31px;letter-spacing:-.03em;margin:0 0 8px;color:#0f172a}.panel-head-pro p{color:#64748b;margin:0;line-height:1.55}.pro-login-form{display:grid;gap:14px}.input-shell label{display:block;margin-bottom:8px;color:#334155;font-weight:1000;font-size:12px}.input-icon-wrap{display:flex;align-items:center;gap:9px;background:#f8fafc;border:1px solid #dbeafe;border-radius:18px;padding:4px 12px;transition:.18s}.input-icon-wrap:focus-within{border-color:#2563eb;box-shadow:0 0 0 5px rgba(37,99,235,.10);background:#fff}.input-icon-wrap span{font-size:17px}.input-icon-wrap input{border:0;background:transparent;border-radius:0;padding:14px 0;box-shadow:none}.input-icon-wrap input:focus{border:0;box-shadow:none}.login-main-btn{height:54px;border-radius:18px;font-size:15px;box-shadow:0 18px 28px rgba(37,99,235,.25)}.login-quick-info{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}.login-quick-info div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;padding:13px}.login-quick-info b{display:block;color:#0f172a}.login-quick-info span{display:block;color:#64748b;font-size:12px;line-height:1.45;margin-top:4px}.demo-account-box{border:1px dashed #bfdbfe;background:#eff6ff;border-radius:18px;padding:12px;margin-top:2px}.demo-account-box summary{cursor:pointer;font-weight:1000;color:#1e40af}.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.demo-grid div{background:#fff;border-radius:14px;padding:11px}.demo-grid b{display:block;margin-bottom:8px}.demo-grid code{display:block;background:#f1f5f9;color:#0f172a;padding:7px 8px;border-radius:9px;margin-top:6px;font-size:12px;white-space:nowrap;overflow:auto}.login-footer-note{margin-top:14px;padding:13px;border-radius:16px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;font-size:12px;line-height:1.5}.login-footer-note b{color:#7c2d12}@media (max-width:980px){.pro-login-page{display:block;padding:16px}.pro-login-wrap{grid-template-columns:1fr;gap:16px}.login-showcase{min-height:auto;border-radius:28px}.showcase-copy{margin:34px 0 20px}.showcase-copy h1{font-size:36px}.feature-mosaic{grid-template-columns:1fr 1fr}.mosaic-card.main{grid-row:auto;min-height:170px}.login-panel-pro{border-radius:28px}}@media (max-width:620px){.pro-login-page{padding:10px;background:linear-gradient(180deg,#0f172a,#1d4ed8)}.login-showcase{padding:18px;border-radius:24px}.showcase-top{align-items:flex-start}.secure-chip{display:none}.login-logo-pro{width:50px;height:50px;border-radius:17px}.showcase-copy h1{font-size:29px}.showcase-copy p{font-size:14px}.feature-mosaic,.showcase-bottom,.login-quick-info,.demo-grid{grid-template-columns:1fr}.mosaic-card,.mosaic-card.main{min-height:auto}.showcase-bottom{margin-top:14px}.login-panel-pro{padding:20px;border-radius:24px}.panel-head-pro h2{font-size:26px}.login-main-btn{height:52px}.shape-c{display:none}}


/* V8 clean GPS UI: status GPS/radius disembunyikan, fokus hanya peta posisi HP */
.gps-card{max-width:880px}.map-card{margin-top:4px}.map-card-head span{font-size:12px}.gps-status,.radius-status{display:none!important}


/* V9: tampilkan status Lokasi Benar */
.radius-status{margin:0 0 12px 0!important;font-size:13px}.radius-status.ok{font-size:14px}


/* V10 FIX LOGIN DEPAN HP - agar halaman bisa discroll dan form login bisa diklik */
html,body{max-width:100%;}
.pro-login-page{overflow-x:hidden!important;overflow-y:auto!important;height:auto!important;min-height:100dvh!important;align-items:flex-start!important;touch-action:auto!important;-webkit-overflow-scrolling:touch!important;}
.pro-login-wrap{position:relative;z-index:5;margin:0 auto;padding:0 0 24px 0;}
.login-bg-shape,.login-showcase:before,.panel-glow{pointer-events:none!important;}
.login-panel-pro,.login-panel-pro *{pointer-events:auto;}
.pro-login-form input,.pro-login-form button,.demo-account-box summary{position:relative;z-index:10;}
@media (max-width:980px){
  .pro-login-page{display:block!important;padding:14px!important;}
  .pro-login-wrap{display:flex!important;flex-direction:column!important;width:100%!important;gap:14px!important;}
  .login-panel-pro{order:1!important;min-height:auto!important;justify-content:flex-start!important;}
  .login-showcase{order:2!important;min-height:auto!important;}
  .showcase-copy{margin:22px 0 16px!important;}
  .feature-mosaic{margin-top:12px!important;}
  .showcase-bottom{display:none!important;}
}
@media (max-width:620px){
  .pro-login-page{padding:8px!important;}
  .login-panel-pro{padding:18px!important;border-radius:22px!important;}
  .login-showcase{padding:16px!important;border-radius:22px!important;}
  .panel-head-pro{margin-bottom:14px!important;}
  .panel-head-pro h2{font-size:24px!important;}
  .panel-head-pro p{font-size:13px!important;}
  .login-quick-info{display:none!important;}
  .login-footer-note{font-size:11px!important;}
  .showcase-copy h1{font-size:25px!important;}
  .showcase-copy p{font-size:13px!important;line-height:1.55!important;}
  .mosaic-card{padding:14px!important;border-radius:18px!important;}
}


/* V11 FIX GPS + LOGIN CLICK
   - Status lokasi benar ditampilkan lagi
   - GPS status ditampilkan sebagai Posisi HP, bukan tulisan GPS aktif
   - Login panel dibuat paling depan agar input/tombol pasti bisa diklik di HP
*/
.gps-status{display:block!important;visibility:visible!important;opacity:1!important;margin-bottom:10px!important;font-size:13px!important;line-height:1.45!important;}
.radius-status{display:block!important;visibility:visible!important;opacity:1!important;margin-bottom:12px!important;}
.map-card{position:relative;z-index:1!important;}
.selfie-panel,.form-stack{position:relative;z-index:2!important;}
.pro-login-page{position:relative!important;overflow-x:hidden!important;overflow-y:auto!important;min-height:100svh!important;height:auto!important;}
.pro-login-wrap{position:relative!important;z-index:30!important;pointer-events:auto!important;}
.login-panel-pro{position:relative!important;z-index:80!important;pointer-events:auto!important;isolation:isolate!important;}
.login-panel-pro form,.login-panel-pro input,.login-panel-pro button,.login-panel-pro details,.login-panel-pro summary{position:relative!important;z-index:120!important;pointer-events:auto!important;touch-action:manipulation!important;}
.login-showcase{position:relative!important;z-index:10!important;}
.login-bg-shape,.login-showcase:before,.panel-glow{pointer-events:none!important;z-index:0!important;}
.input-icon-wrap input{font-size:16px!important;min-height:44px!important;}
.login-main-btn{min-height:52px!important;pointer-events:auto!important;cursor:pointer!important;}
@media (max-width:980px){
  .pro-login-wrap{display:flex!important;flex-direction:column!important;}
  .login-panel-pro{order:1!important;}
  .login-showcase{order:2!important;}
}

.coord-panel{border:1px solid #dbeafe;border-radius:18px;background:#fff;padding:14px;margin:0 0 12px 0;box-shadow:0 10px 22px rgba(15,23,42,.04)}.coord-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}.coord-head b{display:block}.coord-head span{color:#64748b;font-size:12px}.coord-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.coord-item{border:1px solid #e2e8f0;background:#f8fbff;border-radius:14px;padding:12px}.coord-item span{display:block;font-size:12px;color:#64748b;font-weight:800;margin-bottom:4px}.coord-item b{font-size:14px;color:#0f172a;word-break:break-word}.coord-item b.ok{color:#166534}.coord-item b.danger{color:#991b1b}.coord-item b.warn{color:#92400e}@media (max-width:800px){.coord-grid{grid-template-columns:1fr 1fr}.coord-head{display:block}}

.radius-status.hide{display:none!important}


/* V18 - Modern Employee Mobile Portal */
.employee-dashboard-pro{display:grid;gap:16px}.employee-hero-pro{position:relative;overflow:hidden;border-radius:28px;padding:22px;background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 50%,#7c3aed 100%);color:#fff;box-shadow:0 22px 48px rgba(29,78,216,.24);display:grid;grid-template-columns:1.5fr .8fr;gap:18px;align-items:stretch}.hero-bg-orb{position:absolute;border-radius:999px;filter:blur(10px);opacity:.35;pointer-events:none}.hero-bg-orb.one{width:180px;height:180px;background:#60a5fa;right:-65px;top:-70px}.hero-bg-orb.two{width:160px;height:160px;background:#f472b6;left:-80px;bottom:-80px}.hero-main-pro,.hero-profile-pro{position:relative;z-index:1}.hero-kicker{display:inline-flex;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:8px 11px;border-radius:999px;text-transform:uppercase;letter-spacing:.11em;font-weight:900;font-size:11px}.employee-hero-pro h1{font-size:31px;line-height:1.08;margin:14px 0 10px}.employee-hero-pro p{margin:0;color:#e0e7ff;line-height:1.65;max-width:720px}.hero-action-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.btn.soft-white{background:rgba(255,255,255,.17);border:1px solid rgba(255,255,255,.28);color:#fff}.hero-profile-pro{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);border-radius:24px;padding:16px;display:grid;align-content:center;justify-items:center;text-align:center;gap:10px;backdrop-filter:blur(12px)}.profile-avatar-pro{width:86px;height:86px;border-radius:28px;background:linear-gradient(135deg,#fff,#dbeafe);color:#1d4ed8;font-size:38px;font-weight:900;display:grid;place-items:center;overflow:hidden;box-shadow:0 15px 32px rgba(15,23,42,.2)}.profile-avatar-pro img{width:100%;height:100%;object-fit:cover}.hero-profile-pro b{display:block}.hero-profile-pro span{display:block;color:#dbeafe;font-size:12px;margin-top:3px}.status-dot{display:inline-flex;padding:7px 10px;border-radius:999px;font-style:normal;font-weight:900;font-size:12px;background:rgba(255,255,255,.18);color:#fff}.status-dot.active{background:#dcfce7;color:#166534}.status-dot.done{background:#dbeafe;color:#1d4ed8}.status-dot.wait{background:#fef3c7;color:#92400e}.quick-menu-pro{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.quick-menu-pro a{background:#fff;border:1px solid #dbeafe;border-radius:20px;padding:15px;box-shadow:0 12px 28px rgba(15,23,42,.06);display:grid;gap:6px;min-height:126px;transition:.18s}.quick-menu-pro a:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(15,23,42,.10)}.quick-menu-pro i{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,#dbeafe,#eef2ff);display:grid;place-items:center;font-style:normal;font-size:22px}.quick-menu-pro b{font-size:14px}.quick-menu-pro span{font-size:12px;color:#64748b;font-weight:800}.attendance-today-pro,.modern-card-pro{background:rgba(255,255,255,.92);border:1px solid #dbeafe;border-radius:24px;padding:18px;box-shadow:0 14px 32px rgba(15,23,42,.07)}.section-title-pro{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.section-title-pro b{display:block;font-size:17px}.section-title-pro span{display:block;color:#64748b;font-size:12px;margin-top:3px}.section-title-pro a{font-weight:900;color:#1d4ed8;background:#eff6ff;border-radius:999px;padding:8px 11px;font-size:12px}.timeline-pro{display:grid;grid-template-columns:1fr 42px 1fr;align-items:center;gap:6px}.time-node{border:1px solid #e2e8f0;background:#f8fafc;border-radius:20px;padding:15px}.time-node.on{background:#ecfdf5;border-color:#86efac}.time-node i{display:block;font-style:normal;color:#64748b;font-weight:900;font-size:12px}.time-node b{display:block;font-size:28px;margin:5px 0}.time-node span{display:block;color:#64748b;font-size:12px;font-weight:800}.time-line{height:4px;border-radius:999px;background:linear-gradient(90deg,#2563eb,#7c3aed)}.dashboard-grid-pro{display:grid;grid-template-columns:1fr 1fr;gap:16px}.mini-stats-pro{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.mini-stats-pro div{background:#f8fbff;border:1px solid #e2e8f0;border-radius:18px;padding:13px}.mini-stats-pro span{font-size:12px;color:#64748b;font-weight:900}.mini-stats-pro b{display:block;font-size:24px;margin-top:5px}.mini-stats-pro small{color:#64748b;font-weight:800}.info-strip-pro{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:center;background:#eff6ff;border-radius:16px;padding:12px;margin-top:12px}.info-strip-pro span,.info-strip-pro em{color:#64748b;font-size:12px;font-style:normal;font-weight:800}.info-strip-pro b{color:#1e3a8a}.salary-card-pro{background:linear-gradient(180deg,#fff,#f8fbff)}.salary-big-pro{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border-radius:20px;padding:16px;margin-bottom:12px}.salary-big-pro span{display:block;color:#dbeafe;font-weight:800;font-size:12px}.salary-big-pro b{display:block;font-size:26px;margin-top:4px}.salary-list-pro{display:grid;gap:8px}.salary-list-pro p{display:flex;justify-content:space-between;gap:10px;margin:0;border-bottom:1px dashed #dbeafe;padding:8px 0}.salary-list-pro span{color:#64748b;font-weight:800}.announcement-pro{margin-top:0}.announcement-item-pro{display:flex;justify-content:space-between;gap:12px;border:1px solid #e2e8f0;background:#f8fbff;border-radius:18px;padding:13px;margin-bottom:10px}.announcement-item-pro b{display:block}.announcement-item-pro p{margin:5px 0 0;color:#475569}.announcement-item-pro>span{flex:0 0 auto;background:#e0e7ff;color:#1d4ed8;border-radius:12px;padding:7px 9px;font-weight:900;font-size:12px;align-self:flex-start}@media (max-width:1100px){.employee-hero-pro{grid-template-columns:1fr}.quick-menu-pro{grid-template-columns:repeat(3,1fr)}.dashboard-grid-pro{grid-template-columns:1fr}}@media (max-width:800px){.employee-dashboard-pro{gap:12px}.employee-hero-pro{border-radius:22px;padding:18px}.employee-hero-pro h1{font-size:25px}.hero-action-row{display:grid;grid-template-columns:1fr 1fr}.hero-profile-pro{grid-template-columns:auto 1fr;justify-items:start;text-align:left;border-radius:20px}.profile-avatar-pro{width:62px;height:62px;border-radius:20px;font-size:26px}.status-dot{grid-column:1 / -1}.quick-menu-pro{grid-template-columns:repeat(3,1fr);gap:9px}.quick-menu-pro a{min-height:106px;padding:12px;border-radius:17px}.quick-menu-pro i{width:40px;height:40px;border-radius:14px;font-size:19px}.quick-menu-pro b{font-size:12px}.quick-menu-pro span{font-size:11px}.attendance-today-pro,.modern-card-pro{border-radius:20px;padding:14px}.section-title-pro b{font-size:15px}.timeline-pro{grid-template-columns:1fr;gap:9px}.time-line{height:3px}.time-node b{font-size:23px}.mini-stats-pro{grid-template-columns:1fr 1fr}.mini-stats-pro div:last-child{grid-column:1 / -1}.info-strip-pro{grid-template-columns:1fr}.salary-big-pro b{font-size:22px}.announcement-item-pro{display:block}.announcement-item-pro>span{display:inline-flex;margin-top:10px}.hero-action-row .btn{width:100%}}@media (max-width:420px){.quick-menu-pro{grid-template-columns:repeat(2,1fr)}.hero-action-row{grid-template-columns:1fr}}

/* V19 - Rata tengah menu beranda portal karyawan */
.quick-menu-pro a{
  justify-items:center;
  align-content:center;
  text-align:center;
  place-items:center;
}
.quick-menu-pro i{
  margin:0 auto;
}
.quick-menu-pro b,
.quick-menu-pro span{
  display:block;
  width:100%;
  text-align:center;
}
@media (max-width:800px){
  .quick-menu-pro a{
    justify-items:center;
    align-content:center;
    text-align:center;
  }
}

.employee-info-card-pro{overflow:hidden}.employee-info-list-pro{display:grid;gap:9px}.employee-info-list-pro p{margin:0;display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid #e2e8f0;background:linear-gradient(180deg,#ffffff,#f8fbff);border-radius:16px;padding:12px}.employee-info-list-pro span{font-size:12px;color:#64748b;font-weight:900}.employee-info-list-pro b{font-size:13px;color:#0f172a;text-align:right}


.dashboard-grid-pro{grid-template-columns:1fr!important}


/* V24 - Beranda portal karyawan sangat mewah + input uang otomatis */
.money-input{font-weight:900;text-align:right;letter-spacing:.03em;background:linear-gradient(180deg,#ffffff,#f8fbff)!important;border-color:#bfdbfe!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.75),0 8px 18px rgba(37,99,235,.06)!important}.money-input:focus{border-color:#7c3aed!important;box-shadow:0 0 0 4px rgba(124,58,237,.12),0 12px 26px rgba(37,99,235,.10)!important}
.employee-dashboard-pro{position:relative;isolation:isolate;border-radius:32px;padding:8px;background:radial-gradient(circle at 0% 0%,rgba(59,130,246,.18),transparent 31%),radial-gradient(circle at 100% 7%,rgba(236,72,153,.16),transparent 30%),radial-gradient(circle at 50% 110%,rgba(245,158,11,.14),transparent 35%)}
.employee-dashboard-pro:before{content:"";position:absolute;inset:-18px;z-index:-1;background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(124,58,237,.13),rgba(244,114,182,.12));filter:blur(32px);border-radius:42px;opacity:.9;pointer-events:none}.employee-dashboard-pro>*{position:relative;z-index:1}
.employee-hero-pro{min-height:245px;border-radius:34px;padding:28px;background:linear-gradient(132deg,#06112d 0%,#172554 23%,#1d4ed8 52%,#7c3aed 78%,#db2777 115%);border:1px solid rgba(255,255,255,.20);box-shadow:0 32px 80px rgba(29,78,216,.32),inset 0 1px 0 rgba(255,255,255,.20)}
.employee-hero-pro:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.14),transparent 30%,rgba(255,255,255,.09) 70%,transparent),radial-gradient(circle at 78% 22%,rgba(251,191,36,.35),transparent 18%),radial-gradient(circle at 22% 92%,rgba(96,165,250,.24),transparent 24%);pointer-events:none}.employee-hero-pro:after{content:"";position:absolute;width:260px;height:260px;right:-100px;bottom:-120px;background:conic-gradient(from 90deg,#fbbf24,#ec4899,#60a5fa,#22c55e,#fbbf24);border-radius:999px;filter:blur(28px);opacity:.34;pointer-events:none}.hero-bg-orb.one{background:#38bdf8;opacity:.50;filter:blur(14px)}.hero-bg-orb.two{background:#fbbf24;opacity:.35;filter:blur(16px)}
.hero-kicker{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.34);box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 12px 24px rgba(15,23,42,.15);backdrop-filter:blur(14px)}.employee-hero-pro h1{font-size:36px;letter-spacing:-.045em;text-shadow:0 10px 30px rgba(0,0,0,.28)}.employee-hero-pro p{color:#eef2ff;font-weight:650}.hero-action-row .btn{border-radius:18px;padding:13px 16px;box-shadow:0 14px 28px rgba(15,23,42,.20)}.hero-action-row .btn.primary{background:linear-gradient(135deg,#22c55e,#16a34a 48%,#0f766e);box-shadow:0 16px 32px rgba(34,197,94,.26)}.btn.soft-white{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.38);backdrop-filter:blur(12px)}
.hero-profile-pro{background:linear-gradient(180deg,rgba(255,255,255,.20),rgba(255,255,255,.10));border-color:rgba(255,255,255,.28);box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 24px 48px rgba(15,23,42,.17)}.profile-avatar-pro{border-radius:32px;background:linear-gradient(135deg,#fff 0%,#dbeafe 50%,#fce7f3 100%);box-shadow:0 22px 44px rgba(15,23,42,.28),0 0 0 6px rgba(255,255,255,.12)}.status-dot{box-shadow:0 10px 22px rgba(15,23,42,.12)}
.quick-menu-pro{gap:14px}.quick-menu-pro a{position:relative;overflow:hidden;min-height:136px;border-radius:26px;background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(239,246,255,.92));border:1px solid rgba(191,219,254,.95);box-shadow:0 18px 38px rgba(15,23,42,.09),inset 0 1px 0 rgba(255,255,255,.95)}.quick-menu-pro a:before{content:"";position:absolute;inset:auto -40px -65px auto;width:135px;height:135px;border-radius:999px;background:linear-gradient(135deg,rgba(37,99,235,.16),rgba(236,72,153,.18));transition:.25s}.quick-menu-pro a:after{content:"";position:absolute;left:16px;right:16px;top:0;height:3px;border-radius:999px;background:linear-gradient(90deg,#22c55e,#3b82f6,#a855f7,#ec4899);opacity:.85}.quick-menu-pro a:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 26px 54px rgba(15,23,42,.14)}.quick-menu-pro a:hover:before{transform:scale(1.18);opacity:.95}.quick-menu-pro i{position:relative;z-index:1;width:54px;height:54px;border-radius:20px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;box-shadow:0 16px 30px rgba(37,99,235,.25);font-size:24px}.quick-menu-pro a:nth-child(2) i{background:linear-gradient(135deg,#06b6d4,#2563eb)}.quick-menu-pro a:nth-child(3) i{background:linear-gradient(135deg,#f59e0b,#ef4444)}.quick-menu-pro a:nth-child(4) i{background:linear-gradient(135deg,#22c55e,#0d9488)}.quick-menu-pro a:nth-child(5) i{background:linear-gradient(135deg,#a855f7,#ec4899)}.quick-menu-pro a:nth-child(6) i{background:linear-gradient(135deg,#0f172a,#475569)}.quick-menu-pro b{position:relative;z-index:1;font-size:15px;color:#0f172a}.quick-menu-pro span{position:relative;z-index:1;color:#64748b}
.attendance-today-pro,.modern-card-pro{border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,251,255,.94));border:1px solid rgba(191,219,254,.95);box-shadow:0 22px 48px rgba(15,23,42,.08),inset 0 1px 0 rgba(255,255,255,.95)}.section-title-pro b{font-size:18px;letter-spacing:-.02em}.section-title-pro a{background:linear-gradient(135deg,#dbeafe,#eef2ff);box-shadow:0 10px 20px rgba(37,99,235,.10)}.timeline-pro{gap:12px}.time-node{position:relative;overflow:hidden;border-radius:24px;background:linear-gradient(145deg,#ffffff,#f8fbff);border-color:#dbeafe;box-shadow:0 14px 28px rgba(15,23,42,.06)}.time-node:before{content:"";position:absolute;width:110px;height:110px;right:-45px;top:-45px;border-radius:999px;background:rgba(37,99,235,.08)}.time-node.on{background:linear-gradient(145deg,#ecfdf5,#ffffff);border-color:#86efac}.time-node b{letter-spacing:-.04em}.time-line{height:6px;background:linear-gradient(90deg,#22c55e,#3b82f6,#7c3aed);box-shadow:0 8px 18px rgba(37,99,235,.18)}.mini-stats-pro div{border-radius:22px;background:linear-gradient(145deg,#ffffff,#f8fbff);box-shadow:inset 0 1px 0 #fff,0 12px 24px rgba(15,23,42,.05)}.mini-stats-pro b{font-size:28px;color:#1d4ed8}.announcement-pro{background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,251,235,.60))}.announcement-item-pro{border-radius:22px;background:linear-gradient(145deg,#fff,#f8fbff);box-shadow:0 10px 22px rgba(15,23,42,.05)}.announcement-item-pro>span{background:linear-gradient(135deg,#dbeafe,#fce7f3);color:#1d4ed8}
@media (max-width:800px){.employee-dashboard-pro{padding:3px;border-radius:24px}.employee-hero-pro{border-radius:28px;padding:21px;min-height:auto}.employee-hero-pro h1{font-size:29px}.hero-profile-pro{background:rgba(255,255,255,.16)}.quick-menu-pro{grid-template-columns:repeat(3,1fr);gap:10px}.quick-menu-pro a{min-height:118px;border-radius:22px}.quick-menu-pro i{width:46px;height:46px;border-radius:18px}.attendance-today-pro,.modern-card-pro{border-radius:24px}.mini-stats-pro b{font-size:24px}}@media (max-width:420px){.quick-menu-pro{grid-template-columns:repeat(2,1fr)}.employee-hero-pro h1{font-size:27px}}


.wa-panel-inline{background:linear-gradient(135deg,#dcfce7,#ecfeff);border:1px solid #bbf7d0;border-radius:18px;padding:15px}.wa-panel-inline h3{margin:0 0 4px;color:#166534}.wa-panel-inline p{margin:0;color:#047857;font-weight:700}
