/* shared.css */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Tema: Cool Slate (terang, biru-abu sejuk — lembut di mata) */
  --bg:#eef1f6;--bg2:#fbfcfe;--bg3:#e4e9f1;--bg4:#d8dfeb;
  --border:#dde3ed;--border2:#c5cedd;
  --text:#1f2a3d;--text2:#4a5468;--text3:#828da3;
  --gembok:#c87412;--gembok-bg:rgba(200,116,18,.13);
  --odp:#1f9d52;--odp-bg:rgba(31,157,82,.13);
  --jb:#2563eb;--jb-bg:rgba(37,99,235,.11);
  --perapihan:#8b3fd6;--perapihan-bg:rgba(139,63,214,.1);
  --accent:#3b6fe6;
}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;height:100vh;display:flex;flex-direction:column;overflow:hidden}

/* TOPBAR */
.topbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 20px;display:flex;align-items:center;gap:14px;height:52px;flex-shrink:0}
.logo{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text3);letter-spacing:.06em}
.logo b{color:var(--accent)}
.topbar-title{font-size:14px;font-weight:600}
.topbar-right{margin-left:auto;display:flex;gap:8px;align-items:center}
.btn{padding:6px 14px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;border:none;font-family:'DM Sans',sans-serif;transition:all .15s;display:flex;align-items:center;gap:5px;text-decoration:none}
.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(1.15)}
.btn-outline{background:transparent;color:var(--text2);border:1px solid var(--border2)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-green{background:rgba(74,222,128,.15);color:var(--odp);border:1px solid rgba(74,222,128,.3)}.btn-green:hover{background:rgba(74,222,128,.25)}
.btn-red{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(220,47,47,.28)}.btn-red:hover{background:rgba(220,47,47,.16)}

/* STATS BAR */
.statsbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 20px;display:flex;gap:4px;align-items:center;height:38px;flex-shrink:0;overflow-x:auto}
.stat{display:flex;align-items:center;gap:6px;padding:0 10px;border-right:1px solid var(--border);flex-shrink:0}
.stat:last-child{border-right:none}
.stat-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.stat-num{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:500}
.stat-lbl{font-size:10px;color:var(--text3)}
.stat-gembok .stat-num{color:var(--gembok)}
.stat-odp .stat-num{color:var(--odp)}
.stat-jb .stat-num{color:var(--jb)}
.stat-perapihan .stat-num{color:var(--perapihan)}

/* MAIN */
.main{display:flex;flex:1;overflow:hidden}

/* SIDEBAR */
.sidebar{width:280px;min-width:280px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.sidebar-top{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px;flex-shrink:0}
.search-wrap{position:relative;display:flex;align-items:center}
.search-icon{position:absolute;left:10px;color:var(--text3);pointer-events:none;width:14px;height:14px}
.search-input{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:7px 32px;color:var(--text);font-size:12px;font-family:'DM Sans',sans-serif;outline:none;transition:border-color .15s}
.search-input:focus{border-color:var(--accent)}
.search-input::placeholder{color:var(--text3)}
.search-clear{position:absolute;right:8px;color:var(--text3);cursor:pointer;font-size:16px;line-height:1;display:none;background:none;border:none;padding:2px}
.search-clear.visible{display:block}
.filter-chips{display:flex;gap:4px;flex-wrap:wrap}
.chip{padding:3px 8px;border-radius:20px;font-size:10px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);color:var(--text3);transition:all .15s;white-space:nowrap}
.chip.active-all{border-color:var(--text2);color:var(--text2);background:var(--bg4)}
.chip.active-Gembok{border-color:var(--gembok);color:var(--gembok);background:var(--gembok-bg)}
.chip.active-ODP{border-color:var(--odp);color:var(--odp);background:var(--odp-bg)}
.chip.active-JB{border-color:var(--jb);color:var(--jb);background:var(--jb-bg)}
.chip.active-Perapihan{border-color:var(--perapihan);color:var(--perapihan);background:var(--perapihan-bg)}

.results-bar{padding:6px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;min-height:28px}
.results-count{font-size:11px;color:var(--text3)}
.results-count b{color:var(--text2);font-weight:600}

