/* 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;height:auto;max-height:80vh;object-fit:contain;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}
.photo-rotate{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;gap:10px;z-index:3;opacity:0;transition:opacity .15s;pointer-events:none}
.photo-card:hover .photo-rotate{opacity:1;pointer-events:auto}
.photo-rotate button{width:46px;height:46px;border:none;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.4)}
.photo-rotate button:hover{background:rgba(0,0,0,.88);transform:scale(1.08)}
.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}
/* Filter kategori (ODP/JB): titik yang tidak cocok TIDAK disembunyikan, hanya
   diredupkan jadi hitam-putih supaya kategori terpilih lebih menonjol.
   Klik "Semua" mengembalikan semua titik ke warna semula. */
.point-row.bw{filter:grayscale(1);opacity:.45;transition:filter .15s,opacity .15s}
.point-row.bw:hover{opacity:.75}
/* Titik yang COCOK dengan filter aktif: background hitam, teks putih supaya
   menonjol. Warna teks dipaksa putih agar semua tetap terbaca di atas hitam. */
.point-row.sel{background:#111;border-bottom-color:rgba(255,255,255,.22)}
.point-row.sel:hover{background:#000}
.point-row.sel .pt-name,.point-row.sel .pt-sub,.point-row.sel .pt-sub span{color:#fff}
.point-row.sel.active{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)}

/* =====================================================================
   RESPONSIVE — PM-Tracker. Semua aturan HANYA aktif di layar kecil;
   tampilan & fungsi desktop tidak berubah sama sekali.
   Opsi A = penyesuaian dasar · Opsi B = master-detail (panel geser + back).
   ===================================================================== */

/* Tombol "‹ Kembali" — tersembunyi secara default (hanya muncul di mobile). */
.mobile-back{
  display:none;align-items:center;gap:6px;
  background:var(--bg3);border:1px solid var(--border2);color:var(--text);
  font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;
  padding:9px 14px;border-radius:8px;cursor:pointer;
  margin:10px 12px 2px;align-self:flex-start;flex-shrink:0;
}
.mobile-back:active{background:var(--bg4)}

/* ---------- TABLET & MOBILE (<= 900px) ---------- */
@media (max-width: 900px){
  /* Topbar: izinkan tombol membungkus ke baris berikutnya, jangan meluber. */
  .topbar{flex-wrap:wrap;height:auto;min-height:52px;padding:8px 12px;row-gap:8px}
  .topbar-right{flex-wrap:wrap;row-gap:6px}
}

/* ---------- MOBILE (<= 768px) ---------- */
@media (max-width: 768px){
  /* Tombol topbar lebih ringkas & sentuhan lebih nyaman. */
  .topbar{gap:8px}
  .topbar-title{display:none}                 /* hemat ruang; logo tetap tampil */
  .topbar .btn{padding:7px 10px;font-size:11.5px}
  .topbar-right{gap:6px;width:100%;justify-content:flex-start}

  /* Statsbar sudah bisa di-scroll horizontal; rapatkan sedikit. */
  .statsbar{padding:0 12px}
  .stat{padding:0 8px}

  /* INTI (Opsi B): master-detail. Sidebar jadi daftar full-screen;
     panel detail/peta tampil sebagai overlay yang geser masuk dari kanan
     saat sebuah titik dipilih (body.mobile-detail), dengan tombol Kembali. */
  .main{flex-direction:column;position:relative}
  .sidebar{
    width:100%;min-width:0;flex:1;max-height:none;
    border-right:none;border-bottom:none;
  }
  .content{
    position:absolute;inset:0;z-index:60;
    background:var(--bg);
    transform:translateX(100%);
    transition:transform .26s ease;
    will-change:transform;
  }
  body.mobile-detail .content{transform:translateX(0)}

  /* Tombol Kembali muncul (hanya) di mobile. */
  .mobile-back{display:inline-flex}

  /* Header detail boleh membungkus supaya tombol-tombol tidak terpotong. */
  .d-header{flex-wrap:wrap}
  .d-right{margin-left:0;align-items:flex-start;width:100%}

  /* Modal pas di layar kecil (jangan menempel tepi). */
  .modal-overlay{padding:12px}
  .modal{padding:20px}

  /* Lightbox foto: manfaatkan hampir seluruh layar. */
  .lightbox img{max-width:96vw;max-height:88vh}
}

/* ---------- MOBILE KECIL (<= 560px) ---------- */
@media (max-width: 560px){
  /* Galeri foto jadi 1 kolom agar tidak terlalu kecil. */
  .photo-grid{grid-template-columns:1fr}
}

/* ---------- Perangkat sentuh: target ketuk lebih besar ---------- */
@media (hover: none) and (pointer: coarse){
  .point-row{padding-top:11px;padding-bottom:11px}
  .area-header,.wilayah-header{padding-top:11px;padding-bottom:11px}
  .chip{padding-top:6px;padding-bottom:6px}
}

/* =====================================================================
   RESPONSIVE — Halaman Report Gembok (/report/gembok)
   Selektor diawali `body ` agar spesifisitasnya menang atas <style> di
   template (yang dimuat setelah shared.css). Topbar/statsbar/chip halaman
   ini sudah ikut aturan di atas. Tetap di-gate media query → desktop sama.
   ===================================================================== */
@media (max-width: 768px){
  body .rg-wrap{padding:12px 10px}
  body .rg-toolbar{gap:8px;margin-bottom:10px}
  body .rg-search{min-width:0;flex:1 1 100%;max-width:none}   /* kotak cari satu baris penuh */
  body .wil{margin:14px 0 4px;padding:8px 12px;font-size:12px}
  body .area{margin-left:4px;padding:7px 10px}                /* kurangi indentasi bersarang */
  body .seg{margin-left:10px;padding-left:10px}
  body .grp{margin-left:2px}
  body table.rg{font-size:11.5px}
  body table.rg th,body table.rg td{padding:6px 7px}
}
@media (max-width: 480px){
  /* Cegah scroll horizontal di layar mungil: koordinat & header tabel boleh membungkus. */
  body .rg-ko{white-space:normal}
  body table.rg th{white-space:normal}
  body .rg-no{width:38px}
}
