/* ═══════════════════════════════════════════════════════
   SIMANTAP-NR — style.css
   Semua CSS: tema dark/light, layout, komponen, panel
   ═══════════════════════════════════════════════════════ */
/* ═══════════════════════════════════════════
   SIMANTAP-NR THEME — Biru Royal + Gold
   Terinspirasi logo BC Ngurah Rai
═══════════════════════════════════════════ */
:root {
  /* DARK MODE (default) */
  --bg:#080d1a;--bg2:#0e1628;--bg3:#152035;--bg4:#1b2a45;
  --border:rgba(30,100,200,0.18);--border-hi:rgba(59,130,246,0.45);
  --text:#e8eef8;--text2:#7a9cc8;--text3:#344e78;
  --shadow:rgba(0,0,0,0.4);

  /* Accent: Biru Royal */
  --accent:#1a56db;--accent-hi:#3b82f6;--accent-glow:rgba(26,86,219,0.18);
  --accent-deep:#0f3a99;

  /* Gold: warna logo */
  --gold:#c9952a;--gold-hi:#f5c842;--gold-glow:rgba(201,149,42,0.15);
  --gold-deep:#8a6518;

  /* Status colors */
  --green:#059669;--green-hi:#10b981;--green-glow:rgba(5,150,105,0.15);
  --red:#dc2626;--red-hi:#ef4444;--red-glow:rgba(220,38,38,0.15);
  --orange:#d97706;--orange-hi:#f59e0b;--orange-glow:rgba(217,119,6,0.15);
  --purple:#7c3aed;--purple-hi:#8b5cf6;
  --teal:#0891b2;--teal-hi:#06b6d4;

  --font-mono:'IBM Plex Mono',monospace;
  --font-sans:'IBM Plex Sans',sans-serif;

  /* Login gradient */
  --login-grad:radial-gradient(ellipse at 30% 20%,rgba(26,86,219,0.12),transparent 60%),
               radial-gradient(ellipse at 70% 80%,rgba(201,149,42,0.08),transparent 60%);
}

/* LIGHT MODE */
[data-theme="light"] {
  --bg:#f0f4fb;--bg2:#ffffff;--bg3:#e8eef8;--bg4:#dde5f5;
  --border:rgba(26,86,219,0.15);--border-hi:rgba(26,86,219,0.4);
  --text:#0d1b3e;--text2:#3a5a9a;--text3:#7a99cc;
  --shadow:rgba(26,86,219,0.08);
  --accent:#1a56db;--accent-hi:#1245b8;--accent-glow:rgba(26,86,219,0.1);
  --accent-deep:#0f3a99;
  --gold:#b8841e;--gold-hi:#c9952a;--gold-glow:rgba(184,132,30,0.12);
  --gold-deep:#7a5510;
  --green:#047857;--green-hi:#059669;--green-glow:rgba(4,120,87,0.1);
  --red:#b91c1c;--red-hi:#dc2626;--red-glow:rgba(185,28,28,0.1);
  --orange:#b45309;--orange-hi:#d97706;--orange-glow:rgba(180,83,9,0.1);
  --purple:#6d28d9;--purple-hi:#7c3aed;
  --teal:#0e7490;--teal-hi:#0891b2;
  --login-grad:radial-gradient(ellipse at 30% 20%,rgba(26,86,219,0.07),transparent 60%),
               radial-gradient(ellipse at 70% 80%,rgba(201,149,42,0.05),transparent 60%);
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:14px;min-height:100vh;overflow-x:hidden;transition:background .3s,color .3s}
[data-theme="dark"] body::before{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.02) 2px,rgba(0,0,0,0.02) 4px);pointer-events:none;z-index:1000}

/* Pastikan app mengisi layar penuh secara vertikal */
.app.on{display:flex;flex-direction:column;height:100dvh;overflow:hidden}

/* LOGIN */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--login-grad),var(--bg)}
.login-box{width:100%;max-width:460px}
.login-logo{text-align:center;margin-bottom:28px}

/* Logo SIMANTAP di login */
.login-logo-img{width:140px;height:auto;object-fit:contain;margin-bottom:12px}
.login-logo h1{font-size:24px;font-weight:700;letter-spacing:.04em;margin-bottom:4px;
  background:linear-gradient(135deg,var(--accent-hi),var(--gold-hi));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.login-logo .login-subtitle{font-size:12px;color:var(--text2);letter-spacing:.04em}
.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:28px;
  box-shadow:0 8px 32px var(--shadow)}