/* ACCORDION */
.list-wrap{overflow-y:auto;flex:1}
.area-group{border-bottom:1px solid var(--border)}
.area-header{padding:9px 12px;cursor:pointer;display:flex;align-items:center;gap:7px;background:var(--bg3);transition:background .1s;user-select:none}
.area-header:hover{background:var(--bg4)}
.area-chevron{font-size:9px;color:var(--text3);flex-shrink:0;transition:transform .15s;width:12px}
.area-name{font-size:12px;font-weight:600;color:var(--text2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.area-count{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text3);flex-shrink:0}
.area-badges{display:flex;gap:3px;flex-shrink:0}
.area-items{display:none}
.area-group.open .area-items{display:block}
.point-row{padding:8px 12px 8px 28px;cursor:pointer;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:9px;transition:background .1s}
.point-row:last-child{border-bottom:none}
.point-row:hover{background:var(--bg3)}
.point-row.active{background:var(--bg4);border-left:3px solid var(--accent);padding-left:25px}
.pt-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:5px}
.pt-dot-Gembok{background:var(--gembok)}.pt-dot-ODP{background:var(--odp)}.pt-dot-JB{background:var(--jb)}.pt-dot-Perapihan{background:var(--perapihan)}
.pt-name{font-size:12px;font-weight:500;color:var(--text);line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:190px}
.pt-sub{font-size:10px;color:var(--text3);margin-top:2px;display:flex;gap:5px;align-items:center}
.badge{font-size:9.5px;padding:1px 6px;border-radius:9px;font-weight:700;display:inline-block;min-width:18px;text-align:center;line-height:1.5}
.bGembok{color:var(--gembok);background:var(--gembok-bg)}
.bODP{color:var(--odp);background:var(--odp-bg)}
.bJB{color:var(--jb);background:var(--jb-bg)}
.bPerapihan{color:var(--perapihan);background:var(--perapihan-bg)}
.no-results{padding:32px 16px;text-align:center;color:var(--text3);font-size:12px;display:flex;flex-direction:column;align-items:center;gap:8px}

/* PAGINATION */
.pagination{border-top:1px solid var(--border);padding:8px 12px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--bg2)}
.page-info{font-size:10px;color:var(--text3);font-family:'JetBrains Mono',monospace}
.page-btns{display:flex;gap:3px;align-items:center}
.page-btn{width:26px;height:26px;border-radius:5px;border:1px solid var(--border2);background:transparent;color:var(--text2);cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:'DM Sans',sans-serif}
.page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.page-btn:disabled{opacity:.3;cursor:not-allowed}
.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.page-dots{color:var(--text3);font-size:11px;padding:0 2px}

/* CONTENT */
.content{flex:1;overflow-y:auto;background:var(--bg);display:flex;flex-direction:column}
.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text3);text-align:center;gap:10px}
.empty-state svg{opacity:.2}

/* DETAIL */
.d-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:12px;background:var(--bg2);flex-shrink:0}
.d-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}
.d-title{font-size:14px;font-weight:600;line-height:1.3;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.d-sub{font-size:11px;color:var(--text3);margin-top:3px}
.d-right{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.coord-pill{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text2);background:var(--bg3);padding:3px 8px;border-radius:5px;border:1px solid var(--border2)}
.tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0}
.tab{padding:9px 16px;font-size:12px;font-weight:500;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}
.tab:hover{color:var(--text2)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-content{display:none;flex:1;overflow:hidden}
.tab-content.active{display:flex;flex-direction:column}
.photos-panel{padding:16px 20px;overflow-y:auto}
.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.photo-card{border-radius:10px;overflow:hidden;background:var(--bg3);border:1px solid var(--border);position:relative}
.photo-card img{width:100%;display:block;max-height:280px;object-fit:cover;cursor:pointer;transition:opacity .15s}
.photo-card img:hover{opacity:.9}
.photo-label-tag{position:absolute;top:8px;left:8px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:5px;letter-spacing:.05em}
.tag-before{background:rgba(239,68,68,.75);color:#fff}.tag-after{background:rgba(34,197,94,.75);color:#fff}
.photo-empty-card{display:flex;align-items:center;justify-content:center;min-height:160px;color:var(--text3);font-size:12px;border-radius:10px;border:1px dashed var(--border)}
.map-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}
.map-frame-wrap{flex:1;position:relative;overflow:hidden}
.map-frame-wrap iframe{width:100%;height:100%;border:none}
.map-coords-bar{padding:8px 16px;background:var(--bg2);border-top:1px solid var(--border);display:flex;gap:12px;align-items:center;flex-shrink:0}
.map-coord-item{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text2)}
.map-coord-label{font-size:10px;color:var(--text3);margin-right:4px}
.info-panel{padding:16px 20px;overflow-y:auto}
.info-row{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid var(--border)}
.info-row:last-child{border-bottom:none}
.info-key{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;min-width:90px;padding-top:1px}
.info-val{font-size:13px;color:var(--text);flex:1}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:999;display:none;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px}
.lightbox-close{position:absolute;top:16px;right:20px;color:#fff;font-size:30px;cursor:pointer;background:none;border:none;line-height:1}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;display:none;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:14px;padding:28px;width:100%;max-width:420px}
.modal h2{font-size:16px;font-weight:600;margin-bottom:18px}
.modal .field{margin-bottom:14px}
.modal label{display:block;font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px}
.modal input,.modal select{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:7px;padding:8px 12px;color:var(--text);font-size:13px;font-family:'DM Sans',sans-serif;outline:none}
.modal input:focus,.modal select:focus{border-color:var(--accent)}
.modal-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}

