/* ============================================================
   AGE PERFORMA — design system DITURUNKAN dari pulsar.css (Sapa)
   tapi light surface + aksen merah AGE (#c0392b).
   Font: system-ui stack (woff2 Jakarta tidak disalin — fallback).
   ============================================================ */

:root{
  /* palette (light, token names mengikuti pulsar.css) */
  --bg:#f4f5f8; --surface:#ffffff; --surface-2:#f7f8fa; --surface-3:#eef0f4;
  --line:#e4e7ee; --line-2:#d4d9e3;
  --ink:#1d2530; --ink-soft:#3a4454; --muted:#68738a; --faint:#98a1b3;
  --accent:#c0392b; --accent-soft:#faeae7; --accent-glow:rgba(192,57,43,.22);
  /* status / severity (selaras pulsar, kontras utk light) */
  --st-ok:#0e9f6e; --st-warn:#c27803; --st-info:#1a56db; --st-mute:#6b7280; --st-bad:#c0392b;
  --sv-rendah:#0e9f6e; --sv-sedang:#c27803; --sv-tinggi:#dd6b20; --sv-darurat:#c0392b;
  --r:14px; --r-sm:10px; --r-xs:6px;
  --shadow:0 1px 2px rgba(23,30,45,.06), 0 8px 24px rgba(23,30,45,.07);
}
*{box-sizing:border-box}
body{margin:0;background:
    radial-gradient(900px 420px at 88% -8%, rgba(192,57,43,.06), transparent 60%),
    radial-gradient(700px 360px at 8% 4%, rgba(192,57,43,.03), transparent 55%),
    var(--bg);
  color:var(--ink);min-height:100dvh;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit}
code{background:var(--surface-3);border-radius:4px;padding:1px 5px;font-size:.9em}

/* ===== shell: sidebar kiri + main (pola Sapa/Nova) ===== */
.shell{display:flex;min-height:100dvh}
.sidebar{width:212px;flex:none;background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:12px 10px;position:sticky;top:0;height:100dvh;overflow:hidden;z-index:40;
  transition:width .16s ease}
.sbrand{display:flex;align-items:center;justify-content:flex-start;gap:9px;width:100%;flex:none;
  padding:4px 8px 10px;background:none;border:none;border-radius:var(--r-sm);cursor:pointer;
  transition:background .12s;font-family:inherit}
.sbrand:hover{background:var(--surface-3)}
.logo-badge{display:inline-flex;align-items:center;justify-content:center;flex:none;
  min-width:38px;height:28px;padding:0 7px;border-radius:8px;background:var(--accent);color:#fff;
  font-weight:800;font-size:13px;letter-spacing:.6px;box-shadow:0 2px 8px var(--accent-glow)}
.logo-badge.lg{min-width:52px;height:38px;font-size:17px;border-radius:11px}
.logo-word{font-weight:800;font-size:16px;letter-spacing:-.2px;color:var(--ink)}
.snav{display:flex;flex-direction:column;gap:1px;margin-top:4px;flex:1 1 auto;min-height:0;overflow-y:auto;
  scrollbar-width:none;-ms-overflow-style:none}
.snav::-webkit-scrollbar{width:0;height:0;display:none}
.snav a{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-sm);
  color:var(--ink-soft);text-decoration:none;font-size:13.5px;font-weight:600;transition:background .12s,color .12s}
.snav a svg{width:18px;height:18px;flex:none}
.snav a:hover{background:var(--surface-3);color:var(--ink)}
.snav a.on{background:var(--accent-soft);color:var(--accent)}
.sgroup{font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:var(--faint);margin:10px 11px 3px;font-weight:700}
.sgroup:first-child{margin-top:2px}
.sfoot{flex:none;margin-top:8px;padding-top:10px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}
.suser{display:flex;align-items:center;gap:9px;min-width:0;flex:1}
.savatar{width:30px;height:30px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-weight:800;
  display:flex;align-items:center;justify-content:center;font-size:13px;flex:none}
