/* === Admin · Estilos compartidos para todas las sub-páginas === */
:root {
  --ink:#0F172A; --muted:#475569; --line:#e5e7eb; --paper:#fff; --bg:#f8fafc;
  --brand:#01466D; --brand-soft:#e0f2fe; --alarm:#dc2626; --warn:#d97706; --ok:#059669; --info:#0369a1;
  --mono:'JetBrains Mono','Menlo',ui-monospace,monospace;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,'SF Pro',sans-serif;background:var(--bg);color:var(--ink)}
.wrap{max-width:1280px;margin:0 auto;padding:32px 28px}
h1{font-size:32px;margin:0 0 6px;font-weight:700;letter-spacing:-0.5px}
h2{font-size:18px;margin:0;font-weight:600}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.lead{color:var(--muted);font-size:14px;max-width:640px;margin:0 0 28px}

/* === Sub-nav (breadcrumb + tabs) === */
.subnav{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);margin-bottom:24px}
.subnav a{color:var(--brand);text-decoration:none}
.subnav .sep{color:var(--muted)}
.subnav .current{color:var(--ink);font-weight:600}

/* Tab pills */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:24px;overflow-x:auto}
.tabs a{padding:10px 16px;color:var(--muted);text-decoration:none;font-size:13.5px;border-bottom:2px solid transparent;white-space:nowrap;transition:color 120ms,border-color 120ms}
.tabs a:hover{color:var(--ink)}
.tabs a.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}

/* === KPIs === */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
.kpi{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:18px;position:relative;overflow:hidden}
.kpi .label{font-family:var(--mono);font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:6px}
.kpi .val{font-size:26px;font-weight:700;letter-spacing:-0.3px}
.kpi .sub{font-size:11.5px;color:var(--muted);margin-top:4px}
.kpi.alarm .val{color:var(--alarm)}
.kpi.warn .val{color:var(--warn)}
.kpi.ok .val{color:var(--ok)}
.kpi.info .val{color:var(--info)}

/* === Section cards === */
section{background:var(--paper);border:1px solid var(--line);border-radius:14px;margin-bottom:22px;overflow:hidden}
section header{padding:16px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}
section .hdr-actions{display:flex;gap:8px;align-items:center}
section .body{padding:22px}
section .body.flush{padding:0}
.count-pill{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:2px 10px;font-size:11.5px;color:var(--muted);font-family:var(--mono)}