/* UPLOAD ZONE */
.upload-zone{border:2px dashed var(--border2);border-radius:12px;padding:32px;text-align:center;cursor:pointer;transition:all .2s;color:var(--text3)}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent);background:rgba(79,123,255,.05);color:var(--text2)}
.upload-zone svg{margin-bottom:10px;opacity:.5}
.upload-zone .uz-title{font-size:14px;font-weight:600;margin-bottom:4px}
.upload-zone .uz-sub{font-size:12px}
.upload-result{margin-top:14px;font-size:12px;display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto}
.ur-item{padding:6px 10px;border-radius:6px;display:flex;align-items:center;gap:8px}
.ur-ok{background:var(--odp-bg);color:var(--odp)}
.ur-err{background:var(--danger-bg);color:var(--danger)}

/* ── WILAYAH (level 1) ───────────────────────────────────────────────────── */
.wilayah-group{border-bottom:2px solid var(--border2)}
.wilayah-header{padding:10px 12px;cursor:pointer;display:flex;align-items:center;gap:7px;background:var(--bg4);user-select:none;position:sticky;top:0;z-index:2;transition:background .1s}
.wilayah-header:hover{background:var(--accent)}
.wilayah-header:hover .w-name,.wilayah-header:hover .w-icon,.wilayah-header:hover .w-chev{color:#fff}
.wilayah-header:hover .w-badge{background:rgba(255,255,255,.20);color:#fff;border-color:rgba(255,255,255,.38)}
.wilayah-header:hover .badge{background:rgba(255,255,255,.92)}
.w-chev{font-size:9px;color:var(--text3);width:11px;flex-shrink:0}
.w-icon{font-size:14px;flex-shrink:0}
.w-name{font-size:12px;font-weight:700;color:var(--text);flex:1;letter-spacing:.04em;text-transform:uppercase}
.w-counts{display:flex;gap:4px;flex-shrink:0}
.w-badge{font-size:9px;padding:2px 6px;border-radius:10px;background:var(--bg3);color:var(--text3);border:1px solid var(--border);font-weight:600}
.wilayah-items{display:none}
.wilayah-group.open .wilayah-items{display:block}

/* ── AREA (level 2) ─────────────────────────────────────────────────────── */
.area-group{border-bottom:1px solid var(--border)}
.area-header{padding:8px 12px 8px 20px;cursor:pointer;display:flex;align-items:center;gap:6px;background:var(--bg3);user-select:none;transition:background .12s}
.area-header:hover{background:var(--accent)}
.area-header:hover .area-name,.area-header:hover .area-chevron{color:#fff}
.area-header:hover .area-count{color:#fff;background:rgba(255,255,255,.22)}
.area-header:hover .badge{background:rgba(255,255,255,.92)}
.area-chevron{font-size:8px;color:var(--text3);width:10px;flex-shrink:0}
.area-name{font-size:11px;font-weight:600;color:var(--text2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.area-count{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:500;color:var(--text3);background:var(--bg4);padding:1px 6px;border-radius:9px;flex-shrink:0;min-width:22px;text-align:center;line-height:1.55}
.area-badges{display:flex;gap:3px;flex-shrink:0;align-items:center}
.area-items{display:none}
.area-group.open .area-items{display:block}

/* ── TITIK (level 3) ────────────────────────────────────────────────────── */
.point-row{padding:7px 12px 7px 28px;cursor:pointer;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:8px;transition:background .1s}
.point-row:last-child{border:none}
.point-row:hover{background:var(--bg3)}
.point-row.active{background:var(--bg4);border-left:3px solid var(--accent);padding-left:25px}

/* ── KEYS PANEL ─────────────────────────────────────────────────────────── */
:root{--danger:#dc2f2f;--danger-bg:rgba(220,47,47,.10)}
.btn-danger-sm{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(220,47,47,.28);padding:3px 8px;border-radius:5px;font-size:11px;cursor:pointer;font-family:inherit;margin-left:8px}
.keys-panel{height:100%;overflow-y:auto}
.keys-loading{padding:24px;text-align:center;color:var(--text3);font-size:12px}
.keys-content{display:flex;flex-direction:column;gap:0}
.keys-section{padding:16px 20px;border-bottom:1px solid var(--border)}
.keys-section:last-child{border:none}
.keys-section-title{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
.keys-cards{display:flex;flex-direction:column;gap:10px}
.key-card{background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:14px;transition:border-color .15s}
.key-card.key-borrowed{border-color:var(--gembok-bg);background:rgba(245,158,66,.05)}
.key-card-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.key-num{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;color:var(--text)}
.key-loc{font-size:11px;color:var(--text3);flex:1}
.key-status{font-size:11px;font-weight:600}
.key-loan-info{background:var(--bg4);border-radius:7px;padding:10px 12px;margin-bottom:10px;display:flex;flex-direction:column;gap:5px}
.kli-row{display:flex;gap:8px;align-items:flex-start}
.kli-label{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;min-width:70px;padding-top:1px}
.kli-val{font-size:12px;color:var(--text);flex:1}
.kli-val.overdue{color:var(--danger);font-weight:600}
.btn-borrow{width:100%;background:rgba(79,123,255,.15);color:var(--accent);border:1px solid rgba(79,123,255,.3);padding:7px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}
.btn-borrow:hover{background:rgba(79,123,255,.25)}
.btn-return{width:100%;background:rgba(74,222,128,.15);color:var(--odp);border:1px solid rgba(74,222,128,.3);padding:7px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s;margin-top:8px}
.btn-return:hover{background:rgba(74,222,128,.25)}
.history-list{display:flex;flex-direction:column;gap:6px}
.history-section-title{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;padding:6px 0 2px;border-top:1px solid var(--border);margin-top:4px}
.history-section-title:first-child{border-top:none;margin-top:0}
.loan-row{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:3px}
.loan-row.returned{opacity:.6}
.loan-row.overdue{border-color:rgba(248,113,113,.4);background:var(--danger-bg)}
.lr-key{font-size:10px;color:var(--text3);font-weight:600}
.lr-borrower{font-size:12px;color:var(--text);font-weight:500}
.lr-company{font-size:11px;color:var(--text3);font-weight:400;margin-left:6px}
.lr-dates{font-size:11px;color:var(--text2);font-family:'JetBrains Mono',monospace}
.lr-dates .overdue{color:var(--danger)}
.no-history{padding:16px;text-align:center;color:var(--text3);font-size:12px;font-style:italic}

/* ── LEAFLET MAP ─────────────────────────────────────────────────────────── */
.leaflet-map-container{flex:1;min-height:260px;background:var(--bg3)}
.map-status-bar{padding:6px 14px;font-size:11px;background:rgba(251,191,36,.15);color:var(--warn,#fbbf24);border-top:1px solid rgba(251,191,36,.3);flex-shrink:0}
.leaflet-popup-content-wrapper{background:var(--bg2);color:var(--text);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.leaflet-popup-content{font-family:'DM Sans',sans-serif;font-size:12px;margin:8px 12px}
.leaflet-popup-tip{background:var(--bg2)}
.leaflet-bar a{background:var(--bg2);color:var(--text);border-color:var(--border)}
.leaflet-bar a:hover{background:var(--bg3)}

/* Icon hapus di tiap baris sidebar (area & titik) */
.row-del{flex-shrink:0;cursor:pointer;font-size:14px;opacity:.7;padding:3px 6px;border-radius:6px;line-height:1;transition:opacity .12s,background .12s,transform .12s;align-self:center;color:var(--danger)}
.row-del:hover{opacity:1;background:rgba(220,47,47,.16);transform:scale(1.15)}
.area-header .row-del{margin-left:6px}
.point-row .row-del{margin-left:4px}
.area-export{flex-shrink:0;cursor:pointer;opacity:.8;padding:3px 5px;border-radius:6px;line-height:0;display:inline-flex;align-items:center;transition:opacity .12s,background .12s,transform .12s;align-self:center}
.area-export:hover{opacity:1;background:rgba(34,197,94,.20);transform:scale(1.15)}