.sname{font-size:13px;font-weight:600;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  display:flex;flex-direction:column;line-height:1.25}
.sname small{font-size:10.5px;color:var(--faint);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.sfoot .out{color:var(--muted);display:flex}.sfoot .out svg{width:18px;height:18px}.sfoot .out:hover{color:var(--st-bad)}
.main{flex:1;min-width:0;padding:0 24px 60px;max-width:1520px}
.mhead{display:flex;align-items:center;gap:14px;padding:18px 0 14px;flex-wrap:wrap}
.mhead .mtitle{font-size:19px;font-weight:800;letter-spacing:-.3px;margin:0}
.ctx{font-size:12.5px;color:var(--muted);border-left:1px solid var(--line-2);padding-left:14px}
.ctx b{color:var(--ink-soft);font-weight:700}

/* ringkas sidebar ke icon-rail (klik logo) */
body.navmini .sidebar{width:62px;padding:14px 8px}
body.navmini .sgroup,body.navmini .snav a .nl,body.navmini .sname,body.navmini .logo-word{display:none}
body.navmini .sbrand{justify-content:center;padding:4px 0 10px}
body.navmini .snav a{justify-content:center;padding:10px 0;gap:0}
body.navmini .snav a svg{width:20px;height:20px}
body.navmini .sfoot{flex-direction:column;gap:10px}
body.navmini .suser{justify-content:center;flex:none}
@media(max-width:980px){.main{max-width:none;padding:0 16px 50px}}

/* ---- kpi strip ---- */
.kpis{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:13px 17px;min-width:150px;box-shadow:var(--shadow)}
.kpi .v{font-size:24px;font-weight:800;line-height:1.1}
.kpi .k{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:3px}
.kpi.alarm{border-color:var(--st-bad);background:linear-gradient(180deg,rgba(192,57,43,.07),var(--surface))}
.kpi.alarm .v{color:var(--st-bad)}

/* ---- panel ---- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px;margin-bottom:16px;box-shadow:var(--shadow)}
.panel h3{font-size:11.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:0 0 14px}
.pnote{margin:0;font-size:14px;color:var(--ink-soft);line-height:1.6;max-width:88ch}

/* ---- forms ---- */
.fld{margin-bottom:14px}
.fld label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}
input[type=text],input[type=password],input[type=date],input[type=number],input[type=time],
input[type=month],select,textarea{width:100%;background:var(--surface-2);color:var(--ink);
  border:1px solid var(--line-2);border-radius:var(--r-sm);padding:11px 12px;font-size:15px;font-family:inherit;appearance:none}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
select{cursor:pointer;background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2368738a' stroke-width='2' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 11px center;padding-right:38px}
.fgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 14px}
.fgrid .wide{grid-column:1 / -1}
@media(max-width:700px){.fgrid{grid-template-columns:1fr}}
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--accent);color:#fff;
  border:0;border-radius:var(--r-sm);padding:13px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;
  box-shadow:0 6px 20px var(--accent-glow)}
.btn:hover{filter:brightness(1.07)}
.btn:active{transform:translateY(1px)}
.btn.slim{width:auto;padding:9px 18px;font-size:13.5px;box-shadow:none}
.btn.ghost{background:var(--surface-3);color:var(--ink-soft);border:1px solid var(--line-2)}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent);filter:none}

/* ---- alert / saved ---- */
.alert{display:flex;gap:9px;background:rgba(192,57,43,.07);border:1px solid rgba(192,57,43,.35);color:#8f2318;
  border-radius:var(--r-sm);padding:11px 13px;font-size:13.5px;margin-bottom:14px}
.alert svg{width:17px;height:17px;flex:0 0 auto;margin-top:1px}
.saved{background:rgba(14,159,110,.1);color:#046c4e;border:1px solid rgba(14,159,110,.35);border-radius:var(--r-sm);
  padding:8px 12px;font-size:13px;font-weight:600;margin-bottom:12px;text-align:center}

/* ---- table ---- */
.scroll-x{overflow-x:auto}
.rtable{width:100%;border-collapse:collapse;font-size:13px;min-width:560px}
.rtable th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);
  font-weight:700;padding:10px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
.rtable td{padding:11px 12px;border-bottom:1px solid var(--line);color:var(--ink-soft);vertical-align:top}
.rtable tr:last-child td{border-bottom:0}
.rtable .rref{font-weight:700;color:var(--ink);white-space:nowrap}