/* Gold accent line di top login card */
.login-card::before{content:'';display:block;height:3px;background:linear-gradient(90deg,var(--accent),var(--gold-hi),var(--accent));border-radius:3px 3px 0 0;margin:-28px -28px 24px;border-radius:16px 16px 0 0}

.field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.field label{font-size:11px;font-weight:500;color:var(--text2);letter-spacing:.04em;text-transform:uppercase}
.field label span{color:var(--red-hi);margin-left:2px}
input[type=text],input[type=date],input[type=password],select,textarea{background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-sans);font-size:13px;padding:10px 13px;outline:none;transition:border-color .15s,background .3s;width:100%;-webkit-appearance:none}
input:focus,select:focus,textarea:focus{border-color:var(--accent-hi);background:var(--bg2)}
input::placeholder,textarea::placeholder{color:var(--text3)}
select{cursor:pointer}
select option{background:var(--bg3)}
textarea{resize:vertical;min-height:80px;line-height:1.5}
.btn-login{width:100%;background:linear-gradient(135deg,var(--accent),var(--accent-deep));border:none;border-radius:8px;color:#fff;font-family:var(--font-sans);font-size:14px;font-weight:600;padding:12px;cursor:pointer;transition:all .2s;margin-top:4px;letter-spacing:.02em}
.btn-login:hover{background:linear-gradient(135deg,var(--accent-hi),var(--accent));transform:translateY(-1px);box-shadow:0 4px 16px rgba(26,86,219,0.3)}
.demo-sep{text-align:center;font-size:11px;color:var(--text3);font-family:var(--font-mono);margin:20px 0 14px;letter-spacing:.08em}
.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.role-btn{background:var(--bg3);border:1px solid var(--border);border-radius:10px;color:var(--text2);font-family:var(--font-sans);font-size:12px;padding:10px 14px;cursor:pointer;transition:all .15s;text-align:left}
.role-btn:hover{border-color:var(--gold);color:var(--gold-hi);transform:translateY(-1px);background:var(--gold-glow)}
.role-btn .rn{font-weight:600;display:block;margin-bottom:3px;font-size:13px}
.role-btn .rd{font-size:11px;color:var(--text3)}

/* Maskot di login */
.login-maskot{position:fixed;bottom:0;right:24px;width:160px;opacity:.85;pointer-events:none;filter:drop-shadow(0 -4px 20px rgba(26,86,219,0.2))}
@media(max-width:600px){.login-maskot{width:100px;right:8px}}

/* APP SHELL */
/* APP SHELL — fullscreen tanpa header */
.app{display:none;flex-direction:column}
.app.on{display:flex;height:100dvh;overflow:hidden}
.proto-bar{background:rgba(201,149,42,.07);border-bottom:1px solid rgba(201,149,42,.2);padding:5px 20px;text-align:center;font-size:11px;color:var(--gold-hi);font-family:var(--font-mono);letter-spacing:.05em;flex-shrink:0}

/* SIDEBAR LAYOUT */
.app-body{display:flex;flex:1;overflow:hidden;position:relative}

/* SIDEBAR */
.sidebar{
  width:240px;flex-shrink:0;
  background:var(--bg2);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  height:100%;
  overflow-x:hidden;
  overflow-y:hidden;
  transition:transform .25s cubic-bezier(.4,0,.2,1),width .25s cubic-bezier(.4,0,.2,1);
  z-index:200;
  position:relative;
}
/* Collapsed (icon only) — desktop */
.sidebar.collapsed{width:52px}
.sidebar.collapsed .nav-label{opacity:0;width:0;overflow:hidden;white-space:nowrap;transition:opacity .15s,width .2s}
.sidebar.collapsed .nav-section-label{opacity:0;height:0;overflow:hidden;padding:0;margin:0;transition:all .2s}
.sidebar.collapsed .sidebar-brand-text{opacity:0;width:0;overflow:hidden;white-space:nowrap;transition:opacity .15s,width .2s}

/* Mobile: sidebar jadi overlay drawer */
@media(max-width:768px){
  .sidebar{
    position:fixed;left:0;top:0;bottom:0;
    height:100dvh;
    transform:translateX(-100%);
    z-index:400;
    box-shadow:4px 0 24px rgba(0,0,0,.4);
    width:240px!important;
  }
  .sidebar.open{transform:translateX(0)}
  .sidebar.collapsed{width:240px!important}
  .sidebar.collapsed .nav-label{opacity:1!important;width:auto!important}
  .sidebar.collapsed .nav-section-label{opacity:1!important;height:auto!important;padding:revert!important;margin:revert!important}
  .sidebar.collapsed .sidebar-brand-text{opacity:1!important;width:auto!important}
  .sidebar-overlay{display:block}
  .app-body{overflow:auto}
}

/* Overlay backdrop (mobile) */
.sidebar-overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);
  z-index:390;
  backdrop-filter:blur(2px);
  opacity:0;
  transition:opacity .25s;
}
.sidebar-overlay.on{opacity:1}

