*,*: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(250px,1fr));gap:16px;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)}#kpiGrid{display:flex;flex-wrap:wrap;gap:16px}#kpiGrid>.kpi-card{flex:1 1 calc(20% - 16px);min-width:180px}#kpiGrid>.kpi-card-luas,#kpiGrid>.kpi-card-nilai{flex:1 1 calc(50% - 16px)}.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}@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}#splashScreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:linear-gradient(135deg,#f0f4ff,#fff,#f0fdf4);display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease}#splashScreen.hidden{opacity:0;visibility:hidden;pointer-events:none}.splash-inner{display:flex;flex-direction:column;align-items:center;gap:16px;animation:splashFadeIn .5s ease both}@keyframes splashFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}.splash-logo{position:relative;display:flex;align-items:center;justify-content:center;width:88px;height:88px}.splash-icon-wrap{width:72px;height:72px;border-radius:22px;background:linear-gradient(135deg,#2563eb,#4f46e5);display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff;position:relative;z-index:2;box-shadow:0 8px 32px #2563eb4d;animation:splashBob 2s ease-in-out infinite}@keyframes splashBob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.splash-pulse{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:30px;border:2px solid rgba(37,99,235,.3);animation:splashPulse 1.8s ease-out infinite}@keyframes splashPulse{0%{transform:scale(.9);opacity:.8}to{transform:scale(1.4);opacity:0}}.splash-title{font-family:Outfit,Plus Jakarta Sans,sans-serif;font-weight:800;font-size:28px;color:#0f172a;letter-spacing:-.5px}.splash-sub{font-size:14px;color:#64748b;font-weight:500}.splash-bar-wrap{width:260px;display:flex;flex-direction:column;gap:8px;align-items:center}.splash-bar{width:100%;height:4px;background:#e2e8f0;border-radius:99px;overflow:hidden}.splash-bar-fill{height:100%;width:0%;border-radius:99px;background:linear-gradient(90deg,#2563eb,#4f46e5,#7c3aed);background-size:200% 100%;transition:width .4s ease;animation:shimmer 1.5s linear infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.splash-status{font-size:12px;color:#94a3b8;font-weight:500}.kpi-card{animation:cardReveal .5s ease both;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s ease,border-color .2s ease}.kpi-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 12px 32px #00000017}@keyframes cardReveal{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}.kpi-card:nth-child(1){animation-delay:.05s}.kpi-card:nth-child(2){animation-delay:.1s}.kpi-card:nth-child(3){animation-delay:.15s}.kpi-card:nth-child(4){animation-delay:.2s}.kpi-card:nth-child(5){animation-delay:.25s}.kpi-card:nth-child(6){animation-delay:.3s}.kpi-card:nth-child(7){animation-delay:.35s}.kpi-value{transition:color .3s ease}.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:skeletonShimmer 1.4s linear infinite;border-radius:6px;color:transparent;min-height:1em}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.view-section.active{animation:viewIn .3s ease both}@keyframes viewIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.nav-item{position:relative;overflow:hidden}.nav-item:after{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--blue);border-radius:0 3px 3px 0;transition:height .25s cubic-bezier(.34,1.56,.64,1)}.nav-item.active:after{height:60%}.nav-item:not(.active):hover{transform:translate(3px)}.sidebar{box-shadow:4px 0 24px #0000000f}.topbar{box-shadow:0 2px 12px #0000000d}.topbar-badge{background:linear-gradient(135deg,var(--blue-dim),rgba(79,70,229,.1));border-color:#2563eb33;color:var(--blue);font-weight:600;animation:badgePop .4s cubic-bezier(.34,1.56,.64,1) both}@keyframes badgePop{0%{transform:scale(.8);opacity:0}to{transform:none;opacity:1}}.btn-apply{background:linear-gradient(135deg,#2563eb,#4f46e5);box-shadow:0 4px 12px #2563eb4d;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.btn-apply:hover{transform:translateY(-1px);box-shadow:0 6px 20px #2563eb66;opacity:1}.btn-apply:active{transform:translateY(0)}.btn-save{background:linear-gradient(135deg,#2563eb,#4f46e5);box-shadow:0 4px 12px #2563eb40;transition:transform .18s,box-shadow .18s}.btn-save:hover{transform:translateY(-1px);box-shadow:0 6px 20px #2563eb59;opacity:1}.chip{transition:all .2s cubic-bezier(.34,1.56,.64,1)}.chip:active{transform:scale(.94)}.toast{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;box-shadow:0 8px 32px #0000001f;border-radius:12px}.toast.success{border-left:3px solid var(--green)}.toast.error{border-left:3px solid var(--red)}@keyframes toastIn{0%{opacity:0;transform:translate(20px) scale(.95)}to{opacity:1;transform:none}}.modal{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@keyframes modalIn{0%{opacity:0;transform:scale(.94) translateY(16px)}to{opacity:1;transform:none}}.filter-input:focus,.filter-select:focus,.filter-input-sm:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1f}.form-input:focus{box-shadow:0 0 0 3px #2563eb1f}.data-table tbody tr{transition:background .15s ease}.data-table tbody tr:hover td{background:#2563eb0a}.kpi-card-blue{background:linear-gradient(to right,#2563eb0a,#fff)}.kpi-card-green{background:linear-gradient(to right,#16a34a0a,#fff)}.kpi-card-red{background:linear-gradient(to right,#dc26260a,#fff)}.kpi-card-purple{background:linear-gradient(to right,#9333ea0a,#fff)}.kpi-card-orange{background:linear-gradient(to right,#ea580c0a,#fff)}.kpi-card-teal{background:linear-gradient(to right,#0d94880a,#fff)}.lucide-spin{animation:lucideSpin 1s linear infinite}@keyframes lucideSpin{to{transform:rotate(360deg)}}
