:root{--b9:#071525;--b8:#0c1e36;--b7:#112847;--b6:#1a3a6b;--b5:#1d4ed8;--b4:#2563eb;--b3:#3b82f6;--b2:#93c5fd;--b1:#dbeafe;--b0:#eff6ff;--ac:#0ea5e9;--gr:#10b981;--re:#ef4444;--or:#f59e0b;--pu:#8b5cf6;--wh:#fff;--g50:#f8fafc;--g100:#f1f5f9;--g200:#e2e8f0;--g300:#cbd5e1;--g400:#94a3b8;--g500:#64748b;--g600:#475569;--g700:#334155;--sw:256px;--th:60px;--r:12px;--rs:8px;--sh:0 1px 3px rgba(0,0,0,.07),0 4px 16px rgba(0,0,0,.05);--shm:0 4px 24px rgba(29,78,216,.14);--tr:.16s cubic-bezier(.4,0,.2,1);
--bg-body:#f8fafc;--bg-card:#ffffff;--bg-topbar:#ffffff;--border-card:#f1f5f9;--border-topbar:#e2e8f0;--text-main:#334155;--text-sub:#64748b;--text-muted:#94a3b8;--input-bg:#ffffff;--input-border:#e2e8f0}
/* ══ DARK MODE — KOMPREHENSIF ══ */
[data-theme="dark"]{
  --g50:#0f172a;--g100:#1e293b;--g200:#334155;--g300:#475569;
  --g400:#64748b;--g500:#94a3b8;--g600:#cbd5e1;--g700:#e2e8f0;
  --wh:#0f172a;--b0:#1a2f4a;--b1:#1e3a8a;--b2:#3b82f6;
  --sh:0 1px 3px rgba(0,0,0,.3),0 4px 16px rgba(0,0,0,.2);
  --shm:0 4px 24px rgba(37,99,235,.2)
}
/* Base */
[data-theme="dark"] body{background:#0f172a;color:#e2e8f0}
[data-theme="dark"] .main{background:#0f172a}
/* Page header titles */
[data-theme="dark"] .ph h1{color:#f1f5f9}
[data-theme="dark"] .ph p{color:#94a3b8}
/* Topbar */
[data-theme="dark"] .tb{background:#1e293b;border-color:#334155}
[data-theme="dark"] .tb-title{color:#f1f5f9}
[data-theme="dark"] .tb-search{background:#0f172a;border-color:#334155}
[data-theme="dark"] .tb-search input{color:#e2e8f0}
[data-theme="dark"] .tb-search:focus-within{background:#1e293b;border-color:var(--b3)}
[data-theme="dark"] .ib{background:#334155;color:#94a3b8}
[data-theme="dark"] .ib:hover{background:#1e3a5f;color:var(--b3)}
/* Cards */
[data-theme="dark"] .card{background:#1e293b;border-color:#334155}
[data-theme="dark"] .ch{border-color:#334155}
[data-theme="dark"] .ct{color:#f1f5f9}
[data-theme="dark"] .cb{color:#e2e8f0}
/* Stat cards */
[data-theme="dark"] .sc{background:#1e293b;border-color:#334155}
[data-theme="dark"] .sv{color:#f1f5f9}
[data-theme="dark"] .sl{color:#64748b}
[data-theme="dark"] .sd{color:#94a3b8}
[data-theme="dark"] .sico.bl{background:#1e3a5f}
[data-theme="dark"] .sico.gr{background:#0d2b1f}
[data-theme="dark"] .sico.re{background:#2d1515}
[data-theme="dark"] .sico.or{background:#2d2010}
[data-theme="dark"] .sico.pu{background:#1e1535}
[data-theme="dark"] .sico.cy{background:#0d2535}
/* Table */
[data-theme="dark"] th{background:#0f172a;color:#64748b;border-color:#334155}
[data-theme="dark"] td{color:#cbd5e1;border-color:#1e293b}
[data-theme="dark"] .td-n{color:#f1f5f9}
[data-theme="dark"] .td-m{color:#94a3b8}
[data-theme="dark"] tr:hover td{background:#1e3a5f}
/* Forms */
[data-theme="dark"] .fc{background:#0f172a;border-color:#334155;color:#e2e8f0}
[data-theme="dark"] .fc:focus{border-color:var(--b3)}
[data-theme="dark"] .fc::placeholder{color:#475569}
[data-theme="dark"] select.fc option{background:#1e293b;color:#e2e8f0}
[data-theme="dark"] .fg label{color:#94a3b8}
/* Buttons */
[data-theme="dark"] .btn.bs{background:#1e293b;color:#cbd5e1;border-color:#334155}
[data-theme="dark"] .btn.bs:hover{border-color:var(--b3);color:var(--b3)}
[data-theme="dark"] .btn.bd{background:#2d1515;color:#fca5a5;border-color:#7f1d1d}
[data-theme="dark"] .btn.bsc{background:#0d2b1f;color:#6ee7b7;border-color:#065f46}
/* Filter bar */
[data-theme="dark"] .fp{background:#1e293b;border-color:#334155;color:#94a3b8}
[data-theme="dark"] .fp.ac,[data-theme="dark"] .fp:hover{background:#1e3a5f;border-color:var(--b3);color:var(--b2)}
[data-theme="dark"] .sb-input{background:#1e293b;border-color:#334155}
[data-theme="dark"] .sb-input input{color:#e2e8f0}
[data-theme="dark"] .sb-input input::placeholder{color:#475569}
/* Modal */
[data-theme="dark"] .mo{background:rgba(0,0,0,.75)}
[data-theme="dark"] .md{background:#1e293b}
[data-theme="dark"] .mh{border-color:#334155}
[data-theme="dark"] .mh h3{color:#f1f5f9}
[data-theme="dark"] .mc{color:#64748b}
[data-theme="dark"] .mc:hover{background:#334155;color:#cbd5e1}
[data-theme="dark"] .mf{border-color:#334155}
[data-theme="dark"] .mb{color:#e2e8f0}
/* Pagination */
[data-theme="dark"] .pag{border-color:#334155}
[data-theme="dark"] .pag-info{color:#64748b}
[data-theme="dark"] .pag-btn{background:#1e293b;border-color:#334155;color:#cbd5e1}
[data-theme="dark"] .pag-btn:hover{border-color:var(--b3);color:var(--b3)}
[data-theme="dark"] .pag-btn.ac{background:var(--b4);border-color:var(--b4);color:#fff}
/* Charts & viz */
[data-theme="dark"] .bc .bl2{color:#64748b}
[data-theme="dark"] .pb{background:#334155}
[data-theme="dark"] .dnut .dt strong{color:#f1f5f9}
[data-theme="dark"] .dnut .dt span{color:#64748b}
/* Donut text */
[data-theme="dark"] svg text[fill="var(--b9)"]{fill:#f1f5f9 !important}
[data-theme="dark"] svg text[fill="var(--g400)"]{fill:#64748b !important}
/* Timeline */
[data-theme="dark"] .ti{border-color:#334155}
[data-theme="dark"] .tc2 .tt{color:#f1f5f9}
[data-theme="dark"] .tc2 .ts{color:#64748b}
/* Billing row */
[data-theme="dark"] .bil-r{border-color:#334155}
[data-theme="dark"] .bil-nm{color:#f1f5f9}
[data-theme="dark"] .bil-pk{color:#64748b}
[data-theme="dark"] .bil-am{color:#f1f5f9}
/* Isolir warning */
[data-theme="dark"] .iw{background:linear-gradient(90deg,#2d1515,#1e293b);border-color:#7f1d1d}
[data-theme="dark"] .iw p{color:#94a3b8}
/* Packages */
[data-theme="dark"] .pkc{background:#1e293b;border-color:#334155}
[data-theme="dark"] .pkc:hover{border-color:var(--b3)}
[data-theme="dark"] .pkc.pop{background:#1a2f4a;border-color:var(--b4)}
[data-theme="dark"] .pk-nm{color:#f1f5f9}
[data-theme="dark"] .pk-pr{color:#f1f5f9}
[data-theme="dark"] .pk-spd{color:var(--b3)}
[data-theme="dark"] .pk-us{color:#64748b}
/* Riwayat */
[data-theme="dark"] .rw-item{border-color:#334155}
[data-theme="dark"] .rw-ico{background:#0d2b1f}
/* Invoice */
[data-theme="dark"] .inv-body{background:#1e293b;border-color:#334155;color:#e2e8f0}
[data-theme="dark"] .inv-footer{background:#1e293b;border-color:#334155}
[data-theme="dark"] .inv-body strong,.inv-body .td-n{color:#f1f5f9}
/* Inline style color overrides — covers hardcoded color:var(--b9) in inline styles */
[data-theme="dark"] .ph h1,[data-theme="dark"] .ct,[data-theme="dark"] .sv,
[data-theme="dark"] .pk-nm,[data-theme="dark"] .pk-pr,[data-theme="dark"] .mh h3,
[data-theme="dark"] .bil-nm,[data-theme="dark"] .td-n{color:#f1f5f9}
/* Sections with hardcoded dark text in inline styles */
[data-theme="dark"] [style*="color:var(--b9)"]{color:#f1f5f9 !important}
[data-theme="dark"] [style*="color:var(--g700)"]{color:#e2e8f0 !important}
[data-theme="dark"] [style*="color:var(--g600)"]{color:#cbd5e1 !important}
[data-theme="dark"] [style*="color:var(--g500)"]{color:#94a3b8 !important}
[data-theme="dark"] [style*="color:var(--g400)"]{color:#64748b !important}
[data-theme="dark"] [style*="color:var(--b9);font"]{color:#f1f5f9 !important}
/* Background overrides for inline styles */
[data-theme="dark"] [style*="background:var(--g50)"]{background:#0f172a !important}
[data-theme="dark"] [style*="background:var(--g100)"]{background:#1e293b !important}
[data-theme="dark"] [style*="background:var(--b0)"]{background:#1a2f4a !important}
[data-theme="dark"] [style*="background:#fff"]{background:#1e293b !important}
[data-theme="dark"] [style*="background:#ecfdf5"]{background:#0d2b1f !important}
[data-theme="dark"] [style*="background:#fef2f2"]{background:#2d1515 !important}
[data-theme="dark"] [style*="background:#fffbeb"]{background:#2d2010 !important}
[data-theme="dark"] [style*="background:#f5f3ff"]{background:#1e1535 !important}
[data-theme="dark"] [style*="background:#f8fafc"]{background:#0f172a !important}
[data-theme="dark"] [style*="background:#f1f5f9"]{background:#1e293b !important}
/* Border overrides */
[data-theme="dark"] [style*="border-bottom:1px solid var(--g100)"]{border-color:#334155 !important}
[data-theme="dark"] [style*="border-color:var(--g200)"]{border-color:#334155 !important}
/* Strong/bold text that hardcodes dark color */
[data-theme="dark"] [style*="font-weight:700"][style*="color:var(--b9)"]{color:#f1f5f9 !important}
[data-theme="dark"] [style*="font-weight:600"][style*="color:var(--b9)"]{color:#f1f5f9 !important}
[data-theme="dark"] [style*="font-weight:800"][style*="color:var(--b9)"]{color:#f1f5f9 !important}
/* Finance & chart areas */
[data-theme="dark"] .bc .bcol div[style*="color:var(--g400)"]{color:#475569 !important}
/* Import dropzone */
[data-theme="dark"] #importDropzone{background:#0f172a !important;border-color:#334155 !important}
[data-theme="dark"] #importDropzone div[style*="color:var(--g600)"]{color:#94a3b8 !important}
/* Settings info box */
[data-theme="dark"] [style*="color:var(--b5)"]{color:#93c5fd !important}
/* Toast */
[data-theme="dark"] .toast-item{background:#1e293b;color:#e2e8f0}
/* pkg dist chart labels */
[data-theme="dark"] [style*="font-weight:600;color:var(--g700)"]{color:#cbd5e1 !important}
[data-theme="dark"] [style*="font-weight:700;color:var(--b9)"]{color:#f1f5f9 !important}
/* Riwayat modal body items */
[data-theme="dark"] .rw-item [style*="color:var(--b9)"]{color:#f1f5f9 !important}
[data-theme="dark"] .rw-item [style*="color:var(--gr)"]{color:#34d399 !important}
/* User list cards */
[data-theme="dark"] [style*="background:var(--g50);border-radius"]{background:#0f172a !important}
/* Info boxes with blue bg */
[data-theme="dark"] [style*="background:var(--b0);border-radius"]{background:#1a2f4a !important}
[data-theme="dark"] [style*="color:var(--b5);line-height"]{color:#93c5fd !important}
/* Tabs */
[data-theme="dark"] .tabs{background:#334155}
[data-theme="dark"] .tab{color:#94a3b8}
[data-theme="dark"] .tab.ac{background:#1e293b;color:var(--b3)}
/* Map area */
[data-theme="dark"] .map-counter{background:rgba(30,41,59,.95);color:#f1f5f9}
[data-theme="dark"] .map-legend{background:rgba(15,23,42,.95)}
[data-theme="dark"] .li-item{color:#cbd5e1}
/* Traffic section inline text */
[data-theme="dark"] [style*="color:var(--g500)"]:not(.badge):not(.sico){color:#94a3b8 !important}
/* Donut legend */
[data-theme="dark"] .dl .dt strong{color:#f1f5f9}
[data-theme="dark"] .dl .dt span{color:#64748b}
/* Invoice wrap */
[data-theme="dark"] .inv-wrap [style*="color:var(--g500)"]{color:#94a3b8 !important}
[data-theme="dark"] .inv-wrap [style*="color:var(--g700)"]{color:#e2e8f0 !important}
[data-theme="dark"] .inv-wrap [style*="color:var(--b9)"]{color:#f1f5f9 !important}
[data-theme="dark"] .inv-wrap table td{color:#cbd5e1;border-color:#334155}
/* Activity log */
[data-theme="dark"] #activityLog tr td{color:#cbd5e1}
/* Scroll bars */
[data-theme="dark"] ::-webkit-scrollbar{width:6px;height:6px}
[data-theme="dark"] ::-webkit-scrollbar-track{background:#0f172a}
[data-theme="dark"] ::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover{background:#475569}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--g50);color:var(--g700);min-height:100vh;overflow-x:hidden}
/* LOGIN */
#loginScreen{position:fixed;inset:0;background:linear-gradient(135deg,var(--b9) 0%,var(--b7) 50%,var(--b8) 100%);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}
#loginScreen::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 30%,rgba(37,99,235,.25) 0%,transparent 60%),radial-gradient(ellipse at 70% 70%,rgba(14,165,233,.15) 0%,transparent 60%);pointer-events:none}
.lbox{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:40px 36px;width:100%;max-width:400px;backdrop-filter:blur(20px);box-shadow:0 32px 80px rgba(0,0,0,.4);position:relative;z-index:1}
.llogo{display:flex;align-items:center;gap:13px;margin-bottom:28px;justify-content:center}
.licon{width:52px;height:52px;background:linear-gradient(135deg,var(--b4),var(--ac));border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:#fff;box-shadow:0 8px 24px rgba(37,99,235,.5)}
.ltitle{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:#fff}
.lsub{font-size:11px;color:var(--b2);letter-spacing:1.5px;text-transform:uppercase;margin-top:1px}
.llbl{font-size:11.5px;font-weight:600;color:rgba(255,255,255,.6);display:block;margin-bottom:5px}
.linp{width:100%;padding:11px 14px;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.12);border-radius:9px;color:#fff;font-size:13.5px;font-family:'DM Sans',sans-serif;outline:none;transition:border-color var(--tr);margin-bottom:14px}
.linp:focus{border-color:var(--b3);background:rgba(255,255,255,.12)}
.linp::placeholder{color:rgba(255,255,255,.3)}
.lbtn{width:100%;padding:12px;background:linear-gradient(135deg,var(--b4),var(--b5));border:none;border-radius:9px;color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:'Syne',sans-serif;transition:all var(--tr);margin-top:4px;box-shadow:0 4px 16px rgba(37,99,235,.4)}
.lbtn:hover{box-shadow:0 6px 24px rgba(37,99,235,.6);transform:translateY(-1px)}
.lhint{font-size:11px;color:rgba(255,255,255,.3);text-align:center;margin-top:14px}
.lerr{font-size:12px;color:#fca5a5;background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);border-radius:7px;padding:8px 12px;margin-bottom:12px;display:none}
/* IDB LOADING */
#idbLoad{position:fixed;inset:0;background:var(--b9);z-index:9998;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}
.idb-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--b4),var(--ac));border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:#fff;font-family:'Syne',sans-serif;box-shadow:0 12px 36px rgba(37,99,235,.5)}
#idbLoad p{font-size:13px;color:var(--b2)}
.idb-bar{width:180px;height:4px;background:rgba(255,255,255,.1);border-radius:4px;overflow:hidden}
.idb-bar-fill{height:100%;background:linear-gradient(90deg,var(--b4),var(--ac));border-radius:4px;animation:idbP 1.8s ease forwards}
@keyframes idbP{from{width:0}to{width:100%}}
/* SIDEBAR */
.sb{position:fixed;left:0;top:0;bottom:0;width:var(--sw);background:var(--b9);display:flex;flex-direction:column;z-index:1000;transition:transform var(--tr)}
.sb::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 20%,rgba(37,99,235,.18) 0%,transparent 60%);pointer-events:none}
.sb-logo{padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:11px;flex-shrink:0}
.li{width:40px;height:40px;background:linear-gradient(135deg,var(--b4),var(--ac));border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:#fff;box-shadow:0 4px 14px rgba(37,99,235,.45);flex-shrink:0}
.lt strong{display:block;font-family:'Syne',sans-serif;font-size:15px;font-weight:800;color:#fff;letter-spacing:.3px}
.lt span{font-size:9.5px;color:var(--b2);letter-spacing:1.8px;text-transform:uppercase}
.sb-nav{flex:1;overflow-y:auto;padding:10px 0}
.sb-nav::-webkit-scrollbar{width:3px}
.sb-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
.nsl{padding:14px 18px 5px;font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.25)}
.ni{display:flex;align-items:center;gap:10px;padding:8.5px 14px 8.5px 18px;margin:1px 8px;border-radius:8px;color:rgba(255,255,255,.55);cursor:pointer;transition:all var(--tr);font-size:13px;font-weight:500;user-select:none}
.ni:hover{background:rgba(255,255,255,.07);color:#fff}
.ni.ac{background:linear-gradient(90deg,rgba(37,99,235,.45),rgba(37,99,235,.15));color:#fff;box-shadow:inset 3px 0 0 var(--b3)}
.ni .ico{font-size:15px;width:28px;height:28px;border-radius:9px;background:transparent;text-align:center;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:transform var(--tr)}
.ni:hover .ico,.ni.ac .ico{transform:translateY(-1px)}
.yn-emoji-icon{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;line-height:1;font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif;filter:drop-shadow(0 1px 1px rgba(0,0,0,.22));flex-shrink:0}
.ni .ico .yn-emoji-icon{font-size:19px}
.ib .yn-emoji-icon{font-size:19px}
.tb-search .yn-emoji-icon{font-size:17px}
.nsl .yn-emoji-icon{font-size:15px;margin-right:6px;vertical-align:-3px}
.nbadge{margin-left:auto;font-size:10px;font-weight:700;background:var(--re);color:#fff;padding:2px 6px;border-radius:20px;min-width:18px;text-align:center}
.nbadge.or{background:var(--or)}.nbadge.gr{background:var(--gr)}
.sb-foot{padding:14px 18px;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px;flex-shrink:0}
.av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--b4),var(--ac));display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;flex-shrink:0;font-family:'Syne',sans-serif}
.ui strong{display:block;font-size:12px;color:#fff;font-weight:600}
.ui span{font-size:10px;color:var(--b2)}
/* TOPBAR */
.tb{position:fixed;top:0;left:var(--sw);right:0;height:var(--th);background:#fff;border-bottom:1px solid var(--g200);display:flex;align-items:center;gap:10px;padding:0 20px;z-index:200;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.mt{display:none;background:none;border:none;font-size:20px;cursor:pointer;color:var(--g600);padding:4px 8px;border-radius:6px}
.mt:hover{background:var(--g100)}
.tb-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;color:var(--b9);flex:1}
.tb-search{display:flex;align-items:center;gap:7px;background:var(--g100);border-radius:8px;padding:7px 12px;width:240px;border:1.5px solid transparent;transition:all var(--tr)}
.tb-search:focus-within{border-color:var(--b3);background:#fff;width:280px;box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.tb-search input{border:none;background:none;outline:none;font-size:13px;width:100%;font-family:'DM Sans',sans-serif;color:var(--g700)}
.tb-search input::placeholder{color:var(--g400)}
.tb-acts{display:flex;gap:5px}
.ib{width:34px;height:34px;border-radius:8px;background:var(--g100);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--g500);transition:all var(--tr);position:relative}
.ib:hover{background:var(--b0);color:var(--b4)}
.nd{position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;background:var(--re);border:1.5px solid #fff}
.av-top{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--b4),var(--ac));display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;cursor:pointer;border:2px solid var(--b1);font-family:'Syne',sans-serif}
/* MAIN */
.main{margin-left:var(--sw);padding-top:var(--th);min-height:100vh}
.pg{display:none;padding:22px;animation:fadeUp .2s ease}
.pg.ac{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
/* STATS */
.sg{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:22px}
.sc{background:#fff;border-radius:var(--r);padding:18px;box-shadow:var(--sh);display:flex;align-items:flex-start;gap:13px;border:1px solid var(--g100);transition:transform var(--tr),box-shadow var(--tr)}
.sc:hover{transform:translateY(-2px);box-shadow:var(--shm)}
.sico{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.sico .yn-emoji-icon{font-size:25px}
.sico.bl{background:var(--b0);color:var(--b4)}.sico.gr{background:#ecfdf5;color:var(--gr)}.sico.re{background:#fef2f2;color:var(--re)}.sico.or{background:#fffbeb;color:var(--or)}.sico.pu{background:#f5f3ff;color:var(--pu)}.sico.cy{background:#ecfeff;color:var(--ac)}
.sv{font-family:'Syne',sans-serif;font-size:24px;font-weight:800;color:var(--b9);line-height:1.15;word-break:break-word;overflow-wrap:anywhere}
.sc>div:last-child{min-width:0;flex:1}
.sv.rp{font-size:18px;letter-spacing:-.3px}
@media (max-width:600px){.sv{font-size:20px}.sv.rp{font-size:16px}}
.sl{font-size:11.5px;color:var(--g400);margin-top:3px;font-weight:500}
.sd{font-size:11px;margin-top:5px;font-weight:600}
.sd.up{color:var(--gr)}.sd.dn{color:var(--re)}
/* CARDS */
.card{background:#fff;border-radius:var(--r);box-shadow:var(--sh);border:1px solid var(--g100);overflow:hidden}
.ch{padding:14px 18px;border-bottom:1px solid var(--g100);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.ct{font-family:'Syne',sans-serif;font-size:13.5px;font-weight:700;color:var(--b9)}
.cb{padding:18px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}.mb22{margin-bottom:22px}
/* TABLE */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{padding:9px 14px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--g400);text-align:left;background:var(--g50);border-bottom:1px solid var(--g200);white-space:nowrap}
td{padding:11px 14px;font-size:12.5px;color:var(--g600);border-bottom:1px solid var(--g100);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--b0)}
.td-n{font-weight:600;color:var(--b9)}
.td-m{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--g500)}
/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:10.5px;font-weight:600;white-space:nowrap}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0}
.bg{background:#ecfdf5;color:#059669}.bg::before{background:var(--gr)}
.br{background:#fef2f2;color:#dc2626}.br::before{background:var(--re)}
.bo{background:#fffbeb;color:#d97706}.bo::before{background:var(--or)}
.bb{background:var(--b0);color:var(--b5)}.bb::before{background:var(--b3)}
/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--rs);font-size:12.5px;font-weight:600;cursor:pointer;border:none;transition:all var(--tr);font-family:'DM Sans',sans-serif;white-space:nowrap}
.bp{background:linear-gradient(135deg,var(--b4),var(--b5));color:#fff;box-shadow:0 2px 8px rgba(37,99,235,.3)}
.bp:hover{box-shadow:0 4px 16px rgba(37,99,235,.4);transform:translateY(-1px)}
.bs{background:#fff;color:var(--g600);border:1.5px solid var(--g200)}
.bs:hover{border-color:var(--b3);color:var(--b5)}
.bsm{padding:5px 10px;font-size:11.5px}
.bd{background:#fef2f2;color:var(--re);border:1.5px solid #fecaca}
.bd:hover{background:var(--re);color:#fff}
.bsc{background:#ecfdf5;color:#059669;border:1.5px solid #a7f3d0}
.bsc:hover{background:var(--gr);color:#fff}
.bw{background:#ecfdf5;color:#059669;border:1.5px solid #a7f3d0}
.bw:hover{background:#25d366;color:#fff}
/* PROGRESS */
.pb{height:6px;background:var(--g200);border-radius:99px;overflow:hidden}
.pf{height:100%;border-radius:99px;transition:width .7s ease}
.pf.bl{background:linear-gradient(90deg,var(--b4),var(--ac))}
/* FORM */
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.fg{display:flex;flex-direction:column;gap:4px}
.fg label{font-size:11.5px;font-weight:600;color:var(--g600)}
.fc{padding:8px 11px;border:1.5px solid var(--g200);border-radius:var(--rs);font-size:12.5px;font-family:'DM Sans',sans-serif;color:var(--g700);outline:none;transition:border-color var(--tr),box-shadow var(--tr);background:#fff;width:100%}
.fc:focus{border-color:var(--b3);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
textarea.fc{resize:vertical;min-height:70px}
.cloud-user-table td{vertical-align:top}
.cloud-user-name{font-size:12.5px}
.cloud-user-email{font-size:12px;color:var(--g600);word-break:break-word}
.cloud-user-id{margin-bottom:6px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--g400)}
.cloud-user-actions{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.cloud-role-select{height:28px;border:1px solid var(--g200);border-radius:7px;background:var(--input-bg,#fff);color:var(--g700);font-size:11px;padding:0 6px;max-width:92px}
.perm-groups{display:flex;flex-direction:column;gap:13px}
.perm-group{border:1px solid var(--g100);border-radius:10px;padding:10px;background:var(--g50)}
.perm-group-title{font-size:11px;font-weight:800;color:var(--b9);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.perm-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(245px,1fr));gap:8px}
.perm-card{border:1px solid var(--g100);border-radius:8px;padding:10px;background:var(--bg-card,#fff);box-shadow:0 1px 2px rgba(15,23,42,.03)}
.perm-card.allowed{border-color:rgba(16,185,129,.38);background:#f0fdf4}
.perm-card.denied{border-color:rgba(239,68,68,.4);background:#fff1f2}
.perm-card.inherited{border-color:rgba(37,99,235,.3);background:#eff6ff}
.perm-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:7px}
.perm-title{font-size:11.5px;font-weight:700;color:var(--b9);line-height:1.3}
.perm-desc{font-size:10.3px;color:var(--g500);line-height:1.35;margin-top:2px}
.perm-state{font-size:9.5px;font-weight:700;border-radius:999px;padding:2px 6px;white-space:nowrap;background:var(--g100);color:var(--g500)}
.perm-state.allowed{background:#d1fae5;color:#047857}
.perm-state.denied{background:#fee2e2;color:#b91c1c}
.perm-state.inherited{background:var(--b1);color:var(--b5)}
.perm-choice-row{display:flex;gap:7px;align-items:center;margin-top:8px}
.perm-check{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--g600);cursor:pointer}
.perm-choice{border:1px solid var(--g200);background:var(--bg-card,#fff);border-radius:7px;padding:5px 8px;min-width:80px;justify-content:center}
.perm-choice.allow:has(input:checked){border-color:#10b981;background:#ecfdf5;color:#047857;font-weight:700}
.perm-choice.deny:has(input:checked){border-color:#ef4444;background:#fef2f2;color:#b91c1c;font-weight:700}
.perm-check input[type="checkbox"]{appearance:auto;-webkit-appearance:checkbox;width:16px;height:16px;margin:0;accent-color:var(--b4);flex-shrink:0;opacity:1;position:static}
.perm-choice.deny input[type="checkbox"]{accent-color:var(--re)}
.perm-choice.allow input[type="checkbox"]{accent-color:var(--gr)}
.perm-check input[type="checkbox"]:disabled{cursor:not-allowed;opacity:.7}
[data-theme="dark"] .cloud-user-table th{background:#0f172a;color:#94a3b8;border-color:#334155}
[data-theme="dark"] .cloud-user-table td{background:#1e293b;color:#cbd5e1;border-color:#334155}
[data-theme="dark"] .cloud-user-table tr:hover td{background:#172554}
[data-theme="dark"] .cloud-user-name{color:#f8fafc}
[data-theme="dark"] .cloud-user-email{color:#cbd5e1}
[data-theme="dark"] .cloud-user-id{color:#64748b}
[data-theme="dark"] .cloud-role-select{background:#0f172a;border-color:#334155;color:#e2e8f0}
[data-theme="dark"] .cloud-role-select option{background:#1e293b;color:#e2e8f0}
[data-theme="dark"] #cloudPermissionEditor{border-color:#334155!important;background:#1e293b;color:#e2e8f0}
[data-theme="dark"] #cloudPermissionTarget{color:#94a3b8!important}
[data-theme="dark"] .perm-group{background:#0f172a;border-color:#334155}
[data-theme="dark"] .perm-group-title{color:#f8fafc}
[data-theme="dark"] .perm-card{background:#1e293b;border-color:#334155;box-shadow:none}
[data-theme="dark"] .perm-card.allowed{background:#06281d;border-color:#047857}
[data-theme="dark"] .perm-card.denied{background:#2d1515;border-color:#991b1b}
[data-theme="dark"] .perm-card.inherited{background:#172554;border-color:#2563eb}
[data-theme="dark"] .perm-card.unchecked{background:#1e293b;border-color:#334155}
[data-theme="dark"] .perm-title{color:#f8fafc}
[data-theme="dark"] .perm-desc{color:#94a3b8}
[data-theme="dark"] .perm-state{background:#334155;color:#cbd5e1}
[data-theme="dark"] .perm-state.allowed{background:#064e3b;color:#6ee7b7}
[data-theme="dark"] .perm-state.denied{background:#7f1d1d;color:#fecaca}
[data-theme="dark"] .perm-state.inherited{background:#1e3a8a;color:#bfdbfe}
[data-theme="dark"] .perm-choice{background:#0f172a;border-color:#334155;color:#cbd5e1}
[data-theme="dark"] .perm-choice.allow:has(input:checked){background:#064e3b;border-color:#10b981;color:#6ee7b7}
[data-theme="dark"] .perm-choice.deny:has(input:checked){background:#7f1d1d;border-color:#ef4444;color:#fecaca}
[data-theme="dark"] .cloud-role-badge.bb{background:#172554;color:#bfdbfe}
[data-theme="dark"] .cloud-role-badge.bg{background:#064e3b;color:#6ee7b7}
[data-theme="dark"] .cloud-user-table .badge.bg{background:#064e3b;color:#6ee7b7}
[data-theme="dark"] .cloud-user-table .badge.br{background:#7f1d1d;color:#fecaca}
[data-theme="dark"] .cloud-user-table .badge.bb{background:#172554;color:#bfdbfe}
[data-theme="dark"] .cloud-user-table .btn.bs{background:#0f172a;color:#cbd5e1;border-color:#334155}
[data-theme="dark"] .cloud-user-table .btn.bd{background:#2d1515;color:#fca5a5;border-color:#7f1d1d}
[data-theme="dark"] .cloud-user-table .btn.bsc{background:#0d2b1f;color:#6ee7b7;border-color:#065f46}
/* FILTER BAR */
.fb{display:flex;gap:7px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.fp{padding:5px 13px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--g200);background:#fff;color:var(--g500);transition:all var(--tr)}
.fp:hover,.fp.ac{border-color:var(--b3);background:var(--b0);color:var(--b5)}
.sb-input{display:flex;align-items:center;gap:7px;background:#fff;border:1.5px solid var(--g200);border-radius:8px;padding:7px 11px;transition:border-color var(--tr);flex:1;max-width:300px}
.sb-input:focus-within{border-color:var(--b3)}
.sb-input input{border:none;outline:none;font-size:12.5px;font-family:'DM Sans',sans-serif;color:var(--g700);flex:1;background:none}
.sb-input input::placeholder{color:var(--g400)}
/* MODAL */
.mo{position:fixed;inset:0;background:rgba(7,21,37,.65);z-index:500;display:none;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(6px)}
.mo.op{display:flex}
.md{background:#fff;border-radius:16px;width:100%;max-width:580px;box-shadow:0 24px 64px rgba(0,0,0,.22);animation:slideUp .2s ease;max-height:92vh;overflow-y:auto}
@keyframes slideUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.mh{padding:18px 22px 14px;border-bottom:1px solid var(--g100);display:flex;align-items:center;justify-content:space-between}
.mh h3{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;color:var(--b9)}
.mc{background:none;border:none;font-size:19px;cursor:pointer;color:var(--g400);padding:2px 6px;border-radius:6px}
.mc:hover{background:var(--g100)}
.mb{padding:22px}.mf{padding:14px 22px;border-top:1px solid var(--g100);display:flex;gap:7px;justify-content:flex-end;flex-wrap:wrap}
/* PAGE HEADER */
.ph{margin-bottom:20px}
.ph h1{font-family:'Syne',sans-serif;font-size:21px;font-weight:800;color:var(--b9)}
.ph p{font-size:12.5px;color:var(--g400);margin-top:2px}
/* MAP */
.map-wrap{position:relative;overflow:hidden;background:linear-gradient(135deg,#e8f4fd,#dbeafe,#e0f2fe);min-height:420px;border-radius:var(--rs)}
.map-legend{position:absolute;bottom:30px;left:10px;background:rgba(255,255,255,.95);border-radius:8px;padding:10px 13px;box-shadow:var(--sh);display:flex;flex-direction:column;gap:5px;backdrop-filter:blur(4px);z-index:999}
.li-item{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--g600);font-weight:500}
.li-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.map-toolbar{display:flex;gap:6px}
.map-counter{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.95);border-radius:20px;padding:5px 12px;font-size:11.5px;font-weight:700;color:var(--b9);box-shadow:var(--sh);z-index:999}
.leaflet-popup-content-wrapper{border-radius:10px!important;box-shadow:0 4px 20px rgba(0,0,0,.15)!important}
.leaflet-popup-content{margin:12px 14px!important}
[data-theme="dark"] .leaflet-popup-content-wrapper{background:#1e293b!important;color:#e2e8f0!important}
[data-theme="dark"] .leaflet-popup-tip{background:#1e293b!important}

/* DONUT */
.dnut{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.dl{display:flex;flex-direction:column;gap:7px}
.di{display:flex;align-items:center;gap:7px}
.dd{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.dt strong{display:block;font-size:13px;font-weight:700;color:var(--b9)}
.dt span{font-size:11px;color:var(--g400)}
/* BAR CHART */
.bc{display:flex;align-items:flex-end;gap:5px}
.bcol{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}
.bf{width:100%;border-radius:4px 4px 0 0;background:linear-gradient(180deg,var(--b3),var(--b5));min-height:3px}
.bl2{font-size:9.5px;color:var(--g400);font-weight:500}
/* TIMELINE */
.ti{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--g100)}
.ti:last-child{border-bottom:none}
.td2{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:5px}
.tc2 .tt{font-size:12.5px;font-weight:600;color:var(--b9)}
.tc2 .ts{font-size:11px;color:var(--g400);margin-top:2px}
/* INVOICE */
.inv-wrap{max-width:680px;margin:0 auto}
.inv-header{background:linear-gradient(135deg,var(--b9),var(--b7));color:#fff;padding:28px 32px;border-radius:var(--r) var(--r) 0 0;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px}
.inv-body{background:#fff;padding:28px 32px;border:1px solid var(--g200);border-top:none}
.inv-footer{background:#fff;padding:16px 32px 28px;border:1px solid var(--g200);border-top:none;border-radius:0 0 var(--r) var(--r)}
/* ISOLIR WARNING */
.iw{background:linear-gradient(90deg,#fef2f2,#fff8f0);border:1px solid #fecaca;border-radius:var(--r);padding:14px 18px;margin-bottom:18px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.iw h3{font-size:13px;font-weight:700;color:#dc2626}
.iw p{font-size:11.5px;color:var(--g500);margin-top:2px}
/* PACKAGES */
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:13px}
.pkc{border:2px solid var(--g200);border-radius:var(--r);padding:18px;transition:all var(--tr);cursor:pointer;background:#fff}
.pkc:hover{border-color:var(--b3);box-shadow:var(--shm)}
.pkc.pop{border-color:var(--b4);background:var(--b0)}
.pk-spd{font-family:'Syne',sans-serif;font-size:26px;font-weight:800;color:var(--b5);line-height:1}
.pk-spd span{font-size:12px;color:var(--g400);font-weight:400}
.pk-nm{font-size:12.5px;font-weight:700;color:var(--b9);margin:5px 0 3px}
.pk-pr{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;color:var(--b9)}
.pk-pr span{font-size:11px;color:var(--g400);font-weight:400}
.pk-us{font-size:11px;color:var(--g400);margin-top:5px}
.pk-pop{display:inline-block;background:var(--b4);color:#fff;font-size:8.5px;font-weight:700;padding:2px 7px;border-radius:20px;letter-spacing:.5px;text-transform:uppercase;margin-bottom:5px}
/* BILLING ROW */
.bil-r{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--g100)}
.bil-r:last-child{border-bottom:none}
.bil-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;font-family:'Syne',sans-serif}
.bil-inf{flex:1;min-width:0}
.bil-nm{font-size:12.5px;font-weight:600;color:var(--b9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bil-pk{font-size:11px;color:var(--g400)}
.bil-am{font-size:12.5px;font-weight:700;color:var(--b9);text-align:right;white-space:nowrap}
/* PAGINATION */
.pag{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;border-top:1px solid var(--g100);flex-wrap:wrap;gap:10px}
.pag-info{font-size:12px;color:var(--g400)}
.pag-btns{display:flex;gap:5px}
.pag-btn{min-width:30px;height:30px;border-radius:6px;background:#fff;border:1.5px solid var(--g200);cursor:pointer;font-size:12px;font-weight:600;color:var(--g600);transition:all var(--tr);font-family:'DM Sans',sans-serif;padding:0 8px}
.pag-btn:hover{border-color:var(--b3);color:var(--b5)}
.pag-btn.ac{background:var(--b4);border-color:var(--b4);color:#fff}
.pag-btn:disabled{opacity:.4;cursor:not-allowed}
/* MISC */
.sb-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:999}
#offline-badge{position:fixed;top:calc(var(--th)+6px);left:50%;transform:translateX(-50%);background:var(--re);color:#fff;font-size:11.5px;font-weight:700;padding:5px 16px;border-radius:20px;z-index:8000;display:none}
#offline-badge.show{display:block}
#toast{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast-item{background:#fff;border-radius:10px;padding:12px 16px;box-shadow:0 4px 20px rgba(0,0,0,.15);display:flex;align-items:center;gap:10px;min-width:240px;border-left:4px solid var(--gr);animation:slideUp .2s ease;font-size:12.5px;font-weight:500;color:var(--b9);pointer-events:auto}
.toast-item.err{border-left-color:var(--re)}.toast-item.wa{border-left-color:var(--or)}
/* RIWAYAT */
.rw-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--g100)}
.rw-item:last-child{border-bottom:none}
.rw-ico{width:32px;height:32px;border-radius:8px;background:#ecfdf5;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.pulse{animation:pulse 2s infinite}
/* ── Page Loading Indicator ── */
.pg-loader{display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px;padding:60px 20px;color:var(--g400)}
.pg-loader-spin{width:36px;height:36px;border:3px solid var(--g200);border-top-color:var(--b4);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* ── Laporan Bulanan ── */
.lapbul-section{background:var(--g50);border-radius:10px;padding:14px;margin-bottom:12px}

#globalSearchDrop{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.14);border:1px solid var(--g200);z-index:9000;max-height:400px;overflow-y:auto;display:none}
[data-theme="dark"] #globalSearchDrop{background:#1e293b;border-color:#334155}
.gs-item{padding:9px 14px;cursor:pointer;transition:.12s;border-bottom:1px solid var(--g100)}
.gs-item:hover{background:var(--b0)}
.gs-item:last-child{border-bottom:none}
[data-theme="dark"] .gs-item:hover{background:#0f172a}
/* ── Notif Center ── */
.notif-center{position:fixed;top:calc(var(--th)+6px);right:16px;width:340px;background:#fff;border-radius:14px;box-shadow:0 8px 40px rgba(0,0,0,.16);border:1px solid var(--g200);z-index:5000;display:none;max-height:480px;overflow:hidden;flex-direction:column}
[data-theme="dark"] .notif-center{background:#1e293b;border-color:#334155}
.notif-center.open{display:flex}
.notif-item{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-bottom:1px solid var(--g100);cursor:pointer;transition:.12s}
.notif-item:hover{background:var(--g50)}
.notif-item.unread{background:var(--b0)}
[data-theme="dark"] .notif-item.unread{background:#0f172a}
/* ── Network Health Score ── */
.health-ring{width:80px;height:80px;transform:rotate(-90deg)}
.health-ring circle{fill:none;stroke-width:8;stroke-linecap:round}
/* ── Trouble Ticket ── */
.ticket-item{background:#fff;border:1px solid var(--g200);border-radius:10px;padding:13px;margin-bottom:10px;transition:.15s}
.ticket-item:hover{box-shadow:var(--sh)}
[data-theme="dark"] .ticket-item{background:#1e293b;border-color:#334155}
.ticket-status-baru{background:#fee2e2;color:#7f1d1d;padding:2px 9px;border-radius:12px;font-size:10.5px;font-weight:700}
.ticket-status-proses{background:#fef3c7;color:#92400e;padding:2px 9px;border-radius:12px;font-size:10.5px;font-weight:700}
.ticket-status-selesai{background:#d1fae5;color:#065f46;padding:2px 9px;border-radius:12px;font-size:10.5px;font-weight:700}
/* ── IP Pool ── */
.ip-cell{display:inline-flex;align-items:center;justify-content:center;width:36px;height:28px;border-radius:6px;font-size:10px;font-weight:700;cursor:pointer;transition:.12s;font-family:'JetBrains Mono',monospace}
.ip-used{background:#fee2e2;color:#7f1d1d}
.ip-free{background:#d1fae5;color:#065f46}
.ip-free:hover{background:#6ee7b7;transform:scale(1.1)}
/* ── Audit Trail ── */
.audit-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--g100);font-size:12px}
.audit-item:last-child{border-bottom:none}
/* ── Coverage radius ── */
.coverage-toggle{display:flex;align-items:center;gap:6px;font-size:12px}

.marker-kritis-pulse{animation:kritPulse 1.5s infinite}
@keyframes kritPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}
/* ── Riwayat gangguan ── */
.gangguan-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--g100)}
.gangguan-item:last-child{border-bottom:none}
.gangguan-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}
/* ── Kalkulator template ── */
.tpl-chip{display:inline-flex;align-items:center;gap:5px;background:var(--b0);border:1px solid var(--b2);border-radius:20px;padding:3px 10px;font-size:11.5px;cursor:pointer;transition:.15s}
.tpl-chip:hover{background:var(--b1)}
[data-theme="dark"] .tpl-chip{background:#1e3a8a;border-color:#2563eb}
/* ── Alert threshold setting ── */
.threshold-input{width:60px;text-align:center;font-family:'JetBrains Mono',monospace}
/* ── Dashboard FTTH ── */
.mt22{margin-top:22px}

.rx-badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700;font-family:'JetBrains Mono',monospace}
.rx-normal{background:#d1fae5;color:#065f46}
.rx-warning{background:#fef3c7;color:#92400e}
.rx-kritis{background:#fee2e2;color:#7f1d1d}
.rx-offline{background:#f1f5f9;color:#64748b}
[data-theme="dark"] .rx-normal{background:#0d2b1f;color:#6ee7b7}
[data-theme="dark"] .rx-warning{background:#2d2010;color:#fcd34d}
[data-theme="dark"] .rx-kritis{background:#2d1515;color:#fca5a5}
[data-theme="dark"] .rx-offline{background:#1e293b;color:#64748b}
.sync-monitor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px}
.sync-monitor-kv{border:1px solid var(--g100);border-radius:8px;padding:11px 12px;background:var(--g50);min-width:0}
.sync-monitor-label{font-size:10.5px;color:var(--g400);font-weight:700;text-transform:uppercase;margin-bottom:5px}
.sync-monitor-value{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--g700);word-break:break-word}
.sync-monitor-actions{display:flex;gap:9px;flex-wrap:wrap}
.sync-monitor-note{font-size:11.5px;color:var(--g500);line-height:1.6;margin-top:12px}
.sync-monitor-empty{font-size:12px;color:var(--g400);padding:12px}
.sync-monitor-failed{color:var(--re)}
.sync-monitor-result{border:1px solid var(--g100);border-radius:8px;padding:12px;margin-bottom:10px;background:#fff}
.sync-monitor-result.ok{border-left:4px solid var(--gr)}
.sync-monitor-result.failed{border-left:4px solid var(--re)}
.sync-monitor-result-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.sync-monitor-result-title{font-size:13px;font-weight:700;color:var(--g700)}
.sync-monitor-result-time{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--g400);margin-top:3px}
.sync-monitor-error{margin-top:9px;color:var(--re);font-size:12px}
.sync-monitor-detail{margin-top:10px}
.sync-monitor-detail summary{cursor:pointer;font-size:12px;font-weight:700;color:var(--b5)}
.sync-monitor-detail pre{margin:8px 0 0;background:var(--g50);border:1px solid var(--g100);border-radius:8px;padding:10px;overflow:auto;font-size:11px;line-height:1.5;max-height:320px;color:var(--g700)}
.sync-runtime-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-top:10px}
.sync-runtime-grid div{background:var(--g50);border:1px solid var(--g100);border-radius:8px;padding:8px}
.sync-runtime-grid b{display:block;font-size:10px;color:var(--g400);text-transform:uppercase;margin-bottom:4px}
.sync-runtime-grid span{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--g700);word-break:break-word}
[data-theme="dark"] .sync-monitor-kv,[data-theme="dark"] .sync-monitor-detail pre{background:#0f172a;border-color:#334155}
[data-theme="dark"] .sync-monitor-result{background:#1e293b;border-color:#334155}
[data-theme="dark"] .sync-runtime-grid div{background:#0f172a;border-color:#334155}
.financial-readiness-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}
.financial-readiness-item{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--g50);border:1px solid var(--g100);border-radius:8px;padding:10px;font-size:12px;color:var(--g700)}
.financial-readiness-columns{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.financial-readiness-list{margin:8px 0 0;padding-left:18px;color:var(--g700);font-size:12px;line-height:1.7}
.financial-readiness-list b{text-transform:uppercase;font-size:10px;color:var(--or)}
.financial-summary-text{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--g700);text-align:right;word-break:break-word}
[data-theme="dark"] .financial-readiness-item{background:#0f172a;border-color:#334155}
.sync-conflict-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.sync-conflict-card{border:1px solid var(--g100);border-left:4px solid var(--or);border-radius:8px;padding:12px;background:#fff}
.sync-conflict-card.resolved{border-left-color:var(--gr);opacity:.82}
.sync-conflict-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.sync-conflict-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.sync-conflict-grid b{display:block;font-size:10.5px;color:var(--g400);text-transform:uppercase;margin-bottom:5px}
.sync-conflict-grid span,.sync-conflict-grid pre{display:block;margin:0;background:var(--g50);border:1px solid var(--g100);border-radius:8px;padding:9px;font-size:11px;color:var(--g700);white-space:pre-wrap;word-break:break-word;max-height:150px;overflow:auto}
.sync-conflict-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
[data-theme="dark"] .sync-conflict-card{background:#1e293b;border-color:#334155}
[data-theme="dark"] .sync-conflict-grid span,[data-theme="dark"] .sync-conflict-grid pre{background:#0f172a;border-color:#334155}
.olt-port-bar{height:8px;background:var(--g200);border-radius:4px;overflow:hidden;margin-top:4px}
.olt-port-bar-fill{height:100%;border-radius:4px;transition:width .4s}
.onu-sn{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--b5);background:var(--b0);padding:1px 7px;border-radius:4px}
[data-theme="dark"] .onu-sn{background:#1e3a8a;color:var(--b3)}
.calc-result-box{background:linear-gradient(135deg,var(--b0),#f0fdf4);border:1.5px solid var(--b2);border-radius:12px;padding:20px;margin-bottom:14px}
.calc-result-box.warn{background:linear-gradient(135deg,#fefce8,#fef3c7);border-color:#fcd34d}
.calc-result-box.fail{background:linear-gradient(135deg,#fff1f2,#fee2e2);border-color:#fca5a5}
[data-theme="dark"] .calc-result-box{background:linear-gradient(135deg,#0d2b3e,#0d2b1f);border-color:var(--b3)}
[data-theme="dark"] .calc-result-box.warn{background:linear-gradient(135deg,#2d2010,#2d2010);border-color:#f59e0b}
[data-theme="dark"] .calc-result-box.fail{background:linear-gradient(135deg,#2d1515,#2d1515);border-color:#ef4444}
.loss-breakdown{font-size:12px;border-collapse:collapse;width:100%}
.loss-breakdown td{padding:4px 8px;border-bottom:1px solid var(--g100)}
.loss-breakdown td:last-child{text-align:right;font-family:'JetBrains Mono',monospace;font-weight:600}
.olt-status-aktif{background:#d1fae5;color:#065f46;padding:2px 8px;border-radius:12px;font-size:10.5px;font-weight:700}
.olt-status-maintenance{background:#fef3c7;color:#92400e;padding:2px 8px;border-radius:12px;font-size:10.5px;font-weight:700}
.olt-status-offline{background:#fee2e2;color:#7f1d1d;padding:2px 8px;border-radius:12px;font-size:10.5px;font-weight:700}
@media print{.sb,.tb,.no-print{display:none!important}.main{margin-left:0;padding-top:0}.pg{display:block!important;padding:0}body{background:#fff}#loginScreen,#idbLoad{display:none!important}}
@media(max-width:1100px){.g3{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.g2,.g3,.fr,.financial-readiness-columns{grid-template-columns:1fr}}
@media(max-width:768px){.sb{transform:translateX(-100%)}.sb.op{transform:translateX(0)}.sb-ov{display:block;opacity:0;pointer-events:none;transition:opacity .2s}.sb-ov.op{opacity:1;pointer-events:auto}.main{margin-left:0}.tb{left:0}.mt{display:flex}.tb-search{display:none}.sg{grid-template-columns:repeat(2,1fr)}.pg{padding:14px}}
@media(max-width:480px){.sg{grid-template-columns:1fr}.pkg-grid{grid-template-columns:1fr}}