/* Sidebar header (brand + pin) */
.sidebar-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 10px 10px 12px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;height:52px;
  background:linear-gradient(180deg,var(--bg2) 0%,var(--bg3) 100%);
}
.sidebar-brand{display:flex;align-items:center;gap:8px;overflow:hidden}
.sidebar-brand-text{font-size:12px;font-weight:700;font-family:var(--font-mono);
  background:linear-gradient(135deg,var(--accent-hi),var(--gold-hi));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  white-space:nowrap;letter-spacing:.04em}
.sidebar-pin{background:none;border:1px solid var(--border);border-radius:6px;
  color:var(--text3);cursor:pointer;font-size:13px;width:28px;height:28px;
  display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.sidebar-pin:hover{border-color:var(--gold);color:var(--gold-hi)}
.sidebar-pin.pinned{background:var(--gold-glow);border-color:var(--gold);color:var(--gold-hi)}
/* hide pin on mobile */
@media(max-width:768px){.sidebar-pin{display:none}}

/* Sidebar nav list */
.sidebar-nav{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:8px 6px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.sidebar-nav::-webkit-scrollbar{width:3px}
.sidebar-nav::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}

.nav-section-label{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text3);font-family:var(--font-mono);padding:12px 8px 4px;transition:all .2s}

/* NAV ITEM — sidebar version */
.nav-item{
  background:none;border:none;
  color:var(--text2);
  font-family:var(--font-sans);font-size:13px;
  padding:9px 10px;
  cursor:pointer;
  white-space:nowrap;
  transition:all .15s;
  display:flex;align-items:center;gap:10px;
  width:100%;border-radius:8px;margin-bottom:2px;
  text-align:left;position:relative;overflow:hidden;
}
.nav-item:hover{color:var(--text);background:var(--bg3)}
.nav-item.on{
  color:var(--gold-hi);
  background:var(--gold-glow);
  border:1px solid rgba(201,149,42,.2);
  font-weight:600;
}
.nav-item.on::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;
  width:3px;background:var(--gold-hi);border-radius:0 3px 3px 0;
}
.nav-icon{font-size:15px;flex-shrink:0;width:20px;text-align:center;line-height:1}
.nav-label{transition:opacity .15s,width .2s;overflow:hidden;white-space:nowrap}

/* Sidebar footer (user info singkat) */
/* Hamburger lama — disembunyikan, diganti mobile-topbar */
.hamburger{display:none!important}

/* MAIN CONTENT */
.main{flex:1;overflow-y:auto;padding:24px 20px;width:100%}
.panel{display:none}.panel.on{display:block}

/* Hover-expand sidebar saat tidak di-pin (desktop only) */
@media(min-width:769px){
  .sidebar.collapsed:hover{width:240px}
  .sidebar.collapsed:hover .nav-label{opacity:1;width:auto}
  .sidebar.collapsed:hover .nav-section-label{opacity:1;height:auto;padding:12px 8px 4px;margin:0}
  .sidebar.collapsed:hover .sidebar-brand-text{opacity:1;width:auto}
  .sidebar.collapsed:hover .sb-user-text{opacity:1;width:auto}
  .sidebar.collapsed:hover .sb-controls-text{opacity:1;width:auto}
}

/* Header lama — sembunyikan */
.hdr{display:none!important}

/* Sidebar: brand subtitle */
.sidebar-brand-sub{font-size:10px;color:var(--text2);font-family:var(--font-mono);
  white-space:nowrap;letter-spacing:.03em;margin-top:1px}

/* Sidebar controls: theme + lang */
.sidebar-controls{
  padding:8px 10px;border-top:1px solid var(--border);
  display:flex;align-items:center;gap:6px;flex-shrink:0;background:var(--bg2);
  overflow:hidden;
}
.sb-controls-text{display:flex;gap:4px;overflow:hidden;transition:opacity .15s,width .2s}
.sidebar.collapsed .sb-controls-text{opacity:0;width:0}

