/* =====================================================================
   Auditor Indonesia — Sistem Desain (PHP build)
   Identitas visual mengikuti prototype: navy + gold + teal,
   Fraunces (display) + Spline Sans (body/utility).
   Responsif: desktop, tablet, mobile.
   ===================================================================== */

:root{
  --ink:#0d1b2a; --ink-2:#1b263b; --brand-secondary:#0f5257; --teal:#0f5257;
  --gold:#c79a3a; --gold-2:#e0b24a; --brand-btn:#c79a3a; --rust:#a8431f;
  --paper:#f7f4ec; --paper-2:#efe9dc; --line:#e3ddcf; --muted:#7c7563;
  --ok:#2f7d4f; --bad:#b23b3b; --warn:#b8860b; --info:#2c6e8f;
  --radius:14px; --shadow:0 8px 30px rgba(13,27,42,.08);
  --brand-primary:#0d1b2a;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:'Spline Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink); background:var(--paper); line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;line-height:1.2;font-weight:900}
.mono{font-family:'Spline Sans Mono',ui-monospace,monospace}

/* ---------- Layout shell ---------- */
.app-shell{display:grid;grid-template-columns:264px 1fr;min-height:100vh}
.sidebar{
  background:var(--ink);color:var(--paper);padding:1.4rem 1rem;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden;
}
.sidebar .brand{
  display:flex;align-items:center;gap:.5rem;color:#fff;font-size:1.1rem;font-weight:700;
  padding:0 .4rem 1.2rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.8rem;
}
.sidebar .brand .logo-img{height:32px;width:auto;border-radius:6px}
.sidebar .brand .seal{font-size:1.3rem}
.side-role{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-2);padding:0 .4rem;margin-bottom:.6rem}
#navMenu{flex:1;overflow-y:auto;padding-right:.2rem}
#navMenu::-webkit-scrollbar{width:6px}
#navMenu::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:3px}

