*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f8fafc;--bg2: #ffffff;--bg3: #f1f5f9;--surface: #f8fafc;--surface2: #f1f5f9;--border: #e2e8f0;--text: #0f172a;--text2: #334155;--text3: #64748b;--green: #16a34a;--green-dim: rgba(22,163,74,.1);--red: #dc2626;--red-dim: rgba(220,38,38,.1);--blue: #2563eb;--blue-dim: rgba(37,99,235,.1);--purple: #9333ea;--orange: #ea580c;--teal: #0d9488;--yellow: #ca8a04;--sidebar-w: 300px;--topbar-h: 58px;--radius: 12px;--shadow: 0 4px 12px rgba(0,0,0,.05)}html,body{height:100%;font-family:Inter,sans-serif;background:var(--bg);color:var(--text);overflow:hidden}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:200;transform:translate(0);transition:transform .28s cubic-bezier(.4,0,.2,1);overflow-y:auto}.sidebar.collapsed{transform:translate(calc(-1 * var(--sidebar-w)))}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:18px 16px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.logo{display:flex;align-items:center;gap:10px}.logo-icon{font-size:26px}.logo-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:15px;color:var(--text)}.logo-sub{font-size:11px;color:var(--text3);margin-top:1px}.sidebar-close{display:none;background:none;border:none;color:var(--text2);font-size:18px;cursor:pointer;padding:4px}.sidebar-nav{padding:10px 10px 0;flex-shrink:0}.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:8px;background:none;border:none;color:var(--text2);font-family:inherit;font-size:13.5px;font-weight:500;cursor:pointer;transition:all .18s;text-align:left;margin-bottom:2px}.nav-item:hover{background:var(--surface);color:var(--text)}.nav-item.active{background:var(--blue-dim);color:var(--blue)}.nav-icon{font-size:16px}.nav-divider{height:1px;background:var(--border);margin:8px 12px}.nav-login{color:var(--text3)}.nav-login.logged-in{color:var(--green)}.filter-panel{padding:14px 14px 20px;flex:1}.filter-title{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:var(--text);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.filter-reset{background:none;border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:3px 8px;font-size:11px;cursor:pointer}.filter-reset:hover{border-color:var(--red);color:var(--red)}.filter-group{margin-bottom:14px}.filter-label{display:block;font-size:11.5px;color:var(--text3);margin-bottom:6px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.filter-input,.filter-select{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:13px;padding:8px 10px;outline:none;transition:border-color .18s}.filter-input:focus,.filter-select:focus{border-color:var(--blue)}.filter-select option{background:var(--bg3)}.filter-chips{display:flex;flex-wrap:wrap;gap:6px}.chip{padding:4px 10px;border-radius:20px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:12px;cursor:pointer;transition:all .18s;font-family:inherit}.chip.active{border-color:var(--blue);background:var(--blue-dim);color:var(--blue)}.chip-nib.active{border-color:var(--green);background:var(--green-dim);color:var(--green)}.chip-belum.active{border-color:var(--red);background:var(--red-dim);color:var(--red)}.range-row{display:flex;align-items:center;gap:6px}.filter-input-sm{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:13px;padding:7px 8px;outline:none;width:100%}.filter-input-sm:focus{border-color:var(--blue)}.btn-apply{width:100%;padding:10px;background:var(--blue);border:none;border-radius:8px;color:#fff;font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;margin-top:4px;transition:opacity .18s}.btn-apply:hover{opacity:.88}.main-wrapper{margin-left:var(--sidebar-w);height:100vh;display:flex;flex-direction:column;transition:margin-left .28s cubic-bezier(.4,0,.2,1)}.main-wrapper.expanded{margin-left:0}.topbar{height:var(--topbar-h);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0;gap:12px}.topbar-left{display:flex;align-items:center;gap:12px}.menu-toggle{background:none;border:1px solid var(--border);color:var(--text2);border-radius:8px;padding:6px 10px;font-size:18px;cursor:pointer;transition:all .18s}.menu-toggle:hover{background:var(--surface);color:var(--text)}.topbar-title{display:flex;align-items:center;gap:10px}.topbar-title span:first-child{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:15px}.topbar-badge{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:2px 10px;font-size:11.5px;color:var(--text2)}.topbar-right{display:flex;align-items:center}.kpi-mini{display:flex;gap:12px}.kpi-mini-item{display:flex;flex-direction:column;align-items:flex-end}.kpi-num{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:16px;line-height:1}.kpi-lbl{font-size:10.5px;color:var(--text3)}.kpi-green .kpi-num{color:var(--green)}.kpi-red .kpi-num{color:var(--red)}.view-section{display:none;flex:1;overflow:hidden}.view-section.active{display:flex;flex-direction:column}#map{flex:1;z-index:1}.map-legend{position:absolute;bottom:30px;right:16px;z-index:500;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow)}.legend-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text2)}.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.dot-nib{background:var(--green);box-shadow:0 0 8px var(--green)}.dot-belum{background:var(--red);box-shadow:0 0 8px var(--red)}.map-overlay{position:absolute;top:calc(var(--topbar-h) + 12px);right:16px;z-index:500;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:10px 16px;display:flex;gap:16px;box-shadow:var(--shadow)}.overlay-item{display:flex;flex-direction:column;align-items:center}.overlay-item span{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:18px;color:var(--text)}.overlay-item small{font-size:10.5px;color:var(--text3)}.leaflet-container{background:#e5e7eb;font-family:Inter,sans-serif}.leaflet-popup-content-wrapper{background:var(--bg2);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);color:var(--text)}.leaflet-popup-tip{background:var(--bg2);border-bottom:1px solid var(--border);border-right:1px solid var(--border)}.leaflet-popup-content{margin:12px 14px}.popup-title{font-weight:700;font-size:13.5px;margin-bottom:6px;color:var(--text)}.popup-row{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:var(--text2);margin-bottom:3px}.popup-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.popup-badge.nib{background:var(--green-dim);color:var(--green)}.popup-badge.belum{background:var(--red-dim);color:var(--red)}.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background:#3b82f633!important}.marker-cluster-small div,.marker-cluster-medium div,.marker-cluster-large div{background:#3b82f699!important;color:#fff!important;font-weight:700}#viewStats,#viewMasalah,#viewRegistrasi{overflow-y:auto}.stats-container{padding:20px;width:100%}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:24px}.kpi-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:18px 16px;display:flex;align-items:center;gap:14px;transition:transform .18s,box-shadow .18s}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.kpi-icon{font-size:28px;flex-shrink:0}.kpi-value{font-family:Plus Jakarta Sans,sans-serif;font-weight:800;font-size:22px;line-height:1}.kpi-label{font-size:12px;color:var(--text2);margin-top:4px}.kpi-card-blue{border-left:3px solid var(--blue)}.kpi-card-blue .kpi-value{color:var(--blue)}.kpi-card-green{border-left:3px solid var(--green)}.kpi-card-green .kpi-value{color:var(--green)}.kpi-card-red{border-left:3px solid var(--red)}.kpi-card-red .kpi-value{color:var(--red)}.kpi-card-purple{border-left:3px solid var(--purple)}.kpi-card-purple .kpi-value{color:var(--purple)}.kpi-card-orange{border-left:3px solid var(--orange)}.kpi-card-orange .kpi-value{color:var(--orange)}.kpi-card-teal{border-left:3px solid var(--teal)}.kpi-card-teal .kpi-value{color:var(--teal)}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.chart-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.chart-full{grid-column:1 / -1}.chart-title{font-weight:600;font-size:13.5px;margin-bottom:14px;color:var(--text)}.chart-wrap{position:relative;height:220px}.chart-wrap-tall{height:280px}#viewTable{overflow:hidden}.table-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;gap:10px}.table-info{font-size:13px;color:var(--text2)}.table-actions{display:flex;gap:8px}.btn-action{padding:7px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text2);font-family:inherit;font-size:12.5px;cursor:pointer;transition:all .18s}.btn-action:hover{background:var(--surface2);color:var(--text)}.btn-action.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff}.btn-action.btn-primary:hover{opacity:.88}.table-wrapper{flex:1;overflow:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:var(--bg3);color:var(--text2);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:10px 12px;text-align:left;position:sticky;top:0;z-index:10;border-bottom:1px solid var(--border);white-space:nowrap}.data-table th[data-sort]{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th[data-sort]:hover{color:var(--text)}.data-table th.sorted-asc:after{content:" ↑";color:var(--blue)}.data-table th.sorted-desc:after{content:" ↓";color:var(--blue)}.data-table td{padding:9px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.data-table tr:hover td{background:var(--surface)}.table-loading{text-align:center;color:var(--text3);padding:40px!important}.col-actions{width:80px;text-align:center}.badge{display:inline-block;padding:3px 8px;border-radius:10px;font-size:11px;font-weight:600;white-space:nowrap}.badge-nib{background:var(--green-dim);color:var(--green)}.badge-belum{background:var(--red-dim);color:var(--red)}.badge-hak-pengelolaan{background:#3b82f61f;color:var(--blue)}.badge-hak-pakai{background:#a855f71f;color:var(--purple)}.btn-icon{background:none;border:1px solid var(--border);border-radius:6px;padding:4px 7px;cursor:pointer;font-size:13px;transition:all .18s;color:var(--text2)}.btn-icon:hover{background:var(--surface)}.btn-icon-edit:hover{border-color:var(--blue);color:var(--blue)}.btn-icon-del:hover{border-color:var(--red);color:var(--red)}.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-top:1px solid var(--border);background:var(--bg2);flex-shrink:0}.page-btn{padding:5px 11px;border-radius:7px;border:1px solid var(--border);background:var(--surface);color:var(--text2);font-family:inherit;font-size:12.5px;cursor:pointer;transition:all .18s}.page-btn:hover{background:var(--surface2);color:var(--text)}.page-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}.page-btn:disabled{opacity:.4;cursor:not-allowed}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-backdrop.open{display:flex}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:16px;width:100%;max-width:720px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0009;animation:modalIn .22s ease}.modal-sm{max-width:420px}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:none}}.modal-header{padding:18px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:16px}.modal-close{background:none;border:none;color:var(--text3);font-size:18px;cursor:pointer;padding:2px}.modal-close:hover{color:var(--text)}.modal-body{padding:18px 20px;overflow-y:auto;flex:1}.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-full{grid-column:1 / -1}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:12px;color:var(--text2);font-weight:500}.form-input{background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:13.5px;padding:9px 11px;outline:none;transition:border-color .18s;width:100%}.form-input:focus{border-color:var(--blue)}textarea.form-input{resize:vertical;min-height:60px}.form-hint{font-size:11px;color:var(--text3)}.form-error{background:var(--red-dim);border:1px solid var(--red);border-radius:8px;padding:8px 12px;font-size:12.5px;color:var(--red);margin-top:8px}.form-status-preview{margin-top:14px;padding:10px 12px;background:var(--bg3);border-radius:8px;display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text2)}.btn-cancel,.btn-save,.btn-danger{padding:9px 20px;border-radius:9px;border:none;font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;transition:opacity .18s}.btn-cancel{background:var(--surface);border:1px solid var(--border);color:var(--text2)}.btn-cancel:hover{background:var(--surface2)}.btn-save{background:var(--blue);color:#fff}.btn-save:hover{opacity:.88}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{opacity:.88}.text-muted{color:var(--text3);font-size:13px;margin-top:6px}.toast-container{position:fixed;bottom:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}.toast{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 16px;font-size:13px;color:var(--text);box-shadow:var(--shadow);max-width:320px;animation:toastIn .25s ease;display:flex;align-items:center;gap:8px}.toast.success{border-left:3px solid var(--green)}.toast.error{border-left:3px solid var(--red)}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}@media (max-width: 900px){:root{--sidebar-w: 280px}.sidebar{transform:translate(calc(-1 * var(--sidebar-w)))}.sidebar.open{transform:translate(0)}.sidebar-close{display:block}.main-wrapper{margin-left:0!important}.kpi-mini{display:none}.charts-grid,.form-grid{grid-template-columns:1fr}.form-full{grid-column:1}}@media (max-width: 600px){.map-overlay{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr)}}.chart-title-group{margin-bottom:12px}.chart-subtitle{font-size:12px;color:#5f6b85;margin-top:2px}