/* Theme btn sidebar */
.theme-btn{background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  color:var(--text2);cursor:pointer;font-size:14px;width:30px;height:30px;
  display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.theme-btn:hover{border-color:var(--gold);color:var(--gold-hi)}

/* Lang toggle */
.lang-btn{background:var(--bg3);border:1px solid var(--border);border-radius:6px;
  color:var(--text2);cursor:pointer;font-size:10px;font-family:var(--font-mono);
  font-weight:600;padding:4px 7px;transition:all .15s;letter-spacing:.05em;white-space:nowrap}
.lang-btn:hover{border-color:var(--accent-hi);color:var(--accent-hi)}
.lang-btn.active{background:var(--accent-glow);border-color:var(--accent-hi);color:var(--accent-hi)}

/* Sidebar footer — user card klikable */
.sidebar-footer{
  border-top:1px solid var(--border);padding:10px 10px;flex-shrink:0;
  background:var(--bg3);cursor:pointer;transition:background .15s;
  position:relative;user-select:none;
  overflow:visible;
}
.sidebar-footer:hover{background:var(--bg4,var(--bg3))}
/* Hide footer sebelum login, show setelah login */
#sidebar-footer{display:none}
.app.on #sidebar-footer{display:block}
.sidebar-user{display:flex;align-items:center;gap:8px;overflow:hidden}
.sb-user-text{overflow:hidden;flex:1;transition:opacity .15s,width .2s}
.sidebar.collapsed .sb-user-text{opacity:0;width:0}
.sidebar-user-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:10px;color:var(--text2);font-family:var(--font-mono);white-space:nowrap}

/* Popup menu dari sidebar footer ke atas */
.sb-user-popup{
  position:absolute;bottom:calc(100% + 6px);left:8px;right:8px;
  background:var(--bg2);border:1px solid var(--border-hi);border-radius:10px;
  box-shadow:0 -6px 20px rgba(0,0,0,.3);overflow:hidden;z-index:500;
  display:none;animation:popupUp .15s cubic-bezier(.34,1.2,.64,1);
}
.sb-user-popup.on{display:block}
@keyframes popupUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.sb-popup-info{padding:10px 12px;border-bottom:1px solid var(--border);background:var(--bg3);display:flex;align-items:center;gap:9px}
.sb-popup-btn{width:100%;text-align:left;background:none;border:none;padding:9px 12px;
  font-size:13px;cursor:pointer;font-family:var(--font-sans);
  display:flex;align-items:center;gap:9px;color:var(--text);transition:background .12s}
.sb-popup-btn:hover{background:var(--bg3)}
.sb-popup-btn.danger{color:var(--red-hi)}
.sb-popup-btn.danger:hover{background:var(--red-glow)}
.sb-popup-sep{height:1px;background:var(--border)}

/* Avatar */
.uavatar{border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;flex-shrink:0;overflow:hidden}
.av-su{background:rgba(220,38,38,.2);color:var(--red-hi)}
.av-analis{background:var(--accent-glow);color:var(--accent-hi)}
.av-rao{background:var(--orange-glow);color:var(--orange-hi)}
.av-periksa{background:var(--green-glow);color:var(--green-hi)}
.uname{font-weight:500;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.urole{font-family:var(--font-mono);font-size:10px;color:var(--text2)}
.logout-btn{display:none}


.phdr{margin-bottom:20px}
.phdr h2{font-size:20px;font-weight:600;letter-spacing:-.02em;margin-bottom:4px}
.phdr p{font-size:13px;color:var(--text2)}

/* CARDS */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:16px}
.chdr{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.chdr h3{font-size:11px;font-weight:500;color:var(--text2);letter-spacing:.1em;text-transform:uppercase;font-family:var(--font-mono)}
.cbody{padding:20px}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}
.stat{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:border-color .15s,background .15s,transform .1s}
.stat:hover{border-color:var(--border-hi);transform:translateY(-1px)}
.stat.active{border-width:2px}
.stat.active-blue{border-color:var(--accent-hi);background:var(--accent-glow)}
.stat.active-orange{border-color:var(--orange-hi);background:var(--orange-glow)}
.stat.active-teal{border-color:var(--teal-hi);background:rgba(8,145,178,.12)}
.stat.active-red{border-color:var(--red-hi);background:var(--red-glow)}
.snum{font-size:26px;font-weight:600;font-family:var(--font-mono);line-height:1}
.slbl{font-size:11px;color:var(--text2);margin-top:6px}

/* FORM */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg.c3{grid-template-columns:1fr 1fr 1fr}
.fg.c1{grid-template-columns:1fr}
.s2{grid-column:span 2}

