/* BUTTONS */
.btn-primary{background:var(--accent);color:#fff;border:none;padding:0.4rem 0.875rem;border-radius:7px;font-size:0.75rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:0.375rem;transition:background 0.15s}
.btn-primary:hover{background:#1D4ED8}

/* KPI Row */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);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-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(--pln)}
.kpi.border-purple{border-top:3px solid var(--purple)}
.kpi.border-green{border-top:3px solid var(--green)}
.kpi.border-teal{border-top:3px solid var(--cyan)}
.bg-b{background:rgba(59,130,246,0.1);color:#1D4ED8}
.bg-p{background:rgba(139,92,246,0.1);color:#6D28D9}
.bg-g{background:rgba(16,185,129,0.1);color:#047857}
.bg-teal{background:rgba(6,182,212,0.1);color:#0369A1}
.bg-r{background:rgba(239,68,68,0.1);color:#991B1B}
.bg-amber{background:rgba(245,158,11,0.1);color:#92400E}
.bg-orange{background:rgba(249,115,22,0.1);color:#C2410C}

/* TAB BAR */
.tab-bar{display:flex;gap:0;background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.tab-btn{padding:0.625rem 1.125rem;font-size:0.8125rem;font-weight:600;color:var(--muted);cursor:pointer;border:none;background:none;transition:all 0.15s;display:flex;align-items:center;gap:0.375rem;border-bottom:2px solid transparent}
.tab-btn:hover{color:var(--text);background:rgba(0,0,0,0.03)}
.tab-btn.active{color:var(--accent);border-bottom:2px solid var(--accent);background:rgba(37,99,235,0.05)}

/* Tab content */
.tab-content{display:none}
.tab-content.active{display:contents}

/* Cards */
.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;flex-shrink:0}
.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}
.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(37,99,235,0.1);border-color:var(--accent);color:var(--accent)}
.btn-xs.danger{color:var(--red)}
.btn-xs.danger:hover{border-color:var(--red);color:var(--red)}

/* Filter bar */
.filter-bar{display:flex;align-items:center;gap:0.5rem;padding:0.75rem 1rem;border-bottom:1px solid var(--border);background:var(--card2);flex-wrap:wrap}
.filter-bar input,.filter-bar select{height:30px;border:1px solid var(--border);border-radius:6px;padding:0 0.625rem;font-size:0.75rem;color:var(--text);background:var(--card);font-family:'Inter',sans-serif;outline:none}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--accent)}
.filter-bar input{width:180px}
.filter-bar select{width:140px}
.filter-bar label{font-size:0.75rem;color:var(--muted);white-space:nowrap}

/* Status Table */
.status-table{width:100%;border-collapse:collapse}
.status-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(37,99,235,0.03);font-weight:700;white-space:nowrap}
.status-table td{padding:7px 14px;font-size:0.8125rem;border-top:1px solid rgba(0,0,0,0.04)}
.status-table tr:hover td{background:rgba(37,99,235,0.03)}
.mono{font-family:'JetBrains Mono',monospace;font-size:0.8125rem}

/* Badges */
.sbadge{padding:0.15rem 0.5rem;border-radius:100px;font-size:0.6875rem;font-weight:600;white-space:nowrap}
.sbadge-green{background:rgba(16,185,129,0.12);color:#047857}
.sbadge-yellow{background:rgba(245,158,11,0.12);color:#92400E}
.sbadge-red{background:rgba(239,68,68,0.12);color:#991B1B}
.sbadge-blue{background:rgba(59,130,246,0.12);color:#1E40AF}
.sbadge-gray{background:rgba(100,116,139,0.12);color:#475569}
.sbadge-purple{background:rgba(139,92,246,0.12);color:#6D28D9}
.sbadge-orange{background:rgba(249,115,22,0.12);color:#C2410C}
.sbadge-teal{background:rgba(6,182,212,0.12);color:#0E7490}

/* Role badge */
.role-badge{padding:0.15rem 0.5rem;border-radius:5px;font-size:0.6rem;font-weight:700;white-space:nowrap;letter-spacing:0.04em;text-transform:uppercase}
.rb-super{background:#FEE2E2;color:#B91C1C}
.rb-energy{background:#F3E8FF;color:#7C3AED}
.rb-daop{background:#DBEAFE;color:#1D4ED8}
.rb-operator{background:#CCFBF1;color:#0F766E}
.rb-tech{background:#FFEDD5;color:#C2410C}
.rb-viewer{background:#F1F5F9;color:#475569;border:1px solid var(--border)}

/* MFA badge */
.mfa-on{display:inline-flex;align-items:center;gap:3px;font-size:0.6875rem;font-weight:600;color:#047857;background:rgba(16,185,129,0.1);padding:0.1rem 0.4rem;border-radius:4px}
.mfa-off-warn{display:inline-flex;align-items:center;gap:3px;font-size:0.6875rem;font-weight:600;color:#B91C1C;background:rgba(239,68,68,0.1);padding:0.1rem 0.4rem;border-radius:4px}
.mfa-off{display:inline-flex;align-items:center;gap:3px;font-size:0.6875rem;color:var(--muted);padding:0.1rem 0.4rem}

/* Status dot */
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}
.s-on{background:var(--green)}
.s-off{background:var(--red)}
.s-warn{background:var(--solar)}

/* 2-col grid */
.row2{display:grid;grid-template-columns:2fr 1fr;gap:1rem}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}

/* Form elements */
.form-group{margin-bottom:0.75rem}
.form-label{display:block;font-size:0.75rem;font-weight:600;color:var(--text);margin-bottom:0.25rem}
.form-hint{font-size:0.6875rem;color:var(--muted);margin-top:0.2rem}
.form-input{width:100%;height:32px;border:1px solid var(--border);border-radius:6px;padding:0 0.625rem;font-size:0.8125rem;color:var(--text);background:var(--card);font-family:'Inter',sans-serif;outline:none;transition:border-color 0.15s}
.form-input:focus{border-color:var(--accent)}
.form-select{width:100%;height:32px;border:1px solid var(--border);border-radius:6px;padding:0 0.625rem;font-size:0.8125rem;color:var(--text);background:var(--card);font-family:'Inter',sans-serif;outline:none;cursor:pointer}
.form-select:focus{border-color:var(--accent)}
.toggle-wrap{display:flex;align-items:center;gap:0.5rem}
.toggle{width:36px;height:20px;background:var(--green);border-radius:10px;position:relative;cursor:pointer;flex-shrink:0}
.toggle::after{content:'';position:absolute;top:2px;right:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:right 0.2s}
.toggle.off{background:#CBD5E1}
.toggle.off::after{right:18px}
.form-checkbox{display:flex;align-items:center;gap:0.5rem;font-size:0.8125rem;color:var(--text);cursor:pointer}
.form-checkbox input{width:14px;height:14px;cursor:pointer;accent-color:var(--accent)}
.btn-group{display:flex;gap:0.5rem;margin-top:1rem}
.btn-cancel{flex:1;height:32px;border:1px solid var(--border);background:none;border-radius:7px;font-size:0.8125rem;font-weight:600;color:var(--muted);cursor:pointer}
.btn-cancel:hover{border-color:var(--red);color:var(--red)}
.btn-submit{flex:2;height:32px;background:var(--accent);color:#fff;border:none;border-radius:7px;font-size:0.8125rem;font-weight:600;cursor:pointer}
.btn-submit:hover{background:#1D4ED8}

/* RBAC Matrix */
.rbac-table{width:100%;border-collapse:collapse}
.rbac-table th{font-size:10px;text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);padding:0.625rem 0.75rem;text-align:center;border:1px solid var(--border);font-weight:700;white-space:nowrap}
.rbac-table th:first-child{text-align:left}
.rbac-table td{padding:6px 10px;font-size:0.8125rem;border:1px solid rgba(0,0,0,0.05);text-align:center;white-space:nowrap}
.rbac-table td:first-child{text-align:left;font-size:0.8125rem;color:var(--text);font-weight:500}
.rbac-table tr.group-hdr td{background:rgba(37,99,235,0.04);font-size:10px;font-weight:700;text-transform:uppercase;color:var(--muted);letter-spacing:0.06em;padding:4px 10px;text-align:left}
.rbac-table tbody tr:hover td{background:rgba(37,99,235,0.02)}
.perm-yes{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:rgba(16,185,129,0.12);border-radius:50%;color:#047857;font-size:11px;font-weight:700}
.perm-no{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:rgba(239,68,68,0.1);border-radius:50%;color:#991B1B;font-size:11px;font-weight:700}
.perm-scope{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:rgba(245,158,11,0.12);border-radius:50%;color:#92400E;font-size:9px;font-weight:700}

/* MFA status cards */
.mfa-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1rem;display:flex;flex-direction:column;gap:0.5rem}
.mfa-role-hdr{display:flex;align-items:center;justify-content:space-between}
.mfa-progress{height:6px;background:rgba(0,0,0,0.06);border-radius:3px;overflow:hidden;margin:4px 0}
.mfa-progress-fill{height:100%;border-radius:3px}
.mfa-pct{font-size:1.25rem;font-weight:800;font-family:'JetBrains Mono',monospace}

/* Audit log */
.audit-type{display:inline-flex;align-items:center;gap:4px;padding:0.15rem 0.5rem;border-radius:5px;font-size:0.6875rem;font-weight:600}
.at-login{background:rgba(16,185,129,0.1);color:#047857}
.at-fail{background:rgba(239,68,68,0.1);color:#991B1B}
.at-export{background:rgba(59,130,246,0.1);color:#1D4ED8}
.at-alert{background:rgba(245,158,11,0.1);color:#92400E}
.at-wo{background:rgba(6,182,212,0.1);color:#0E7490}
.at-user{background:rgba(139,92,246,0.1);color:#6D28D9}
.at-report{background:rgba(99,102,241,0.1);color:#4338CA}
.at-mfa{background:rgba(16,185,129,0.1);color:#047857}
.at-config{background:rgba(249,115,22,0.1);color:#C2410C}
.at-pwreset{background:rgba(100,116,139,0.1);color:#475569}

/* Pagination */
.pagination{display:flex;align-items:center;gap:0.25rem;padding:0.75rem 1rem;border-top:1px solid var(--border)}
.pg-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;background:none;font-size:0.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.pg-btn:hover{border-color:var(--accent);color:var(--accent)}
.pg-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.pg-info{font-size:0.75rem;color:var(--muted);margin-left:auto}

/* Inline warning notice */
.notice{display:flex;align-items:flex-start;gap:0.5rem;background:rgba(245,158,11,0.08);border:1px solid rgba(245,158,11,0.25);border-radius:8px;padding:0.625rem 0.75rem;font-size:0.75rem;color:#92400E;margin-top:0.5rem}
.notice-info{background:rgba(59,130,246,0.06);border-color:rgba(59,130,246,0.2);color:#1D4ED8}
.notice i{margin-top:1px;flex-shrink:0}

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