.permissions-hero {
  background: linear-gradient(135deg, rgba(15,23,42,.98), rgba(37,99,235,.82));
  color: #fff;
  border: 0;
}
.permissions-hero .eyebrow { color: rgba(255,255,255,.78); text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; }
.permissions-stats .stat-card strong { font-size: clamp(1.8rem, 3vw, 2.6rem); }
.permissions-layout { align-items: start; }
.permissions-table td { vertical-align: middle; }
.inline-form, .compact-row-form { display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; }
.compact-row-form select { min-width: 180px; max-width: 100%; }
.btn-small { padding: .45rem .75rem; font-size: .86rem; }
.badge { display: inline-flex; align-items: center; border-radius: 999px; padding: .25rem .55rem; font-size: .75rem; background: #e2e8f0; color: #0f172a; margin: .1rem; }
.badge.success { background: #dcfce7; color: #166534; }
.badge.warning { background: #fef3c7; color: #92400e; }
.badge.danger { background: #fee2e2; color: #991b1b; }
.role-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1rem; }
.role-card { border: 1px solid #e2e8f0; border-radius: 18px; padding: 1rem; background: #fff; box-shadow: 0 12px 34px rgba(15,23,42,.06); }
.role-card h4 { margin: 0 0 .35rem; }
.role-card p { color: #64748b; min-height: 2.4rem; }
.permission-checks { display: grid; grid-template-columns: 1fr; gap: .45rem; margin: .8rem 0 1rem; }
.check-card { display: flex; gap: .55rem; align-items: center; border: 1px solid #e2e8f0; border-radius: 12px; padding: .6rem .7rem; background: #f8fafc; }
.check-card input { width: auto; }
.insight-list { display: grid; gap: .6rem; }
.insight-item { border-left: 4px solid #2563eb; background: #f8fafc; border-radius: 12px; padding: .75rem .9rem; color: #334155; }
.table-responsive { width: 100%; overflow-x: auto; }
@media (max-width: 820px) {
  .permissions-layout { grid-template-columns: 1fr !important; }
  .compact-row-form { display: grid; grid-template-columns: 1fr; }
  .compact-row-form select, .compact-row-form button { width: 100%; }
}