/* PILLS */
.pg{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.pill{position:relative}
.pill input{position:absolute;opacity:0;width:0;height:0}
.pill label{display:flex;align-items:center;gap:5px;background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:5px 13px;font-size:12px;color:var(--text2);cursor:pointer;transition:all .15s;user-select:none}
.pill input:checked+label{background:var(--accent-glow);border-color:var(--accent-hi);color:var(--accent-hi);font-weight:500}
.pill.npp input:checked+label{background:var(--red-glow);border-color:var(--red-hi);color:var(--red-hi)}
.pill.hvg input:checked+label{background:var(--orange-glow);border-color:var(--orange-hi);color:var(--orange-hi)}
.pill.uang input:checked+label{background:var(--green-glow);border-color:var(--green-hi);color:var(--green-hi)}
.pill.lain input:checked+label{background:rgba(124,58,237,.15);border-color:var(--purple-hi);color:var(--purple-hi)}
.pill.pos label{border-color:var(--red);color:var(--red-hi)}
.pill.pos input:checked+label{background:var(--red-glow);border-color:var(--red-hi);color:var(--red-hi);font-weight:600}
.pill.neg label{border-color:var(--green);color:var(--green-hi)}
.pill.neg input:checked+label{background:var(--green-glow);border-color:var(--green-hi);color:var(--green-hi);font-weight:600}

/* ANALIS */
.ag{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px}
.ap{position:relative}
.ap input{position:absolute;opacity:0;width:0;height:0}
.ap label{display:block;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--text2);cursor:pointer;transition:all .15s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ap input:checked+label{background:var(--accent-glow);border-color:var(--accent-hi);color:var(--accent-hi);font-weight:500}

/* ROUTE */
.route{display:flex;align-items:flex-start;gap:8px}
.rstep{flex:1}
.rcode{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.1em;margin-bottom:4px}
.rdesc{font-size:11px;color:var(--text2);margin-bottom:4px}
.rarrow{color:var(--text3);font-size:16px;padding-top:32px;flex-shrink:0}

/* BTNS */
.acts{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.btn{border-radius:8px;font-family:var(--font-sans);font-size:13px;font-weight:500;padding:9px 18px;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}
.btn-g{background:var(--green);color:#fff}.btn-g:hover{background:var(--green-hi)}
.btn-b{background:var(--accent);color:#fff}.btn-b:hover{background:var(--accent-hi)}
.btn-o{background:none;border:1px solid var(--border);color:var(--text2)}.btn-o:hover{border-color:var(--border-hi);color:var(--text)}
.btn-r{background:var(--red-glow);border:1px solid var(--red);color:var(--red-hi)}.btn-r:hover{background:var(--red)}

/* BADGES */
.bdg{font-size:10px;font-weight:500;padding:2px 8px;border-radius:4px;font-family:var(--font-mono)}
.bdg-npp{background:var(--red-glow);color:var(--red-hi)}
.bdg-hvg{background:var(--orange-glow);color:var(--orange-hi)}
.bdg-uang{background:var(--green-glow);color:var(--green-hi)}
.bdg-lain{background:rgba(124,58,237,.15);color:var(--purple-hi)}
.bdg-pending{background:var(--orange-glow);color:var(--orange-hi)}
.bdg-matched{background:rgba(6,182,212,.12);color:var(--teal-hi);border:1px solid var(--teal-hi)}
.bdg-selesai{background:var(--green-glow);color:var(--green-hi)}
.bdg-positif{background:var(--red-glow);color:var(--red-hi)}
.bdg-negatif{background:var(--green-glow);color:var(--green-hi)}

/* TARGET CARDS */
.tc{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:8px;transition:border-color .15s,background .15s}
.tc:hover{border-color:var(--border-hi);background:var(--bg3)}
.tname{font-weight:600;font-size:14px;margin-bottom:5px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.tmeta{font-size:12px;color:var(--text2);font-family:var(--font-mono);display:flex;flex-wrap:wrap;gap:10px;margin-bottom:4px}

/* MATCH */
.malert{border-radius:12px;padding:18px 20px;margin-bottom:16px}
.malert-r{background:var(--red-glow);border:1.5px solid var(--red);animation:blink .7s ease-in-out 6}
.malert-g{background:var(--green-glow);border:1px solid var(--green)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.55}}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.mtitle{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:4px}
.msub{font-size:13px;color:var(--text2)}

/* SCORE */
.srow{display:flex;align-items:center;padding:9px 0;border-bottom:1px solid var(--border);font-size:12px;gap:12px}
.srow:last-child{border-bottom:none}
.sbar{height:3px;border-radius:2px;background:var(--bg3);margin-top:3px;overflow:hidden;width:100%}
.sfill{height:100%;border-radius:2px;transition:width .5s}

/* DETAIL */
.dg{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;font-size:12px}
.dl{color:var(--text2);white-space:nowrap}
.dv{font-family:var(--font-mono);color:var(--text)}

/* FOTO */
.foto-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.foto-slot{background:var(--bg3);border:1.5px dashed var(--border-hi);border-radius:10px;aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;transition:all .15s;font-size:12px;color:var(--text2)}
.foto-slot:hover{border-color:var(--accent-hi);color:var(--accent-hi);background:var(--accent-glow)}
.foto-slot .fi{font-size:22px}
.foto-done{background:var(--bg3);border:1px solid var(--green);border-radius:10px;aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:11px;color:var(--green-hi);font-family:var(--font-mono);text-align:center;padding:8px}

/* VOICE NOTE */
.voice-box{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:16px;margin-top:10px}
.voice-controls{display:flex;align-items:center;gap:12px}
.rec-btn{width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .2s;flex-shrink:0}
.rec-btn.idle{background:var(--red-glow);border:1.5px solid var(--red);color:var(--red-hi)}
.rec-btn.idle:hover{background:var(--red);color:#fff;transform:scale(1.05)}
.rec-btn.recording{background:var(--red);color:#fff;animation:recpulse 1s ease-in-out infinite}
.rec-btn.done{background:var(--green-glow);border:1.5px solid var(--green);color:var(--green-hi)}
@keyframes recpulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.4)}50%{box-shadow:0 0 0 8px rgba(220,38,38,0)}}
.voice-info{flex:1}
.voice-status{font-size:13px;font-weight:500;margin-bottom:3px}
.voice-time{font-family:var(--font-mono);font-size:12px;color:var(--text2)}
.voice-wave{display:flex;align-items:center;gap:3px;height:24px;margin-top:8px}
.wave-bar{width:3px;border-radius:2px;background:var(--red-hi);animation:wave .6s ease-in-out infinite}
.wave-bar:nth-child(2){animation-delay:.1s;height:60%}
.wave-bar:nth-child(3){animation-delay:.2s;height:100%}
.wave-bar:nth-child(4){animation-delay:.3s;height:70%}
.wave-bar:nth-child(5){animation-delay:.4s;height:40%}
.wave-bar:nth-child(6){animation-delay:.5s;height:85%}
.wave-bar:nth-child(7){animation-delay:.15s;height:55%}
.wave-bar:nth-child(8){animation-delay:.35s;height:90%}
@keyframes wave{0%,100%{transform:scaleY(1)}50%{transform:scaleY(.3)}}
.audio-player{margin-top:10px;display:flex;align-items:center;gap:10px;background:var(--bg4);border-radius:8px;padding:10px 14px}
.play-btn{width:32px;height:32px;border-radius:50%;background:var(--accent);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;transition:background .15s}
.play-btn:hover{background:var(--accent-hi)}
.progress-bar{flex:1;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden;cursor:pointer}
.progress-fill{height:100%;width:0%;background:var(--accent);border-radius:2px;transition:width .1s}
.audio-time{font-family:var(--font-mono);font-size:11px;color:var(--text2);white-space:nowrap}

/* HASIL FORM */
.hasil-form{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:20px;margin-top:16px}
.auto-field{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 13px;font-size:13px;color:var(--text2);display:flex;align-items:center;gap:8px}
.auto-field .lock{font-size:11px;color:var(--text3)}

/* SEARCH */
.sbar-wrap{display:flex;gap:8px;margin-bottom:16px}
.sinput{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-sans);font-size:13px;padding:9px 14px;outline:none;transition:border-color .15s}
.sinput:focus{border-color:var(--border-hi)}

/* LAPORAN */
.li{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:8px}
.li.positif{border-color:var(--red)}
.li.negatif{border-color:var(--green)}
.li-result{background:var(--bg3);border-radius:6px;padding:8px 12px;margin-top:8px;font-size:12px;line-height:1.6}

/* INLINE HASIL BOX di Daftar Target */
.tc-hasil-box{border-radius:8px;padding:10px 14px;margin-top:10px;border-left:3px solid transparent}
.tc-hasil-positif{background:var(--red-glow);border-color:var(--red-hi);border:1px solid rgba(220,38,38,.3);border-left:3px solid var(--red-hi)}
.tc-hasil-negatif{background:var(--green-glow);border-color:var(--green-hi);border:1px solid rgba(5,150,105,.25);border-left:3px solid var(--green-hi)}

/* ADMIN */
.urow{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.urow:last-child{border-bottom:none}
.uinfo{flex:1}
.uname-t{font-weight:500;font-size:13px;margin-bottom:2px}

/* AUDIT */
.alog{display:flex;align-items:flex-start;gap:12px;padding:9px 0;border-bottom:1px solid var(--border);font-size:12px}
.alog:last-child{border-bottom:none}
.adot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:4px}

/* WATCHLIST */
.witem{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border)}
.witem:last-child{border-bottom:none}
.winfo{flex:1;min-width:0}
.wname{font-weight:500;font-size:11px;margin-bottom:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wmeta{font-size:10px;color:var(--text2);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Watchlist RAO — kolom kiri lebih lebar */
.rao-layout{display:grid;grid-template-columns:480px 1fr;gap:14px;align-items:start}
.rao-watchlist-box{max-height:calc(100vh - 220px);overflow-y:auto}
@media(max-width:900px){.rao-layout{grid-template-columns:1fr}}

/* Sembunyikan maskot di panel dashboard */
.dash-maskot,.dashboard-maskot,.maskot-dashboard,
#dash-maskot,#dashboard-maskot,#maskot-dashboard,
.panel img[class*="maskot"],.panel img[id*="maskot"],
#panel-dashboard img:not([id*="logo"]):not([class*="logo"]){display:none!important}

/* Panel full width */
.panel{width:100%}

/* TOAST */
.toast{position:fixed;bottom:20px;right:20px;background:var(--bg2);border:1px solid var(--green);border-radius:10px;padding:12px 18px;font-size:13px;display:flex;align-items:center;gap:10px;z-index:9999;transform:translateY(80px);opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);max-width:320px}
.toast.on{transform:translateY(0);opacity:1}

/* DIVIDER */
.div{height:1px;background:var(--border);margin:20px 0}

@media(max-width:640px){
  .stats{grid-template-columns:1fr 1fr}
  .fg,.fg.c3{grid-template-columns:1fr}
  .s2{grid-column:span 1}
  .route{flex-direction:column}
  .rarrow{padding-top:0;align-self:center;transform:rotate(90deg)}
  .foto-grid{grid-template-columns:1fr 1fr}
  .ag{grid-template-columns:1fr 1fr}
  .role-grid{grid-template-columns:1fr 1fr}
}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.8);z-index:500;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto}
.modal-overlay.on{display:flex}
.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:16px;width:100%;max-width:580px;margin:auto;animation:modalIn .25s cubic-bezier(.34,1.2,.64,1)}
@keyframes modalIn{from{opacity:0;transform:translateY(-16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-hdr{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg2);z-index:1;border-radius:16px 16px 0 0}
.modal-hdr h3{font-size:15px;font-weight:600;letter-spacing:-.01em}
.modal-close{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:14px;cursor:pointer;padding:4px 10px;border-radius:6px;line-height:1;transition:all .15s}
.modal-close:hover{color:var(--text);border-color:var(--border-hi)}
.modal-body{padding:20px}
.msection{margin-bottom:20px}
.msection:last-child{margin-bottom:0}
.msection-title{font-size:10px;font-weight:500;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;font-family:var(--font-mono);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.mrow{display:grid;grid-template-columns:130px 1fr;gap:5px 12px;font-size:12px;margin-bottom:5px;align-items:start}
.mlbl{color:var(--text2)}
.mval{font-family:var(--font-mono);color:var(--text);word-break:break-all}
.mval.hi{color:var(--accent-hi)}
.mval.alasan{font-family:var(--font-sans);color:var(--text2);line-height:1.6;background:var(--bg3);border-radius:6px;padding:8px 10px;margin-top:4px;grid-column:span 1}
.hasil-box{border-radius:10px;padding:14px 16px;font-size:12px;line-height:1.7}
.hasil-positif{background:var(--red-glow);border:1.5px solid var(--red)}
.hasil-negatif{background:var(--green-glow);border:1.5px solid var(--green)}
.hasil-pending{background:var(--bg3);border:1px solid var(--border)}
.tc-clickable{cursor:pointer;transition:border-color .15s,transform .1s}
.tc-clickable:hover{border-color:var(--accent-hi)!important;transform:translateX(2px)}

/* ═══════════════════════════════════════════════════════════
   MOBILE RESPONSIVE TAMBAHAN — SIMANTAP-NR
   ═══════════════════════════════════════════════════════════ */

/* Mobile topbar — default tersembunyi di desktop */
.mobile-topbar{display:none!important}

@media(max-width:768px){
  .main{
    padding:8px 12px 20px 12px !important;
  }
  .mobile-topbar{
    display:flex!important;align-items:center;gap:8px;
    padding:8px 0 10px;
    border-bottom:1px solid var(--border);
    margin-bottom:14px;
    position:sticky;top:0;
    background:var(--bg);
    z-index:100;
  }
  .mobile-menu-btn{
    background:var(--bg2);border:1px solid var(--border);border-radius:8px;
    color:var(--text2);cursor:pointer;width:34px;height:34px;
    display:flex;align-items:center;justify-content:center;
    transition:all .15s;flex-shrink:0;
  }
  .mobile-menu-btn:hover{border-color:var(--gold);color:var(--gold-hi)}
  .mobile-topbar-logo{
    width:24px;height:24px;object-fit:contain;flex-shrink:0;
  }
  .mobile-topbar-title{
    font-size:13px;font-weight:700;font-family:var(--font-mono);
    background:linear-gradient(135deg,var(--accent-hi),var(--gold-hi));
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
    letter-spacing:.04em;flex:1;
  }
  .mobile-topbar-avatar{
    width:30px;height:30px;font-size:11px;
    flex-shrink:0;cursor:pointer;
  }

  /* Panel header wrap rapi */
  .phdr{
    padding:12px 14px 10px !important;
    min-height:unset !important;
  }
  .phdr h2{font-size:16px !important}

  /* Sembunyikan padding-right besar (ruang maskot) */
  [style*="padding-right:130px"]{
    padding-right:0 !important;
  }

  /* Filter date row: wrap ke bawah */
  .phdr [style*="display:flex"]{
    flex-wrap:wrap !important;
    gap:6px !important;
  }

  /* Tabel: scroll horizontal */
  .cbody{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
  }
  table{min-width:560px}

  /* Card */
  .card{border-radius:10px !important}
  .chdr{padding:10px 14px !important;flex-wrap:wrap;gap:6px}
  .cbody{padding:12px 14px !important}

  /* Tombol: lebih besar untuk jari */
  .btn{
    min-height:36px !important;
    font-size:13px !important;
  }

  /* Toast: full width bawah */
  .toast{
    left:12px !important;
    right:12px !important;
    bottom:12px !important;
    max-width:unset !important;
  }

  /* Modal full width */
  .modal-box{
    max-width:100% !important;
    width:100% !important;
    margin:0 !important;
    border-radius:14px 14px 0 0 !important;
  }
  .modal-overlay{
    align-items:flex-end !important;
    padding:0 !important;
  }

  /* Grid form: 1 kolom */
  .fg{grid-template-columns:1fr !important}
  .fg.c2,.fg.c3{grid-template-columns:1fr !important}
  .s2{grid-column:span 1 !important}

  /* Search bar */
  .sbar-wrap{flex-direction:column;gap:6px}
  .sinput{font-size:14px}

  /* Foto grid: 2 kolom */
  .foto-grid{grid-template-columns:1fr 1fr !important}

  /* Stats: 2x2 */
  .stats{grid-template-columns:1fr 1fr !important;gap:8px !important}
  .stat{padding:12px 10px !important}
  .snum{font-size:22px !important}
  .slbl{font-size:11px !important}

  /* Input tab buttons: wrap */
  #inp-paste-btn, #itab-manual-btn{
    width:100%;
    justify-content:center;
  }
  [style*="display:flex;gap:6px;margin-bottom:16px"]{
    flex-direction:column !important;
  }

  /* Detail grid */
  .dg{grid-template-columns:1fr !important;gap:3px 0}
  .dl{color:var(--text3);font-size:11px}
  .dv{font-size:12px}

  /* Mrow di modal: 1 kolom */
  .mrow{grid-template-columns:1fr !important}
  .mlbl{font-size:10px;color:var(--text3)}
}

/* ── Handphone kecil (≤ 420px) ── */
@media(max-width:420px){
  .main{padding:52px 8px 16px 8px !important}
  .phdr h2{font-size:14px !important}
  .snum{font-size:20px !important}
  .btn{font-size:12px !important;padding:7px 12px !important}
  table th, table td{font-size:11px !important;padding:5px 7px !important}
  .chdr h3{font-size:10px !important}
  .login-box{width:96vw !important;padding:20px 14px !important}
}