.nav-item{
  display:flex;align-items:center;gap:.7rem;padding:.6rem .7rem;border-radius:9px;
  font-size:.88rem;font-weight:500;color:#c9c2b4;width:100%;text-align:left;
  background:none;border:none;cursor:pointer;transition:.18s;margin-bottom:.1rem;text-decoration:none;
}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:var(--brand-btn);color:var(--ink);font-weight:600}
.nav-item .i{width:20px;text-align:center;flex:none}
.nav-item .badge-n{margin-left:auto;background:var(--rust);color:#fff;font-size:.66rem;font-weight:700;padding:.05rem .45rem;border-radius:999px}
.nav-item.active .badge-n{background:var(--ink);color:#fff}

.nav-group{margin:.5rem 0 .15rem}
.nav-gtitle{
  display:flex;align-items:center;gap:.5rem;width:100%;padding:.4rem .7rem;
  font-size:.66rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  color:var(--gold-2);background:none;border:none;text-align:left;cursor:pointer;border-radius:8px;
}
.nav-gtitle:hover{background:rgba(255,255,255,.05)}
.nav-gtitle .chev{margin-left:auto;transition:.2s;font-size:.7rem;opacity:.7}
.nav-group.collapsed .chev{transform:rotate(-90deg)}
.nav-group.collapsed .nav-gbody{display:none}
.nav-gtitle .gbadge{background:var(--rust);color:#fff;font-size:.6rem;font-weight:700;padding:.05rem .4rem;border-radius:999px;margin-left:auto}
.nav-gtitle .gbadge + .chev{margin-left:.4rem}

.side-foot{margin-top:auto;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}
.user-chip{display:flex;align-items:center;gap:.6rem;padding:.55rem;border-radius:10px;background:rgba(255,255,255,.05);margin-bottom:.5rem}
.user-chip .av{width:36px;height:36px;border-radius:50%;background:var(--brand-btn);color:var(--ink);display:grid;place-items:center;font-weight:700;flex:none}
.user-chip .nm{font-size:.84rem;font-weight:600;color:#fff;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chip .em{font-size:.72rem;color:#9a937f;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---------- Main ---------- */
.main{display:flex;flex-direction:column;min-width:0}
.topbar-app{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1rem 1.6rem;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;
}
.topbar-app .crumb{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.topbar-app h2{font-size:1.3rem}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:8px;width:40px;height:40px;font-size:1.1rem;cursor:pointer}
.content{padding:1.6rem;flex:1}

/* ---------- Cards / panels ---------- */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:1.2rem;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.2rem;border-bottom:1px solid var(--line);flex-wrap:wrap}
.panel-head h3{font-size:1.05rem}
.panel-body{padding:1.2rem}
.panel-body.flush{padding:0}
.scroll-x{overflow-x:auto}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-bottom:1.6rem}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;position:relative;overflow:hidden}
.kpi::after{content:"";position:absolute;right:-20px;top:-20px;width:80px;height:80px;border-radius:50%;background:var(--paper-2)}
.kpi .lbl{font-size:.8rem;color:var(--muted);position:relative;z-index:1}
.kpi .val{font-family:'Fraunces',serif;font-size:2rem;font-weight:900;margin:.3rem 0;position:relative;z-index:1}
.kpi .sub{font-size:.78rem;color:var(--brand-secondary);position:relative;z-index:1}
.kpi .ic{position:absolute;right:14px;top:14px;font-size:1.3rem;z-index:1}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;font-size:.88rem}
thead th{text-align:left;font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:.7rem 1rem;border-bottom:1px solid var(--line);background:var(--paper)}
tbody td{padding:.7rem 1rem;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
.empty{text-align:center;color:var(--muted);padding:2rem!important}
.empty .e-ic{font-size:2rem;display:block;margin-bottom:.5rem}

/* ---------- Pills / badges ---------- */
.pill{display:inline-block;font-size:.72rem;font-weight:600;padding:.18rem .6rem;border-radius:999px;background:var(--paper-2);color:var(--ink)}
.pill-ok{background:#dcefe2;color:var(--ok)} .pill-bad{background:#f5dcdc;color:var(--bad)}
.pill-warn{background:#f6ecd2;color:var(--warn)} .pill-pend{background:#e7e2d5;color:var(--muted)}
.pill-info{background:#d8e8f0;color:var(--info)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-family:'Spline Sans';font-size:.9rem;font-weight:600;padding:.6rem 1.1rem;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:.18s;text-decoration:none;line-height:1}
.btn-sm{padding:.42rem .8rem;font-size:.82rem}
.btn-block{width:100%}
.btn-gold{background:var(--brand-btn);color:var(--ink)} .btn-gold:hover{background:var(--gold-2)}
.btn-dark{background:var(--ink);color:#fff} .btn-dark:hover{background:var(--ink-2)}
.btn-teal{background:var(--teal);color:#fff} .btn-teal:hover{filter:brightness(1.1)}
.btn-danger{background:var(--bad);color:#fff} .btn-danger:hover{filter:brightness(1.05)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)} .btn-ghost:hover{background:var(--paper)}
.icon-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:.9rem;transition:.15s}
.icon-btn:hover{background:var(--paper)}
.icon-btn.danger:hover{background:#f5dcdc;border-color:var(--bad)}
.icon-btn.ok:hover{background:#dcefe2;border-color:var(--ok)}
.row-actions{display:flex;gap:.35rem;flex-wrap:wrap}

/* ---------- Forms ---------- */
.field{margin-bottom:1rem}
.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.35rem;color:var(--ink-2)}
.field input,.field select,.field textarea,.search-in{
  width:100%;padding:.6rem .8rem;border:1px solid var(--line);border-radius:9px;
  font-family:inherit;font-size:.9rem;background:#fff;color:var(--ink);transition:.15s;
}
.field input:focus,.field select:focus,.field textarea:focus,.search-in:focus{outline:none;border-color:var(--brand-btn);box-shadow:0 0 0 3px rgba(199,154,58,.15)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
.full{grid-column:1/-1}
.drop{border:2px dashed var(--line);border-radius:10px;padding:1.4rem;text-align:center;color:var(--muted);font-size:.86rem;cursor:pointer;transition:.2s}
.drop:hover{border-color:var(--brand-btn);background:var(--paper)}
.hint{font-size:.78rem;color:var(--muted);text-align:center}

/* ---------- Alerts ---------- */
.alert{padding:.8rem 1rem;border-radius:10px;font-size:.86rem;margin-bottom:1rem;border:1px solid transparent}
.alert-info{background:#d8e8f0;border-color:#b5d3e3;color:var(--info)}
.alert-ok{background:#dcefe2;border-color:#b6dcc4;color:var(--ok)}
.alert-bad{background:#f5dcdc;border-color:#e6b9b9;color:var(--bad)}

/* ---------- Stat bars / ranking (webstats) ---------- */
.bar{height:8px;background:var(--paper-2);border-radius:999px;overflow:hidden}
.bar i{display:block;height:100%;background:var(--brand-btn);border-radius:999px}
.stat-bar-row{margin-bottom:.7rem}
.stat-bar-row .lbl{display:flex;justify-content:space-between;font-size:.82rem;margin-bottom:.25rem}
.rank-row{display:flex;align-items:center;gap:.7rem;padding:.5rem 0;border-bottom:1px solid var(--line)}
.rank-row:last-child{border-bottom:none}
.rank-row .rk{width:26px;height:26px;flex:none;border-radius:7px;background:var(--paper-2);color:var(--ink);display:grid;place-items:center;font-weight:700;font-size:.78rem}
.rank-row .rk.top{background:var(--brand-btn)}
.rank-row .rl{flex:1;min-width:0}
.rank-row .rl b{font-size:.86rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-row .rv{font-weight:700;font-size:.86rem;color:var(--brand-secondary)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}

/* ---------- Permission matrix table ---------- */
.perm-table th,.perm-table td{text-align:center}
.perm-table td:first-child,.perm-table th:first-child{text-align:left}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(13,27,42,.55);display:grid;place-items:center;z-index:100;padding:1rem}
.modal{background:#fff;border-radius:16px;width:100%;max-width:460px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow)}
.modal.modal-lg{max-width:700px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.3rem;border-bottom:1px solid var(--line)}
.modal-head h3{font-size:1.1rem}
.modal-head .x{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--muted);line-height:1}
.modal-body{padding:1.3rem}
.def-list{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1rem;font-size:.88rem}
.def-list dt{color:var(--muted)} .def-list dd{font-weight:600}

/* ---------- Toast ---------- */
#toastRoot{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:200}
.toast{background:var(--ink);color:#fff;padding:.8rem 1.2rem;border-radius:10px;font-size:.88rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.5rem;animation:toastIn .25s}
.toast .tk{color:var(--gold-2)}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---------- Auth pages ---------- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:1.5rem;background:linear-gradient(135deg,var(--ink),var(--brand-secondary))}
.auth-card{background:#fff;border-radius:18px;width:100%;max-width:420px;padding:2rem;box-shadow:var(--shadow)}
.auth-card .brand{display:flex;align-items:center;gap:.5rem;font-family:'Fraunces';font-weight:900;font-size:1.4rem;margin-bottom:.3rem}
.auth-card .brand .seal{color:var(--gold)}
.auth-sub{color:var(--muted);font-size:.88rem;margin-bottom:1.5rem}

/* =====================================================================
   RESPONSIF
   ===================================================================== */
@media(max-width:1024px){            /* Tablet */
  .app-shell{grid-template-columns:228px 1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .content{padding:1.2rem}
}
@media(max-width:768px){             /* Mobile */
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:fixed;z-index:60;width:280px;transform:translateX(-100%);transition:transform .25s}
  .sidebar.open{transform:none}
  .sidebar::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:-1;opacity:0;pointer-events:none;transition:.25s}
  .sidebar.open::after{opacity:1;pointer-events:auto}
  .burger{display:inline-flex;align-items:center;justify-content:center}
  .topbar-app{padding:.8rem 1rem}
  .topbar-app h2{font-size:1.1rem}
  .content{padding:1rem}
  .form-grid,.form-grid-3{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:1fr 1fr;gap:.8rem}
  .panel-head{padding:.9rem 1rem}
  .panel-body{padding:1rem}
}
@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr}
  .auth-card{padding:1.5rem}
  thead th,tbody td{padding:.6rem .7rem}
}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
