*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#F1F5F9;--sidebar:#FFFFFF;--card:#FFFFFF;--card2:#F8FAFC;--border:#E2E8F0;
  --text:#1E293B;--muted:#64748B;--accent:#1D4ED8;--kai-blue:#003082;
  --green:#16A34A;--red:#DC2626;--orange:#D97706;--amber:#D97706;
  --yellow:#F59E0B;--purple:#7C3AED;--blue:#2563EB;--cyan:#06B6D4;
  --status-siap:#16A34A;--status-perawatan:#D97706;--status-kritis:#DC2626;
  --status-overhaul:#7C3AED;--status-standby:#2563EB;
}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);display:flex;flex-direction:column;height:100vh;overflow:hidden;font-size:13px}

/* Header */
.hdr{height:52px;background:var(--sidebar);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.25rem;gap:0.75rem;flex-shrink:0;z-index:100}
.logo{display:flex;align-items:center;gap:0.5rem;text-decoration:none;color:inherit}
.logo-icon{width:32px;height:32px;background:var(--kai-blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem}
.logo-name{font-size:0.9375rem;font-weight:800;color:var(--text)}
.logo-name span{color:var(--kai-blue)}
.breadcrumb{font-size:0.75rem;color:var(--muted);display:flex;align-items:center;gap:0.375rem}
.breadcrumb a{color:var(--muted);text-decoration:none}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep2{color:var(--border)}
.breadcrumb .cur{color:var(--text);font-weight:600}
.sep{width:1px;height:24px;background:var(--border)}
.hdr-center{display:flex;align-items:center;gap:0.75rem;margin-left:auto;margin-right:auto}
.live-badge{display:flex;align-items:center;gap:0.375rem;background:rgba(22,163,74,0.1);border:1px solid rgba(22,163,74,0.3);padding:0.25rem 0.625rem;border-radius:100px;font-size:0.6875rem;color:#15803D}
.pulse{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
.hdr-date{font-size:0.75rem;color:var(--muted)}
.hdr-right{display:flex;align-items:center;gap:0.75rem}
.hdr-time{font-size:0.875rem;font-weight:600;font-family:'JetBrains Mono',monospace;color:var(--text)}
.icon-btn{background:none;border:1px solid var(--border);color:var(--muted);width:32px;height:32px;border-radius:7px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;position:relative;font-size:0.8125rem}
.icon-btn:hover{border-color:var(--accent);color:var(--accent)}
.nb{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;width:14px;height:14px;border-radius:50%;font-size:0.5625rem;display:flex;align-items:center;justify-content:center;font-weight:700}
.avatar{width:30px;height:30px;background:linear-gradient(135deg,var(--kai-blue),var(--accent));border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:0.6875rem;font-weight:700;color:#fff;cursor:pointer}

/* Common components */
.card{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:box-shadow 0.15s}
.card:hover{box-shadow:0 2px 12px rgba(0,0,0,0.06)}
.card-hdr{padding:0.75rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:0.8125rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:0.5rem}
.card-body{padding:1rem}
.card-actions{display:flex;gap:0.375rem;align-items:center}

/* Buttons */
.btn{padding:0.375rem 0.875rem;border-radius:7px;font-size:0.8125rem;font-weight:600;cursor:pointer;transition:all 0.15s;border:none;display:inline-flex;align-items:center;gap:0.375rem}
.btn-primary{background:var(--kai-blue);color:#fff}
.btn-primary:hover{background:#002060}
.btn-secondary{background:none;border:1px solid var(--border);color:var(--muted)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:#1E40AF}
.btn-xs{padding:0.2rem 0.5rem;border-radius:5px;font-size:0.6875rem;border:1px solid var(--border);background:none;color:var(--muted);cursor:pointer;transition:all 0.15s}
.btn-xs:hover{border-color:var(--accent);color:var(--accent)}
.btn-xs.act{background:rgba(0,48,130,0.08);border-color:var(--kai-blue);color:var(--kai-blue)}

/* Badges */
.sbadge{padding:0.15rem 0.5rem;border-radius:100px;font-size:0.6875rem;font-weight:600;white-space:nowrap}
.sbadge-green{background:rgba(22,163,74,0.12);color:#15803D}
.sbadge-yellow{background:rgba(217,119,6,0.12);color:#92400E}
.sbadge-red{background:rgba(220,38,38,0.12);color:#991B1B}
.sbadge-blue{background:rgba(0,48,130,0.1);color:#003082}
.sbadge-orange{background:rgba(249,115,22,0.12);color:#9A3412}
.sbadge-purple{background:rgba(139,92,246,0.12);color:#5B21B6}
.sbadge-gray{background:rgba(100,116,139,0.12);color:#475569}
.sbadge-teal{background:rgba(20,184,166,0.12);color:#0F766E}

/* Status dots */
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px;flex-shrink:0}
.s-on{background:var(--status-siap)}
.s-warn{background:var(--status-perawatan)}
.s-off{background:var(--status-kritis)}
.s-idle{background:var(--muted)}
.s-blue{background:var(--status-standby)}
.s-purple{background:var(--status-overhaul)}

/* Table */
.data-table{width:100%;border-collapse:collapse}
.data-table th{font-size:10px;text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);padding:0.5rem 0.875rem;text-align:left;background:rgba(0,48,130,0.03);font-weight:700;white-space:nowrap}
.data-table td{padding:7px 14px;font-size:0.8125rem;border-top:1px solid rgba(0,0,0,0.04)}
.data-table tr:hover td{background:rgba(0,48,130,0.03);cursor:pointer}
.mono{font-family:'JetBrains Mono',monospace;font-size:0.8125rem}

/* KPI cards */
.kpi-row{display:grid;gap:0.75rem}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:0.875rem 1rem;transition:box-shadow 0.15s}
.kpi:hover{box-shadow:0 4px 16px rgba(0,0,0,0.08)}
.kpi-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0.5rem}
.kpi-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:0.875rem}
.kpi-delta{font-size:0.6875rem;font-weight:600}
.kpi-val{font-size:1.5rem;font-weight:800;color:var(--text);line-height:1;font-family:'JetBrains Mono',monospace}
.kpi-lbl{font-size:0.6875rem;color:var(--muted);margin-top:0.25rem;text-transform:uppercase;letter-spacing:0.04em}
.kpi-sub{font-size:0.625rem;color:var(--muted);margin-top:0.2rem}
.kpi.border-blue{border-top:3px solid var(--kai-blue)}
.kpi.border-green{border-top:3px solid var(--status-siap)}
.kpi.border-red{border-top:3px solid var(--status-kritis)}
.kpi.border-orange{border-top:3px solid var(--status-perawatan)}
.kpi.border-amber{border-top:3px solid var(--status-perawatan)}
.kpi.border-purple{border-top:3px solid var(--status-overhaul)}

/* Background helpers */
.bg-b{background:rgba(0,48,130,0.1);color:#003082}
.bg-g{background:rgba(22,163,74,0.1);color:#15803D}
.bg-r{background:rgba(220,38,38,0.1);color:#991B1B}
.bg-o{background:rgba(217,119,6,0.1);color:#92400E}
.bg-p{background:rgba(124,58,237,0.1);color:#5B21B6}
.bg-bl{background:rgba(37,99,235,0.1);color:#1D4ED8}
.bg-c{background:rgba(6,182,212,0.1);color:#0369A1}
.bg-y{background:rgba(245,158,11,0.1);color:#92400E}

/* Deltas */
.delta-up{color:var(--green)}
.delta-down{color:var(--red)}
.delta-flat{color:var(--muted)}

/* Alert feed */
.alert-item{padding:0.625rem 1rem;border-bottom:1px solid rgba(0,0,0,0.04);display:flex;align-items:flex-start;gap:0.625rem;font-size:0.8125rem;transition:background 0.15s}
.alert-item:last-child{border-bottom:none}
.alert-item:hover{background:rgba(0,0,0,0.02)}
.alert-sev{width:3px;min-height:36px;border-radius:2px;flex-shrink:0;margin-top:2px}
.sev-crit{background:var(--red)}
.sev-high{background:var(--orange)}
.sev-med{background:var(--yellow)}
.sev-low{background:var(--accent)}
.alert-name{font-weight:600;color:var(--text);margin-bottom:2px}
.alert-dev{font-size:0.6875rem;color:var(--muted)}
.alert-time{margin-left:auto;font-size:0.6875rem;color:var(--muted);white-space:nowrap;padding-top:2px}

/* Progress bar */
.prog-row{display:flex;align-items:center;gap:0.5rem;padding:0.5rem 0}
.prog-row+.prog-row{border-top:1px solid rgba(0,0,0,0.04)}
.prog-info{flex:1;min-width:0}
.prog-name{font-size:0.75rem;font-weight:600;color:var(--text)}
.prog-sub{font-size:0.625rem;color:var(--muted)}
.prog-bar-wrap{width:80px;flex-shrink:0}
.prog-bar-bg{height:6px;background:rgba(0,0,0,0.06);border-radius:3px;overflow:hidden}
.prog-bar-fill{height:100%;border-radius:3px}
.prog-val{font-size:0.75rem;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--text);white-space:nowrap;text-align:right;min-width:60px}

/* Filter bar */
.filter-bar{display:flex;gap:0.5rem;align-items:center;flex-wrap:wrap}
.filter-select{padding:0.3rem 0.625rem;border:1px solid var(--border);border-radius:6px;font-size:0.75rem;color:var(--text);background:var(--card);cursor:pointer;font-family:inherit}
.filter-select:focus{outline:none;border-color:var(--kai-blue)}
.search-input{padding:0.3rem 0.75rem;border:1px solid var(--border);border-radius:6px;font-size:0.75rem;color:var(--text);background:var(--card);min-width:200px;font-family:inherit}
.search-input:focus{outline:none;border-color:var(--kai-blue)}
.search-wrap{position:relative;display:inline-flex;align-items:center}
.search-wrap i{position:absolute;left:0.625rem;color:var(--muted);font-size:0.75rem;pointer-events:none}
.search-input-icon{padding-left:2rem}

/* Scrollbar */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#CBD5E1;border-radius:2px}