/* ---- badges ---- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;padding:3px 8px;
  border-radius:999px;letter-spacing:.2px;white-space:nowrap;border:1px solid transparent;color:#fff}
.sev-rendah{background:var(--sv-rendah)}.sev-sedang{background:var(--sv-sedang)}
.sev-tinggi{background:var(--sv-tinggi)}.sev-darurat{background:var(--sv-darurat)}
.tag-line{background:transparent;border-color:var(--line-2);color:var(--muted)}
.role-admin{background:var(--accent)}.role-manager{background:var(--st-info)}.role-petugas{background:var(--st-mute)}

/* ---- SSO / magic link ---- */
.ssobtn{display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;
  background:var(--surface-2);border:1px solid var(--line-2);color:var(--ink-soft);border-radius:var(--r-sm);
  padding:10px 14px;font-size:13.5px;font-weight:700;transition:border-color .15s,color .15s}
.ssobtn:hover{border-color:var(--accent);color:var(--accent)}
.ssobtn:active{transform:translateY(1px)}
.ssohint{font-size:11.5px;color:var(--faint);line-height:1.45;margin:12px 2px 0;text-align:center}
.ordiv{display:flex;align-items:center;gap:10px;color:var(--faint);font-size:10.5px;margin:16px 0;
  text-transform:uppercase;letter-spacing:.5px}
.ordiv::before,.ordiv::after{content:"";flex:1;height:1px;background:var(--line)}
.ssolink{background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--r);padding:14px 16px;margin-bottom:16px}
.ssolink-h{font-size:13px;color:var(--ink);font-weight:600;margin-bottom:9px}
.ssolink-row{display:flex;gap:8px;align-items:center}
.ssolink-row input{flex:1;min-width:0;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-xs);
  color:var(--ink);font-family:inherit;font-size:13px;padding:8px 10px}
.ssolink-hint{font-size:11.5px;color:var(--muted);margin:8px 0 0;line-height:1.45}

/* ---- halaman login ---- */
.login{max-width:380px;margin:9vh auto 0;padding:0 20px}
.login .lhead{text-align:center;margin-bottom:22px}
.login .brandmark{display:flex;justify-content:center;margin-bottom:12px}
.login h1{font-size:20px;font-weight:800;margin:0}
.login p{color:var(--muted);font-size:13.5px;margin:5px 0 0}
.foot{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--faint);font-size:11.5px;margin-top:22px}

/* ---- checkbox row (misspoint) ---- */
.checkrow{display:flex;flex-wrap:wrap;gap:8px}
.check{display:inline-flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--line-2);
  border-radius:var(--r-sm);padding:8px 12px;font-size:13.5px;font-weight:600;color:var(--ink-soft);cursor:pointer;user-select:none}
.check input{accent-color:var(--accent);width:15px;height:15px;cursor:pointer}
.check:has(input:checked){border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}

/* ---- charts (ECharts vendored) ---- */
.chartgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:980px){.chartgrid{grid-template-columns:1fr}}
.chartbox{width:100%;height:260px}
.chartbox.tall{height:340px}

/* ---- tautan eksternal (Metabase) ---- */
.mblinks{display:flex;flex-wrap:wrap;gap:10px}
.mblinks a{display:inline-flex;align-items:center;gap:7px;text-decoration:none;font-size:13px;font-weight:700;
  color:var(--ink-soft);background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:9px 14px}
.mblinks a:hover{border-color:var(--accent);color:var(--accent)}

/* ---- aksi inline tabel (Kelola Akses) ---- */
.rowactions{display:flex;flex-wrap:wrap;gap:6px}
.rowactions form{margin:0}
.btn.tiny{width:auto;padding:6px 11px;font-size:12px;box-shadow:none;border-radius:var(--r-xs)}
.alink{display:inline-block;padding:6px 11px;font-size:12px;font-weight:700;color:var(--ink-soft);text-decoration:none;
  background:var(--surface-3);border:1px solid var(--line-2);border-radius:var(--r-xs)}
.alink:hover{border-color:var(--accent);color:var(--accent)}

/* focus-visible (a11y keyboard) */
a:focus-visible,.btn:focus-visible,.out:focus-visible,select:focus-visible,
.sbrand:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-xs)}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
