:root{
  /* ── Kiper Online Theme ── */
  --bg:#F7F3EE;--bg2:#FFFFFF;--bg3:#F0EBE3;
  --text:#1C3A3A;--text2:#5A7070;--text3:#8FA8A8;
  --border:#DDD5C8;--border2:#C8BDB0;
  /* Teal primary (dari border lingkaran logo) */
  --green:#2D6E6E;--green-bg:#E2EFEF;--green-text:#1C4A4A;
  /* Amber tetap untuk warning */
  --amber:#BA7517;--amber-bg:#FAEEDA;--amber-text:#854F0B;
  /* Soft red untuk danger */
  --red:#B03A3A;--red-bg:#FBECEC;--red-text:#B03A3A;
  /* Soft pink dari logo sebagai blue/info */
  --blue:#A05070;--blue-bg:#F5E8EE;--blue-text:#7A3050;
  /* Purple tetap */
  --purple-bg:#EEEDFE;--purple-text:#3C3489;
  --radius:8px;--radius-lg:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;font-size:14px;color:var(--text);background:var(--bg)}
.app{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:210px;background:var(--bg2);border-right:1px solid var(--border);padding:1rem 0;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar-logo{padding:0 1rem 1rem;border-bottom:1px solid var(--border);margin-bottom:0.5rem}
.sidebar-logo h2{font-size:15px;font-weight:600;display:flex;align-items:center;gap:6px}
.sidebar-logo p{font-size:11px;color:var(--text2);margin-top:2px}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 1rem;cursor:pointer;font-size:13px;color:var(--text2);transition:background 0.12s;user-select:none}
.nav-item:hover{background:var(--bg3);color:var(--text)}
.nav-item.active{background:var(--bg3);color:var(--text);font-weight:500;border-left:2px solid var(--green)}
.nav-item i{font-size:16px;flex-shrink:0}
.nav-badge{margin-left:auto;background:#E24B4A;color:#fff;font-size:10px;padding:1px 6px;border-radius:99px;font-weight:600;display:none}

/* MAIN */
.main{flex:1;overflow-y:auto;background:var(--bg);min-width:0}
.page{display:none;padding:1.5rem;width:100%}
.page-inner{max-width:1100px;width:100%}
.page.active{display:block}
.page-header{margin-bottom:1.5rem}
.page-header h1{font-size:20px;font-weight:600}
.page-header p{font-size:13px;color:var(--text2);margin-top:3px}

/* CARDS */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem}
.card h3{font-size:13px;font-weight:600;margin-bottom:1rem;padding-bottom:0.75rem;border-bottom:1px solid var(--border);color:var(--text2);text-transform:uppercase;letter-spacing:0.04em;display:flex;align-items:center;gap:6px}

/* METRICS */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:1rem}
.metric{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}
.metric-label{font-size:12px;color:var(--text2);margin-bottom:6px}
.metric-value{font-size:26px;font-weight:600}
.metric-value.teal{color:var(--green)}.metric-value.amber{color:var(--amber)}.metric-value.red{color:var(--red)}

