/* ============================================================
   Barangay Poloy-Poloy Profiling System — Stylesheet
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f0f4f8;--surface:#fff;--surface2:#f7f9fb;--border:#dde2ea;
  --text:#1a1e28;--text2:#54607a;--text3:#98a3b8;
  --blue:#1550c0;--blue-l:#e8effd;--blue-d:#1040a0;
  --green:#0c9467;--green-l:#e5f7f1;
  --amber:#c96d04;--amber-l:#fef0db;
  --red:#c82020;--red-l:#fde8e8;
  --purple:#6d30e0;--purple-l:#ede8fd;
  --teal:#0784a8;--teal-l:#e3f4fa;
  --radius:10px;--radius-lg:14px;
}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--text);font-size:14px;min-height:100vh}
a{text-decoration:none;color:inherit}

/* Layout */
.app{display:flex;min-height:100vh}
.sidebar{width:228px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}
.main{flex:1;overflow:hidden;display:flex;flex-direction:column}

/* Sidebar */
.logo{padding:18px 16px 14px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#1550c0 0%,#0784a8 100%)}
.logo-flag{font-size:10px;font-weight:700;color:rgba(255,255,255,.7);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.logo-title{font-size:14px;font-weight:700;color:#fff;line-height:1.2}
.logo-sub{font-size:11px;color:rgba(255,255,255,.65);margin-top:2px}
.nav{padding:10px 8px;flex:1}
.nav-section{font-size:10px;font-weight:700;color:var(--text3);letter-spacing:.9px;text-transform:uppercase;padding:10px 8px 4px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text2);margin-bottom:2px;transition:all .15s}
.nav-item:hover{background:var(--bg);color:var(--text)}
.nav-item.active{background:var(--blue-l);color:var(--blue)}
.nav-icon{width:15px;height:15px;flex-shrink:0}
.sidebar-footer{padding:12px 14px;border-top:1px solid var(--border);font-size:11px;color:var(--text3)}

/* Topbar */
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:11px 22px;display:flex;align-items:center;justify-content:space-between}
.topbar-title{font-size:15px;font-weight:700}
.topbar-loc{font-size:11px;color:var(--text3);margin-top:1px}
.content{flex:1;padding:18px 22px;overflow-y:auto}

/* Cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:15px}
.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px}
.metric-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.metric-val{font-size:28px;font-weight:700;line-height:1;color:var(--text)}
.section-hd{font-size:13px;font-weight:700;margin-bottom:12px}

/* Grids */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}

/* Badges */
.badge{display:inline-flex;align-items:center;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;margin-top:5px}
.badge-green{background:var(--green-l);color:var(--green)}
.badge-blue{background:var(--blue-l);color:var(--blue)}
.badge-amber{background:var(--amber-l);color:var(--amber)}
.badge-red{background:var(--red-l);color:var(--red)}
.badge-purple{background:var(--purple-l);color:var(--purple)}
.badge-teal{background:var(--teal-l);color:var(--teal)}
.tag{display:inline-block;padding:2px 7px;border-radius:20px;font-size:10px;font-weight:700}
.purok-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;background:var(--teal-l);color:var(--teal)}

/* Buttons */
.btn{padding:7px 13px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);font-family:inherit;transition:all .15s;text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.btn:hover{background:var(--bg)}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--blue-d)}
.btn-sm{padding:4px 10px;font-size:11px}
.btn-danger{background:var(--red-l);color:var(--red);border-color:transparent}

/* Forms */
input,select,textarea{font-family:inherit;font-size:12px;padding:7px 11px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);width:100%;outline:none;transition:border .15s}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(21,80,192,.1)}
label{font-size:11px;font-weight:700;color:var(--text2);display:block;margin-bottom:3px;text-transform:uppercase;letter-spacing:.3px}
.form-group{margin-bottom:12px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

/* Table */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:12px}
th{text-align:left;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;padding:7px 10px;border-bottom:1px solid var(--border);background:var(--surface2)}
td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafbfd}

/* Stats rows */
.stat-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border);font-size:12px;gap:8px}
.stat-row:last-child{border-bottom:none}
.prog-bar{height:5px;background:var(--border);border-radius:3px;overflow:hidden;flex:1;margin-left:8px}
.prog-fill{height:100%;border-radius:3px;transition:width .5s}

/* Modal */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,20,35,.45);z-index:200;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border-radius:var(--radius-lg);padding:22px;width:540px;max-height:88vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.18)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.modal-title{font-size:14px;font-weight:700}
.close-btn{width:26px;height:26px;border-radius:6px;border:none;background:var(--bg);cursor:pointer;font-size:14px;color:var(--text2)}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;background:#1a1e28;color:#fff;padding:10px 18px;border-radius:10px;font-size:12px;font-weight:600;z-index:999;transform:translateY(60px);opacity:0;transition:all .3s;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}

/* Alert */
.alert{padding:10px 14px;border-radius:8px;font-size:12px;margin-bottom:14px}
.alert-success{background:var(--green-l);color:var(--green)}
.alert-danger{background:var(--red-l);color:var(--red)}

/* SMS phone preview */
.sms-phone{background:#1a1a2e;border-radius:20px;padding:20px 16px;max-width:260px;margin:0 auto}
.sms-bubble{background:#1550c0;border-radius:14px 14px 4px 14px;padding:10px 14px;color:#fff;font-size:12px;line-height:1.5;word-break:break-word;margin-top:8px}
.sms-sender{font-size:10px;color:#6b7a99;margin-bottom:4px;font-family:monospace}

@media(max-width:900px){
  .sidebar{width:56px}.logo-title,.logo-sub,.logo-flag,.nav-section,.sidebar-footer{display:none}
  .nav-item span{display:none}.grid4{grid-template-columns:1fr 1fr}.grid3{grid-template-columns:1fr}
}
