/* ============================================================================
 * GeoField Kit — CSS (prefix .gf-) agar tidak bentrok dengan style aplikasi.
 * Termasuk dukungan dark mode bila <body class="dark-mode">.
 * ==========================================================================*/

/* Kotak peta */
.gf-map-box{position:relative;background:#fff;z-index:10;border:1px solid #d5dde6;border-radius:14px;margin:18px 0 8px;overflow:hidden;box-shadow:0 8px 24px rgba(15,23,42,.10)}
#gf-map{height:340px;width:100%;background:#e9eef2}
.gf-map-box.full{position:fixed;inset:8px;z-index:5000;margin:0;border-radius:14px}
.gf-map-box.full #gf-map{height:calc(100vh - 74px)}
.gf-map-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:linear-gradient(180deg,#fff,#f7fafc);border-bottom:1px solid #e2e8f0}
.gf-map-title{font-weight:700;color:#0f172a;display:flex;align-items:center;gap:7px}
.gf-map-title i{color:#16a34a}
.gf-map-status{font-size:12px;color:#64748b;margin-top:2px}
.gf-map-actions{display:flex;align-items:center;gap:7px;flex-wrap:wrap;justify-content:flex-end}
.gf-icon-btn,.gf-upload{display:inline-flex;align-items:center;gap:7px;background:#fff;color:#0f172a;border:1px solid #cbd5e1;border-radius:10px;padding:8px 10px;font-weight:600;cursor:pointer}
.gf-icon-btn:hover,.gf-upload:hover{background:#f1f5f9}
.gf-icon-btn i{color:#2563eb}
.gf-upload i{color:#16a34a}
.gf-upload input{display:none}

/* Panel tracking */
.gf-tracking-panel{display:none;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:10px 12px}
.gf-tracking-panel.open{display:block}
.gf-track-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.gf-track-head b{display:block;color:#0f172a}
.gf-track-head small{display:block;color:#64748b;font-size:12px}
.gf-mini-close{background:#e2e8f0;color:#0f172a;padding:6px 10px;border-radius:8px;border:0;cursor:pointer}
.gf-track-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.gf-track-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:12px;padding:10px 14px;font-weight:700;min-width:92px;color:#fff;border:0;cursor:pointer}
.gf-track-btn.start{background:#16a34a}
.gf-track-btn.pause{background:#f59e0b}
.gf-track-btn.stop{background:#dc2626}
.gf-track-btn:disabled{opacity:.45;cursor:not-allowed}
.gf-color-label{display:inline-flex;align-items:center;gap:8px;border:1px solid #cbd5e1;border-radius:12px;padding:7px 9px;background:#fff;color:#334155;font-weight:600}
.gf-color-label input{width:34px;height:28px;border:0;background:transparent;padding:0}
.gf-track-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:9px}
.gf-track-grid>div{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:9px 10px}
.gf-track-grid small{display:block;color:#64748b;font-size:11px;margin-bottom:3px}
.gf-track-grid b{font-size:14px;color:#0f172a}
.gf-track-status-line{margin-top:8px;background:#ecfdf5;border:1px solid #bbf7d0;color:#166534;border-radius:10px;padding:8px 10px;font-size:13px}
.gf-track-status-line.warn{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.gf-track-status-line.danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}

/* Kanvas + crosshair presisi */
.gf-map-canvas-wrap{position:relative}
.gf-map-crosshair{position:absolute;left:50%;top:50%;transform:translate(-50%,-55%);z-index:600;font-size:30px;color:#dc2626;text-shadow:0 0 3px #fff,0 0 6px #fff;pointer-events:none;font-weight:700}
.gf-map-box.full .gf-map-crosshair{font-size:38px}

/* Pemilih placemark (di modal) */
#gfPmModalBox .gf-pm-colors{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0}
#gfPmModalBox .gf-pm-swatch{width:34px;height:34px;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 1px #cbd5e1;cursor:pointer}
#gfPmModalBox .gf-pm-swatch.sel{box-shadow:0 0 0 3px #111}
#gfPmModalBox .gf-pm-shapes{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0}
#gfPmModalBox .gf-pm-shape{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:2px solid #cbd5e1;border-radius:10px;background:#fff;cursor:pointer}
#gfPmModalBox .gf-pm-shape svg{max-width:100%;max-height:100%}
#gfPmModalBox .gf-pm-shape.sel{border-color:#111;box-shadow:0 0 0 2px #111 inset}
.gf-pm-divicon{background:transparent;border:0}

/* Kontrol grup placemark di pojok peta */
.gf-pm-group-control{position:absolute;right:8px;bottom:8px;z-index:650;background:rgba(255,255,255,.95);border:1px solid #cbd5e1;border-radius:10px;padding:8px 10px;font-size:13px;max-height:40%;overflow:auto}
.gf-pm-group-control b{display:block;margin-bottom:4px}
.gf-pm-group-control label{display:block;cursor:pointer;margin:2px 0}

/* Modal generik kit */
.gf-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:6000;overflow:auto}
.gf-modal-content{background:#fff;margin:40px auto;padding:20px;border-radius:8px;max-width:96%;width:520px;max-height:84vh;overflow:auto;position:relative}
.gf-modal-close{position:sticky;top:0;float:right;background:#dc2626;color:#fff;border:0;border-radius:6px;padding:6px 10px;cursor:pointer}
.gf-modal-content label{display:block;margin:8px 0}
.gf-modal-content input[type=text]{width:100%;padding:8px;box-sizing:border-box;border:1px solid #cbd5e1;border-radius:8px}
.gf-modal-content button{padding:8px 14px;border:0;border-radius:8px;color:#fff;background:#475569;cursor:pointer;margin-right:6px}
.gf-modal-content button.btn-ok{background:#16a34a}

/* Tabel rekap */
.gf-table{width:100%;border-collapse:collapse;font-size:13px}
.gf-table th,.gf-table td{border:1px solid #e2e8f0;padding:6px 8px;text-align:left}
.gf-table th{background:#f1f5f9}
.btn-danger{background:#dc2626;color:#fff;border:0;border-radius:6px;padding:5px 9px;cursor:pointer}
.btn-ok{background:#16a34a;color:#fff;border:0;border-radius:6px;padding:6px 12px;cursor:pointer}
.btn-blue{background:#2563eb;color:#fff;border:0;border-radius:6px;padding:6px 12px;cursor:pointer}

/* Dark mode */
body.dark-mode .gf-map-box{background:#1e1e1e;border-color:#333}
body.dark-mode .gf-map-header{background:linear-gradient(180deg,#262626,#1e1e1e);border-bottom-color:#333}
body.dark-mode #gf-map{background:#0d0d0d}
body.dark-mode .gf-tracking-panel{background:#1a1a1a;border-bottom-color:#333}
body.dark-mode .gf-track-grid>div{background:#1e1e1e;border-color:#333}
body.dark-mode .gf-modal-content{background:#1e1e1e;color:#e0e0e0}
body.dark-mode .gf-pm-group-control{background:rgba(30,30,30,.95);border-color:#444;color:#e0e0e0}

@media(max-width:720px){
  #gf-map{height:300px}
  .gf-map-header{align-items:flex-start;flex-direction:column}
  .gf-map-actions{justify-content:flex-start;width:100%}
  .gf-icon-btn span{display:none}
  .gf-track-btn{min-width:86px;flex:1}
  .gf-track-grid{grid-template-columns:repeat(2,1fr)}
}