/* FORMS */
.fg{display:flex;flex-direction:column;gap:5px}
.fg label{font-size:12px;color:var(--text2);font-weight:500}
.fg input,.fg select,.fg textarea{font-size:13px;padding:7px 10px;border-radius:var(--radius);border:1px solid var(--border2);background:#fff;color:var(--text);width:100%;outline:none;transition:border-color 0.15s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:#888}
.fg textarea{resize:vertical;min-height:60px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.grid4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px}
.full{grid-column:1/-1}
.sec{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.06em;margin:1.25rem 0 0.75rem;padding-bottom:6px;border-bottom:1px solid var(--border);grid-column:1/-1}

/* BUTTONS */
.btn{padding:7px 16px;border-radius:var(--radius);border:1px solid var(--border2);font-size:13px;cursor:pointer;background:#fff;color:var(--text);display:inline-flex;align-items:center;gap:5px;font-family:inherit;transition:background 0.12s}
.btn:hover{background:var(--bg3)}
.btn.primary{background:var(--green);color:#fff;border-color:var(--green)}
.btn.primary:hover{background:#1C4A4A}
.btn.danger{background:var(--red-bg);color:var(--red);border-color:#f09595}
.btn-row{display:flex;gap:8px;justify-content:flex-end;margin-top:1rem}

/* SEARCH BAR */
.sbar{display:flex;gap:8px;margin-bottom:1rem;align-items:center}
.sbar input{flex:1;font-size:13px;padding:7px 10px;border-radius:var(--radius);border:1px solid var(--border2);background:#fff;color:var(--text);outline:none}
.sbar select{font-size:13px;padding:7px 10px;border-radius:var(--radius);border:1px solid var(--border2);background:#fff;color:var(--text)}

/* TABLE */
table{width:100%;border-collapse:collapse;font-size:13px}
th{font-size:11px;font-weight:600;color:var(--text2);text-align:left;padding:8px 10px;border-bottom:2px solid var(--border);white-space:nowrap}
td{padding:9px 10px;border-bottom:1px solid var(--border);color:var(--text)}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafaf8}
.tbl-wrap{overflow-x:auto}

/* BADGE */
.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:500}
.badge.green{background:var(--green-bg);color:var(--green-text)}
.badge.amber{background:var(--amber-bg);color:var(--amber-text)}
.badge.red{background:var(--red-bg);color:var(--red-text)}
.badge.blue{background:var(--blue-bg);color:var(--blue-text)}
.badge.purple{background:var(--purple-bg);color:var(--purple-text)}

/* ACTION BUTTON */
.abtn{background:none;border:none;cursor:pointer;color:var(--text2);font-size:15px;padding:3px 5px;border-radius:4px;transition:background 0.1s}
.abtn:hover{background:var(--bg3);color:var(--text)}
.abtn.danger:hover{color:var(--red);background:var(--red-bg)}

/* TABS */
.tab-row{display:flex;gap:4px;margin-bottom:1rem;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:8px}
.tab{padding:6px 14px;border-radius:var(--radius);font-size:13px;cursor:pointer;background:transparent;border:1px solid transparent;color:var(--text2);transition:all 0.12s}
.tab:hover{background:var(--bg3)}
.tab.active{background:var(--bg2);color:var(--text);font-weight:500;border-color:var(--border2);box-shadow:0 1px 3px rgba(0,0,0,0.06)}

/* EMPTY STATE */
.empty{text-align:center;padding:3rem;color:var(--text2)}
.empty i{font-size:40px;display:block;margin-bottom:0.75rem;opacity:0.4}

/* NOTIF ITEM */
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:8px;background:#fff}
.ni-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px}
.ni-icon.warn{background:var(--amber-bg);color:var(--amber-text)}
.ni-icon.info{background:var(--blue-bg);color:var(--blue-text)}
.ni-icon.danger{background:var(--red-bg);color:var(--red-text)}
.ni-icon.ok{background:var(--green-bg);color:var(--green-text)}

/* OBAT */
.obat-group{border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:12px;background:#fff}
.obat-group h4{font-size:13px;font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.obat-row{display:grid;grid-template-columns:1fr 90px 120px 140px auto;gap:8px;align-items:center;margin-bottom:6px}
.obat-row select,.obat-row input{font-size:12px;padding:5px 8px;border-radius:var(--radius);border:1px solid var(--border2);background:#fff;color:var(--text)}

/* WILAYAH */
.wil-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem}
.wil-kec-title{font-size:13px;font-weight:600;padding:8px 12px;background:var(--bg3);border-radius:var(--radius);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.wil-desa-label{font-size:12px;color:var(--text2);padding:4px 10px;font-weight:500}
.wil-kel-title{font-size:12px;padding:3px 10px;border-radius:var(--radius);cursor:pointer}
.wil-kel-title:hover{background:var(--bg3)}
.pasien-mini{margin-left:20px;font-size:12px;color:var(--text2);padding:2px 8px}

/* USG */
.usg-section{border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:8px}
.usg-section h4{font-size:12px;font-weight:600;margin-bottom:8px;color:var(--text2)}

/* ALERT KLINIS */
#klinis-alert{border-radius:var(--radius);padding:10px 14px;font-size:13px;margin-bottom:10px;line-height:1.6}

/* FILTER ROW */
.filter-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:8px;align-items:end;padding:1rem 1.25rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1rem}

/* MODAL OVERLAY */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:100;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;width:500px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,0.18)}
.modal h2{font-size:16px;font-weight:600;margin-bottom:1rem;padding-bottom:0.75rem;border-bottom:1px solid var(--border)}

@media(max-width:768px){
  .sidebar{width:52px}.sidebar-logo p,.nav-item span,.sidebar-logo h2 span{display:none}
  .metrics{grid-template-columns:1fr 1fr}.grid3{grid-template-columns:1fr 1fr}.grid4{grid-template-columns:1fr 1fr}
  .filter-row{grid-template-columns:1fr 1fr}
}

/* LOGIN OVERLAY */
#login-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#1C4A4A 0%,#2D6E6E 50%,#2D6E6E00 100%),#1C3A3A;z-index:9999;display:flex;align-items:center;justify-content:center}
#login-box{background:#fff;border-radius:16px;padding:2rem 2.5rem;width:380px;max-width:95vw;box-shadow:0 20px 60px rgba(0,0,0,0.3)}
#login-box h1{font-size:20px;font-weight:700;margin-bottom:4px;color:#1a1a18}
#login-box p{font-size:13px;color:var(--text2);margin-bottom:1.5rem}
.pin-row{display:flex;gap:10px;justify-content:center;margin:1rem 0}
.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid #ccc;background:transparent;transition:all 0.15s}
.pin-dot.filled{background:#2D6E6E;border-color:#2D6E6E}
.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:1rem}
.pin-key{background:#f5f4f0;border:1px solid #e0ddd6;border-radius:10px;padding:14px;font-size:18px;font-weight:600;cursor:pointer;text-align:center;transition:background 0.1s;user-select:none}
.pin-key:hover{background:#e8e6e0}
.pin-key:active{background:#d8d5ce;transform:scale(0.95)}
.login-select{width:100%;font-size:14px;padding:9px 12px;border-radius:8px;border:1.5px solid #e0ddd6;background:#f5f4f0;color:#1a1a18;margin-bottom:1rem;outline:none}
.login-select:focus{border-color:#2D6E6E}
#login-err{display:none;color:#A32D2D;font-size:12px;text-align:center;margin-top:8px;padding:6px;background:#FCEBEB;border-radius:6px}
.user-bar{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--green-bg);border-radius:99px;font-size:12px;font-weight:500;color:var(--green-text);cursor:pointer;border:1px solid #7BABAB}
.user-bar i{font-size:14px}

/* ── Custom Date Picker ── */
.dp-wrap{position:relative;display:block}
.dp-cal{position:absolute;z-index:9999;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px;box-shadow:0 8px 24px rgba(0,0,0,0.15);min-width:260px;top:calc(100% + 4px);left:0}
.dp-cal.dp-right{left:auto;right:0}
.dp-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.dp-nav button{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text);padding:2px 8px;border-radius:6px;line-height:1}
.dp-nav button:hover{background:var(--bg3)}
.dp-nav span{font-weight:600;font-size:13px;cursor:pointer;padding:2px 8px;border-radius:6px}
.dp-nav span:hover{background:var(--bg3)}
.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}
.dp-grid .dh{font-size:10px;color:var(--text2);font-weight:600;padding:4px 0}
.dp-grid .dd{font-size:12px;padding:5px 2px;border-radius:5px;cursor:pointer;color:var(--text)}
.dp-grid .dd:hover{background:var(--bg3)}
.dp-grid .dd.today{font-weight:700;color:var(--green)}
.dp-grid .dd.sel{background:var(--green);color:#fff}
.dp-grid .dd.other{color:var(--text2)}
.dp-grid .dd.empty{cursor:default;pointer-events:none}
.dp-msel{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-bottom:6px}
.dp-msel div{font-size:12px;padding:8px 4px;border-radius:6px;cursor:pointer;text-align:center;color:var(--text)}
.dp-msel div:hover{background:var(--bg3)}
.dp-msel div.sel{background:var(--green);color:#fff}
.dp-ysel{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.dp-ysel div{font-size:12px;padding:8px 4px;border-radius:6px;cursor:pointer;text-align:center;color:var(--text)}
.dp-ysel div:hover{background:var(--bg3)}
.dp-ysel div.sel{background:var(--green);color:#fff}
