/* ═══════════════════════════════════════════════════════════
   GraPARI Connect — West Java Platform
   Main Stylesheet
   ═══════════════════════════════════════════════════════════ */

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#ED1C24;--primary-dark:#B71C1C;--primary-light:#FF5252;
  --bg:#F5F7FA;--card:#fff;--text:#1A1A2E;--text-light:#6B7280;
  --border:#E5E7EB;--success:#10B981;--warning:#F59E0B;--info:#3B82F6;
  --sidebar-w:260px;--radius:12px;
}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}
.page{display:none;min-height:100vh}.page.active{display:flex}

/* ── Login / Register ───────────────────────── */
.auth-bg{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#1A1A2E 0%,var(--primary-dark) 50%,var(--primary) 100%);padding:20px}
.auth-card{background:#fff;border-radius:20px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.auth-card.wide{max-width:540px}
.auth-head{text-align:center;margin-bottom:28px}
.logo-circle{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:#fff;font-size:28px}
.auth-head h1{font-size:22px;font-weight:700}.auth-head p{font-size:13px;color:var(--text-light);margin-top:4px}

/* ── Form ───────────────────────────────────── */
.form-group{margin-bottom:15px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text);margin-bottom:5px}
.form-input{width:100%;padding:11px 14px;border:2px solid var(--border);border-radius:10px;font-size:13px;transition:.2s;outline:none;background:#FAFAFA}
.form-input:focus{border-color:var(--primary);background:#fff}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn{padding:11px 22px;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:.2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn:disabled{opacity:.6;cursor:not-allowed}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;width:100%}
.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px rgba(237,28,36,.35)}
.btn-outline{background:transparent;border:2px solid var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--primary);color:#fff}
.btn-info{background:var(--info);color:#fff}
.btn-sm{padding:7px 14px;font-size:12px;border-radius:8px}
.link-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-size:13px;font-weight:600}
.alert{padding:11px 15px;border-radius:10px;font-size:13px;margin-bottom:14px;display:none}
.alert.show{display:block}
.alert-success{background:#D1FAE5;color:#065F46}.alert-error{background:#FEE2E2;color:#991B1B}
.alert-warning{background:#FEF3C7;color:#92400E}.alert-info{background:#DBEAFE;color:#1E40AF}

/* ── Sidebar ────────────────────────────────── */
.sidebar{width:var(--sidebar-w);height:100vh;background:linear-gradient(180deg,#1A1A2E 0%,#16213E 100%);
  position:fixed;left:0;top:0;z-index:100;display:flex;flex-direction:column;transition:.3s}
.sidebar-brand{padding:18px 22px 26px;display:flex;align-items:center;gap:12px;color:#fff;border-bottom:1px solid rgba(255,255,255,.07)}
.sidebar-brand .logo-sm{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  display:flex;align-items:center;justify-content:center;font-size:17px}
.sidebar-brand h2{font-size:15px;font-weight:700;line-height:1.2}
.sidebar-brand span{font-size:11px;color:rgba(255,255,255,.45)}
.nav-section{padding:14px 22px 6px;font-size:10px;font-weight:700;color:rgba(255,255,255,.3);letter-spacing:.8px;text-transform:uppercase}
.nav-menu{flex:1;overflow-y:auto;padding:8px 0}
.nav-item{display:flex;align-items:center;gap:13px;padding:12px 22px;color:rgba(255,255,255,.6);cursor:pointer;
  transition:.18s;font-size:13.5px;font-weight:500;border-left:3px solid transparent}
.nav-item:hover,.nav-item.active{color:#fff;background:rgba(255,255,255,.07);border-left-color:var(--primary)}
.nav-item i{width:18px;text-align:center;font-size:15px}
.sidebar-footer{padding:14px 22px;border-top:1px solid rgba(255,255,255,.1)}
.user-info{display:flex;align-items:center;gap:10px;color:#fff}
.user-avatar{width:34px;height:34px;border-radius:9px;background:var(--primary);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.user-info .uname{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-info .urole{font-size:10.5px;color:rgba(255,255,255,.45)}

/* ── Main content ───────────────────────────── */
.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh}
.topbar{height:62px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;
  justify-content:space-between;padding:0 26px;position:sticky;top:0;z-index:50;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.topbar h2{font-size:17px;font-weight:700}
.content-area{padding:22px 26px}
.view{display:none}.view.active{display:block}

/* ── Cards & Stats ──────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:15px;margin-bottom:22px}
.stat-card{background:#fff;border-radius:var(--radius);padding:18px;box-shadow:0 1px 3px rgba(0,0,0,.05);border:1px solid var(--border)}
.stat-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:17px;margin-bottom:11px}
.stat-value{font-size:26px;font-weight:800;color:var(--text)}
.stat-label{font-size:12px;color:var(--text-light);margin-top:3px}
.stat-sub{font-size:11px;color:var(--success);margin-top:4px}
.card{background:#fff;border-radius:var(--radius);box-shadow:0 1px 3px rgba(0,0,0,.05);border:1px solid var(--border);margin-bottom:18px}
.card-header{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-header h3{font-size:15px;font-weight:700}
.card-body{padding:18px 20px}

/* ── Table ──────────────────────────────────── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:600px}
th,td{padding:11px 14px;text-align:left;font-size:12.5px;border-bottom:1px solid var(--border)}
th{font-weight:600;color:var(--text-light);background:#FAFAFA;white-space:nowrap}
tr:hover td{background:#FAFBFC}
.badge{padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-success{background:#D1FAE5;color:#065F46}.badge-warning{background:#FEF3C7;color:#92400E}
.badge-danger{background:#FEE2E2;color:#991B1B}.badge-info{background:#DBEAFE;color:#1E40AF}
.badge-gray{background:#F3F4F6;color:#6B7280}

/* ── Map ────────────────────────────────────── */
#map-container{height:calc(100vh - 250px);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);min-height:480px}
.map-controls{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.map-controls .form-input{max-width:260px}
.map-legend{display:flex;gap:16px;margin-top:10px;font-size:12px;color:var(--text-light);flex-wrap:wrap}
.map-legend span{display:flex;align-items:center;gap:5px}

/* ── Upload ─────────────────────────────────── */
.upload-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:18px}
.upload-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:20px}
.upload-card h4{font-size:14px;font-weight:700;margin-bottom:4px}
.upload-card p{font-size:12px;color:var(--text-light);margin-bottom:14px}
.upload-zone{border:2px dashed var(--border);border-radius:10px;padding:28px 16px;text-align:center;cursor:pointer;transition:.2s}
.upload-zone:hover{border-color:var(--primary);background:rgba(237,28,36,.02)}
.upload-zone i{font-size:32px;color:var(--primary);margin-bottom:8px}
.upload-zone p{font-size:12px;color:var(--text-light);margin-top:4px}

/* ── ODP Popup ────────────────────────────────*/
.odp-popup h4{font-size:13px;font-weight:700;color:var(--text);margin-bottom:6px}
.odp-popup .row{display:flex;justify-content:space-between;font-size:11.5px;padding:3px 0;border-bottom:1px solid #f0f0f0}
.odp-popup .row:last-child{border-bottom:none}
.odp-popup .label{color:#888}.odp-popup .val{font-weight:600}
.odp-popup .status-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;margin-bottom:6px}

/* ── Modal ──────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1050;display:none;align-items:center;justify-content:center;padding:16px}
.modal-overlay.active{display:flex}
.modal{background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}
.modal-header{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.modal-header h3{font-size:15px;font-weight:700}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-light);line-height:1}
.modal-body{padding:20px}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* ── Loading ────────────────────────────────── */
.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-overlay{position:fixed;inset:0;background:rgba(255,255,255,.8);z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;display:none}
.loading-overlay.active{display:flex}
.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}

/* ── Pending banner ──────────────────────────── */
.pending-badge{background:#FEF3C7;color:#92400E;border:1px solid #FDE68A;border-radius:10px;padding:12px 18px;font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:10px}

/* ── Ruler tool ──────────────────────────────── */
.ruler-bar{background:#EFF6FF;border:2px solid #2563EB;border-radius:var(--radius);padding:10px 16px;margin-bottom:10px;display:none;align-items:center;gap:12px;flex-wrap:wrap}
.ruler-bar.active{display:flex}
.ruler-bar .ruler-status{flex:1;font-size:13px;color:var(--text)}

/* ── Map layer toggle ────────────────────────── */
.map-layer-toggle{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.map-layer-toggle button{padding:6px 12px;font-size:12px;border:none;background:#fff;cursor:pointer;font-weight:500;transition:.15s;color:var(--text)}
.map-layer-toggle button.active{background:var(--primary);color:#fff}

/* ── Multiselect ─────────────────────────────── */
.multiselect{position:relative;z-index:1000}
.multiselect-trigger{display:flex;align-items:center;gap:8px;padding:8px 14px;border:2px solid var(--border);
  border-radius:10px;font-size:13px;cursor:pointer;background:#FAFAFA;min-width:140px;white-space:nowrap}
.multiselect-trigger.open{border-color:var(--primary)}
.multiselect-menu{display:none;position:absolute;top:calc(100% + 4px);left:0;background:#fff;
  border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 16px rgba(0,0,0,.1);
  min-width:160px;z-index:9999;padding:6px 0}
.multiselect-menu.open{display:block}
.multiselect-menu label{display:flex;align-items:center;gap:8px;padding:7px 14px;font-size:13px;cursor:pointer}
.multiselect-menu label:hover{background:#F9FAFB}
.multiselect-divider{height:1px;background:var(--border);margin:4px 0}
.map-controls{position:relative;z-index:1000}

/* ── Pending count badge ─────────────────────── */
.nav-badge{background:var(--primary);color:#fff;border-radius:50%;width:18px;height:18px;font-size:10px;
  font-weight:700;display:none;align-items:center;justify-content:center;margin-left:auto}
.nav-badge.show{display:flex}

/* ── Responsive ──────────────────────────────── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}
  .main-content{margin-left:0}.form-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}.menu-toggle{display:block!important}
}

/* ── Marker Cluster custom ───────────────────── */
.odp-cluster{
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;color:#fff;font-weight:800;box-shadow:0 2px 8px rgba(0,0,0,.3);
  border:3px solid rgba(255,255,255,.85);
}
.odp-cluster-sm { background:#ED1C24; width:36px; height:36px; font-size:13px; }
.odp-cluster-md { background:#B71C1C; width:46px; height:46px; font-size:15px; }
.odp-cluster-lg { background:#7F1010; width:58px; height:58px; font-size:17px; }
