:root{--navy: #1E3A5F;--navy-d: #0F2440;--navy-50: #EFF6FF;--gold: #C9A227;--gold-50: #FEFCE8;--teal: #0D9488;--ink: #1E293B;--fg: #334155;--muted: #64748B;--border: #E2E8F0;--border-l: #F1F5F9;--white: #FFFFFF;--bg: #F8FAFC;--surface: #FFFFFF;--red: #DC2626;--red-50: #FEF2F2;--green: #16A34A;--blue: #2563EB;--amber: #D97706;--topbar-h: 56px;--sidebar-w: 320px;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 18px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow: 0 4px 16px rgba(0,0,0,.07);--shadow-lg: 0 12px 40px rgba(0,0,0,.12);--transition: .28s cubic-bezier(.25, .1, .25, 1)}@media (prefers-color-scheme: dark){:root{--navy: #3B82F6;--navy-d: #1E3A5F;--navy-50: #1E293B;--gold: #F59E0B;--gold-50: #1C1917;--ink: #F1F5F9;--fg: #CBD5E1;--muted: #94A3B8;--border: #334155;--border-l: #1E293B;--white: #0F172A;--bg: #020617;--surface: #0F172A;--red-50: #1C0A0A;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow: 0 4px 16px rgba(0,0,0,.3);--shadow-lg: 0 12px 40px rgba(0,0,0,.4)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:.8125rem;line-height:1.6;color:var(--fg);background:var(--bg);height:100vh;overflow:hidden}#root{height:100vh;display:flex;flex-direction:column}::selection{background:var(--navy);color:var(--white)}:focus-visible{outline:2px solid var(--navy);outline-offset:2px}h1,h2,h3,h4{color:var(--ink);line-height:1.2;letter-spacing:-.02em}h1{font-size:1.125rem;font-weight:700}h2{font-size:1rem;font-weight:700}h3{font-size:.8125rem;font-weight:600}.label{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.muted{color:var(--muted)}#topbar{height:var(--topbar-h);background:var(--navy-d);display:flex;align-items:center;padding:0 20px;gap:16px;z-index:1000;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.06)}.logo-area{display:flex;align-items:center;gap:10px}.logo-icon{font-size:20px}#topbar h1{color:var(--white);font-size:.8125rem;font-weight:600;letter-spacing:-.01em}#topbar h1 span{display:block;font-size:.625rem;font-weight:400;color:#fff6;letter-spacing:.02em}.topbar-right{display:flex;align-items:center;gap:10px;margin-left:auto}.role-badge{background:var(--gold);color:var(--navy-d);padding:2px 10px;border-radius:var(--radius-sm);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);font-size:.75rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background var(--transition),color var(--transition),border-color var(--transition),transform var(--transition),box-shadow var(--transition);white-space:nowrap}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.45;cursor:default;transform:none}.btn-outline{background:transparent;border-color:var(--border);color:var(--fg)}.btn-outline:hover{background:var(--border-l);border-color:var(--muted)}.btn-primary{background:var(--navy-d);color:var(--white)}.btn-primary:hover{background:var(--navy);box-shadow:var(--shadow-sm)}.btn-gold{background:var(--gold);color:var(--white)}.btn-gold:hover{box-shadow:var(--shadow-sm);filter:brightness(1.08)}.btn-teal{background:var(--teal);color:var(--white)}.btn-teal:hover{box-shadow:var(--shadow-sm);filter:brightness(1.08)}.btn-danger{background:var(--red-50);color:var(--red);border-color:transparent}.btn-danger:hover{background:var(--red);color:var(--white)}.btn-icon{width:32px;height:32px;padding:0;justify-content:center;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);color:var(--fg);cursor:pointer;transition:background var(--transition),color var(--transition),transform var(--transition);display:grid;place-items:center}.btn-icon:hover{background:var(--border-l);transform:translateY(-1px)}.btn-icon-danger{color:var(--red)}.btn-icon-danger:hover{background:var(--red-50);color:var(--red)}.btn-logout{color:#fff9!important;border-color:#ffffff26!important;font-size:.6875rem}.btn-logout:hover{color:var(--white)!important;border-color:#ffffff4d!important;background:#ffffff0f!important}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--navy-d);display:flex;align-items:center;justify-content:center;z-index:9999;overflow:hidden}.login-screen:before{content:"";position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;background:radial-gradient(circle at 30% 40%,rgba(59,130,246,.15),transparent 60%),radial-gradient(circle at 70% 80%,rgba(201,162,39,.1),transparent 50%);animation:login-glow 8s ease-in-out infinite alternate}@keyframes login-glow{0%{transform:translate(0) scale(1)}to{transform:translate(-2%,-3%) scale(1.05)}}.login-card{position:relative;background:var(--surface);border-radius:var(--radius-xl);padding:48px 40px 40px;width:100%;max-width:400px;box-shadow:var(--shadow-lg);text-align:center;animation:login-enter .5s cubic-bezier(.16,1,.3,1)}@keyframes login-enter{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card .icon-box{font-size:2rem;margin-bottom:16px}.login-card h1{font-size:1.125rem;color:var(--ink);margin-bottom:2px}.login-card .sub{font-size:.75rem;color:var(--muted);margin-bottom:32px}.login-card label{display:block;font-size:.6875rem;font-weight:600;color:var(--muted);margin-bottom:6px;text-align:left;text-transform:uppercase;letter-spacing:.05em}.login-card select{width:100%;padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border);font-size:.875rem;color:var(--ink);margin-bottom:20px;background:var(--surface);transition:border-color var(--transition)}.login-card select:focus{border-color:var(--navy)}.login-error{color:var(--red);font-size:.75rem;margin-bottom:8px;display:none}.login-note{font-size:.6875rem;color:var(--muted);margin-top:20px;line-height:1.5}.admin-app{display:flex;flex-direction:column;height:100vh}#main{flex:1;display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:calc(100vh - var(--topbar-h))}#sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}.sidebar-section{padding:20px;border-bottom:1px solid var(--border-l)}.sidebar-section:last-child{border-bottom:none}.sidebar-section h2{font-size:.875rem;color:var(--ink);margin-bottom:14px;display:flex;align-items:center;gap:8px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}.stat-card{background:var(--bg);border:1px solid var(--border-l);border-radius:var(--radius);padding:12px 10px;text-align:center;transition:transform var(--transition),box-shadow var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.stat-card .val{font-size:1.375rem;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;line-height:1}.stat-card .lbl{font-size:.625rem;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.04em}.stat-card.accent{background:var(--navy-d);border-color:transparent}.stat-card.accent .val{color:var(--gold)}.stat-card.accent .lbl{color:#ffffff80}.progress-bar-wrap{height:5px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:6px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--gold),#EAB308);border-radius:3px;transition:width .6s cubic-bezier(.16,1,.3,1)}.completion-text{font-size:.625rem;color:var(--muted);font-variant-numeric:tabular-nums}.legend{display:flex;flex-direction:column;gap:4px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.75rem;cursor:pointer;padding:5px 8px;border-radius:var(--radius-sm);transition:background var(--transition),color var(--transition)}.legend-item:hover{background:var(--border-l)}.legend-item.active{font-weight:700;background:var(--navy-50);color:var(--navy)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.search-wrap{position:relative}.search-wrap .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.search-input{width:100%;padding:8px 12px 8px 34px;border-radius:var(--radius);border:1px solid var(--border);font-size:.8125rem;color:var(--ink);background:var(--surface);transition:border-color var(--transition),box-shadow var(--transition)}.search-input::placeholder{color:var(--muted)}.search-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1e3a5f14}.parcel-list{display:flex;flex-direction:column}.parcel-item{display:flex;align-items:center;gap:10px;padding:10px 20px;cursor:pointer;border-bottom:1px solid var(--border-l);transition:background var(--transition),padding-left var(--transition)}.parcel-item:hover{background:var(--bg)}.parcel-item.active{background:var(--navy-50);border-left:3px solid var(--navy);padding-left:17px}.parcel-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.parcel-info{flex:1;min-width:0}.parcel-info h3{font-size:.8125rem;color:var(--ink);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.parcel-info p{font-size:.6875rem;color:var(--muted);margin-top:1px}.chip{font-size:.625rem;padding:2px 8px;border-radius:9999px;font-weight:700;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}#map-container{position:relative;overflow:hidden}#map{width:100%;height:100%}#map-toolbar{position:absolute;top:12px;right:12px;z-index:800;display:flex;flex-direction:column;gap:4px}.map-btn{width:32px;height:32px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);font-size:14px;cursor:pointer;display:grid;place-items:center;color:var(--fg);transition:background var(--transition),transform var(--transition)}.map-btn:hover{background:var(--border-l);transform:translateY(-1px)}#basemap-switcher{position:absolute;bottom:14px;left:14px;z-index:800;display:flex;gap:0;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--border)}.basemap-btn{padding:6px 14px;font-size:.6875rem;font-weight:500;border:none;background:var(--surface);color:var(--fg);cursor:pointer;transition:background var(--transition),color var(--transition);white-space:nowrap;border-right:1px solid var(--border)}.basemap-btn:last-child{border-right:none}.basemap-btn:hover{background:var(--bg)}.basemap-btn.active{background:var(--navy-d);color:var(--white);font-weight:600}.bottom-panel{position:absolute;bottom:0;left:0;right:0;z-index:900;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -4px 24px #00000014;transform:translateY(100%);transition:transform .35s cubic-bezier(.16,1,.3,1);max-height:45vh;overflow-y:auto;padding:16px 24px 20px}.bottom-panel.open{transform:translateY(0)}.panel-handle{display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);margin-bottom:12px;gap:6px;font-size:.75rem}.panel-handle svg{transition:transform var(--transition)}#panel-title{font-size:.9375rem;color:var(--ink);margin-bottom:16px;font-weight:700;letter-spacing:-.02em}.detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px 12px}.detail-field label{font-size:.625rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em;display:block}.detail-field p{font-size:.8125rem;color:var(--ink);margin-top:2px;font-weight:500}.detail-actions{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap}.detail-actions-spacer{flex:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:overlay-in .2s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-xl);width:90%;max-width:680px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modal-in .3s cubic-bezier(.16,1,.3,1)}@keyframes modal-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:20px 24px 14px;display:flex;align-items:center;gap:12px}.modal-header h2{flex:1;font-size:1rem;color:var(--ink)}.modal-close{width:28px;height:28px;border-radius:50%;border:none;background:var(--bg);cursor:pointer;color:var(--muted);display:grid;place-items:center;transition:background var(--transition),color var(--transition)}.modal-close:hover{background:var(--border);color:var(--ink)}.gold-line{width:3px;height:20px;background:var(--gold);border-radius:2px}.modal-body{padding:0 24px 24px}.cert-modal{max-width:740px}.cert-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:18px;border-bottom:2px solid var(--gold);margin-bottom:18px}.cert-logo .icon-box{font-size:1.5rem;margin-bottom:6px}.cert-logo .company{font-size:.9375rem;font-weight:700;color:var(--ink)}.cert-logo .sub{font-size:.6875rem;color:var(--muted)}.cert-badge{text-align:right}.cert-no{font-size:.8125rem;font-weight:700;color:var(--gold)}.cert-date{font-size:.625rem;color:var(--muted);margin-top:2px}.section-title{font-size:.75rem;font-weight:700;color:var(--ink);margin:20px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em}.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.info-field label{font-size:.625rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.info-field p{font-size:.8125rem;color:var(--ink);margin-top:2px;font-weight:500}.cert-footer{margin-top:28px;padding-top:18px;border-top:1px solid var(--border)}.cert-footer p{font-size:.6875rem;color:var(--muted);margin-bottom:14px}.cert-actions{display:flex;gap:8px;justify-content:flex-end}.pekerja-app{display:flex;flex-direction:column;height:100vh;background:var(--bg)}.laporan-page{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:32px 20px;overflow-y:auto}.laporan-card{background:var(--surface);border-radius:var(--radius-xl);padding:32px 36px;width:100%;max-width:720px;box-shadow:var(--shadow);border:1px solid var(--border-l)}.laporan-card h2{font-size:1.125rem;color:var(--ink);margin-bottom:4px;display:flex;align-items:center;gap:8px}.laporan-card .muted{font-size:.8125rem;color:var(--muted);margin-bottom:24px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-field label{display:block;font-size:.6875rem;font-weight:600;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}.form-field input,.form-field select,.form-field textarea{width:100%;padding:9px 12px;border-radius:var(--radius);border:1px solid var(--border);font-size:.8125rem;color:var(--ink);background:var(--surface);transition:border-color var(--transition),box-shadow var(--transition)}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--muted)}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1e3a5f14;outline:none}.form-field textarea{resize:vertical;min-height:72px}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.laporan-list-item{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border-l);transition:background var(--transition)}.laporan-list-item:last-child{border-bottom:none}.laporan-list-item:hover{background:var(--bg);margin:0 -8px;padding:12px 8px;border-radius:var(--radius)}.laporan-list-info{flex:1;min-width:0}.laporan-list-info .laporan-id{font-weight:700;font-size:.8125rem;color:var(--ink)}.laporan-list-info .laporan-meta{font-size:.6875rem;color:var(--muted);margin-top:2px}#toast{position:fixed;bottom:24px;right:24px;z-index:5000;display:flex;align-items:center;gap:10px;background:var(--navy-d);color:var(--white);padding:12px 20px;border-radius:var(--radius);font-size:.8125rem;font-weight:500;box-shadow:var(--shadow-lg);transform:translateY(80px);opacity:0;transition:transform .35s cubic-bezier(.16,1,.3,1),opacity .25s ease;pointer-events:none}#toast .toast-icon{flex-shrink:0}#toast.show{transform:translateY(0);opacity:1}@media (max-width: 1024px){#main{grid-template-columns:260px 1fr}:root{--sidebar-w: 260px}.detail-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){#main{grid-template-columns:1fr}#sidebar{display:none}.detail-grid{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:1fr}.laporan-card{padding:24px 20px}.login-card{margin:16px;padding:32px 24px}#basemap-switcher{bottom:8px;left:8px}.basemap-btn{padding:5px 10px;font-size:.625rem}}