/* === Hub cards (admin.html) === */
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:28px}
.hub-card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:22px;text-decoration:none;color:inherit;transition:border-color 120ms,transform 120ms,box-shadow 120ms;display:flex;flex-direction:column;gap:10px;cursor:pointer}
.hub-card:hover{border-color:var(--brand);box-shadow:0 4px 14px rgba(1,70,109,0.08);transform:translateY(-1px)}
.hub-card .icon{width:42px;height:42px;border-radius:10px;background:var(--brand-soft);display:flex;align-items:center;justify-content:center;color:var(--brand)}
.hub-card h3{margin:0;font-size:16px;font-weight:600}
.hub-card p{margin:0;font-size:13px;color:var(--muted);line-height:1.5}
.hub-card .badge{display:inline-block;font-size:11px;font-weight:600;color:var(--muted);font-family:var(--mono)}
.hub-card.warn .icon{background:#fef3c7;color:#92400e}
.hub-card.alarm .icon{background:#fee2e2;color:#991b1b}
.hub-card.ok .icon{background:#dcfce7;color:#166534}

/* === Tablas === */
table.std{width:100%;border-collapse:collapse;font-size:13px}
table.std th,table.std td{padding:11px 16px;text-align:left;border-bottom:1px solid var(--line)}
table.std th{background:var(--bg);font-weight:600;color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:0.06em;position:sticky;top:0}
table.std tbody tr:last-child td{border-bottom:none}
table.std tbody tr:hover{background:var(--bg)}

/* === Buttons === */
.btn{padding:8px 14px;background:var(--brand);color:white;border:none;border-radius:8px;font-size:13px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px;font-weight:500}
.btn:hover{opacity:0.9}
.btn.outline{background:white;color:var(--ink);border:1px solid var(--line)}
.btn.outline:hover{background:var(--bg)}
.btn.danger{background:var(--alarm)}
.btn.sm{padding:5px 10px;font-size:11.5px}
.btn.icon{padding:6px;width:32px;height:32px;justify-content:center}

/* === Badges (roles, status) === */
.role{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;font-family:var(--mono)}
.role.owner{background:#fef3c7;color:#92400e}
.role.admin{background:#e0e7ff;color:#3730a3}
.role.editor{background:#dcfce7;color:#166534}
.role.viewer{background:#f1f5f9;color:#475569}
.status{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10.5px;font-weight:600;font-family:var(--mono)}
.status.active{background:#dcfce7;color:#166534}
.status.pending{background:#fef3c7;color:#92400e}
.status.disabled{background:#fee2e2;color:#991b1b}

/* === Avatar === */
.avatar{width:32px;height:32px;border-radius:50%;background:var(--brand);color:white;display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0;text-transform:uppercase}
.avatar.lg{width:42px;height:42px;font-size:16px}
.avatar.sm{width:24px;height:24px;font-size:10.5px}

.avatar-stack{display:inline-flex}
.avatar-stack .avatar{margin-left:-6px;border:2px solid var(--paper)}
.avatar-stack .avatar:first-child{margin-left:0}

/* === Permission matrix === */
.perm-matrix{width:100%;border-collapse:collapse;font-size:13px}
.perm-matrix th,.perm-matrix td{padding:10px 14px;text-align:center;border:1px solid var(--line)}
.perm-matrix th{background:var(--bg);font-weight:600;color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:0.06em}
.perm-matrix th.action{text-align:left}
.perm-matrix td.action{text-align:left;background:var(--bg);font-weight:500}
.perm-matrix .check{color:var(--ok);font-size:18px;font-weight:700}
.perm-matrix .cross{color:#cbd5e1;font-size:18px}
.perm-matrix tbody tr:hover td:not(.action){background:var(--bg)}

/* === Modal === */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,0.55);display:none;align-items:center;justify-content:center;z-index:200;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.modal-backdrop.show{display:flex}
.modal{background:white;border-radius:14px;padding:26px;max-width:540px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,0.25)}
.modal h3{margin:0 0 6px;font-size:18px}
.modal .lead{margin:0 0 18px;color:var(--muted);font-size:13px}
.modal .row{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.modal label{font-size:12px;font-weight:500;color:var(--muted)}
.modal input,.modal select,.modal textarea{padding:8px 12px;border:1px solid var(--line);border-radius:7px;font-size:13.5px;width:100%;font-family:inherit}
.modal .actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px;border-top:1px solid var(--line);padding-top:14px}

/* Modal de comando — para mostrar comando bash/python copyable */
.cmd-block{position:relative;background:#0f172a;color:#e2e8f0;padding:14px 50px 14px 16px;border-radius:8px;font-family:var(--mono);font-size:12.5px;line-height:1.6;white-space:pre-wrap;word-break:break-all;margin:8px 0}
.cmd-block .copy-btn{position:absolute;top:8px;right:8px;background:rgba(255,255,255,0.08);color:#cbd5e1;border:1px solid rgba(255,255,255,0.1);border-radius:6px;padding:4px 10px;font-size:11px;font-family:inherit;cursor:pointer;font-weight:500}
.cmd-block .copy-btn:hover{background:rgba(255,255,255,0.15);color:white}
.cmd-block .copy-btn.copied{background:#10b981;color:white;border-color:#10b981}
.cmd-info{display:flex;align-items:flex-start;gap:8px;padding:11px 14px;border-radius:8px;background:#fef3c7;color:#78350f;font-size:12.5px;margin-bottom:8px;line-height:1.55}
.cmd-info.danger{background:#fee2e2;color:#991b1b}
.cmd-info.info{background:#dbeafe;color:#1e3a8a}
.cmd-info strong{font-weight:600}
.cmd-info svg{flex-shrink:0;margin-top:1px}

/* === Helpers === */
.empty{padding:40px;text-align:center;color:var(--muted);font-size:13px}
.tenant-pill{display:inline-block;padding:1px 7px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;font-family:var(--mono);margin:1px 2px}
.tenant-pill.crillon{background:#fef3c7;color:#92400e}
.tenant-pill.westminster{background:#fce7f3;color:#9d174d}
.tenant-pill.icm{background:#dcfce7;color:#166534}
.tenant-pill.cdi{background:#e0e7ff;color:#3730a3}
.tenant-pill.ipq{background:#fee2e2;color:#991b1b}
.tenant-pill.vcm{background:#fef9c3;color:#854d0e}
.tenant-pill.ice{background:#cffafe;color:#155e75}
.tenant-pill.comaser{background:#f3e8ff;color:#6b21a8}
.muted-tx{color:var(--muted);font-size:12.5px}
.mono{font-family:var(--mono)}

@media (max-width:900px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .hub-grid{grid-template-columns:1fr}
  table.std{font-size:12px}
  table.std th,table.std td{padding:8px 11px}
}
