:root{
  --sidebar-w: 250px;
  --topbar-h: 72px;
  --bg:#040405;
  --bg-soft:#08080a;
  --bg-panel:#0b0b0f;
  --bg-card:#101014;
  --bg-card-2:#0c0c11;
  --line:rgba(255,255,255,.07);
  --line-strong:rgba(255,255,255,.12);
  --text:#eef2f7;
  --muted:#98a2b3;
  --muted-2:#6b7280;
  --primary:#3b82f6;
  --primary-2:#2563eb;
  --success:#22c55e;
  --warning:#f59e0b;
  --danger:#ef4444;
  --radius-xl:28px;
  --radius-lg:20px;
  --radius-md:16px;
  --shadow:0 18px 36px rgba(0,0,0,.28);
  --shadow-soft:0 10px 24px rgba(0,0,0,.22);
  --content-max: 1700px;
  font-synthesis-weight:none;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,Arial,sans-serif}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
a{color:inherit;text-decoration:none}

body{min-height:100vh;background:
 radial-gradient(circle at top left, rgba(59,130,246,.06), transparent 24%),
 radial-gradient(circle at top right, rgba(255,255,255,.03), transparent 18%),
 linear-gradient(180deg, #050506 0%, #040405 100%);
}

.dev-shell{display:flex;min-height:100vh}
.dev-sidebar{
  width:var(--sidebar-w);
  flex:0 0 var(--sidebar-w);
  border-right:1px solid var(--line);
  background:linear-gradient(180deg, #07070a 0%, #040405 100%);
  position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;
}
.sidebar-brand{
  height:var(--topbar-h);
  display:flex;align-items:center;
  padding:0 22px;
  border-bottom:1px solid var(--line);
}
.brand-mark{font-size:28px;font-weight:1000;letter-spacing:.06em;color:#f8fbff}
.brand-sub{margin-top:2px;font-size:12px;font-weight:800;letter-spacing:.24em;color:#7fb0ff}

.sidebar-nav{display:grid;gap:10px;padding:18px 12px}
.sidebar-link{
  width:100%;min-height:48px;border:1px solid transparent;border-radius:18px;
  background:transparent;color:#d8e4ff;display:flex;align-items:center;gap:12px;padding:0 14px;
  font-size:14px;font-weight:900;transition:.18s ease;
}
.sidebar-link:hover{background:rgba(255,255,255,.04);border-color:var(--line);transform:translateX(2px)}
.sidebar-link.active{
  background:linear-gradient(135deg, rgba(59,130,246,.22), rgba(29,78,216,.34));
  border-color:rgba(125,171,255,.32);
  box-shadow:0 14px 26px rgba(29,78,216,.24);
}
.sidebar-ico{width:18px;flex:0 0 18px;text-align:center}
.sidebar-secondary{margin-top:auto;padding:0 12px 12px}
.sidebar-footer{padding:18px 16px 22px;border-top:1px solid var(--line);display:grid;gap:10px}
.sidebar-footer-text{font-size:12px;font-weight:800;color:#b8c7e6}
.sidebar-footer-chip{display:inline-flex;width:max-content;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid var(--line);font-size:11px;font-weight:900;color:#88a6d9}

.dev-main-area{flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}
.topbar{
  height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;
  padding:0 18px 0 22px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, rgba(8,8,10,.96), rgba(5,5,7,.94));
  backdrop-filter:blur(10px);position:sticky;top:0;z-index:20;
}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:12px}
.topbar-home-btn{
  border:1px solid rgba(125,171,255,.28);background:rgba(59,130,246,.10);color:#e8f1ff;
  height:38px;border-radius:12px;padding:0 14px;font-weight:1000;letter-spacing:.06em;
}
.topbar-context{font-size:13px;font-weight:800;color:var(--muted)}
.topbar-chip{
  height:34px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;
  background:rgba(255,255,255,.05);border:1px solid var(--line);font-size:12px;font-weight:900;color:#9db4db;
}
.hello{font-size:14px;font-weight:900;color:#e6edfa}
.divider{width:1px;height:24px;background:rgba(255,255,255,.12)}
.topbar-icon{
  width:34px;height:34px;border-radius:10px;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);color:#e6edfa;display:grid;place-items:center;
}
.topbar-icon:hover{background:rgba(255,255,255,.10)}

#app{
  flex:1;overflow:auto;padding:22px;
}
.app-page{max-width:var(--content-max);margin:0 auto;display:grid;gap:18px}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.page-title{margin:0;font-size:40px;line-height:1.02;font-weight:1000;letter-spacing:-.03em}
.page-subtitle{margin:8px 0 0;font-size:14px;font-weight:800;color:var(--muted)}
.page-actions{display:flex;flex-wrap:wrap;gap:10px}

.btn,
.btn-ghost,
.btn-primary,
.btn-danger,
.btn-warning{
  height:42px;border-radius:14px;padding:0 16px;border:1px solid var(--line-strong);background:rgba(255,255,255,.04);
  color:var(--text);font-weight:900;
}
.btn-primary{background:linear-gradient(135deg, #3b82f6, #2563eb);border-color:rgba(125,171,255,.24);box-shadow:0 8px 24px rgba(37,99,235,.22)}
.btn-danger{background:linear-gradient(135deg, rgba(239,68,68,.18), rgba(185,28,28,.26));border-color:rgba(239,68,68,.28)}
.btn-warning{background:linear-gradient(135deg, rgba(245,158,11,.18), rgba(180,83,9,.22));border-color:rgba(245,158,11,.28)}
.btn-ghost:hover,.btn-primary:hover,.btn-danger:hover,.btn-warning:hover{filter:brightness(1.08)}

.grid-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.kpi-card,.panel,.table-card,.empty-card{
  border-radius:var(--radius-xl);background:linear-gradient(180deg, rgba(16,16,20,.96), rgba(9,9,12,.98));
  border:1px solid var(--line);box-shadow:var(--shadow);position:relative;
}
.kpi-card{padding:20px}
.kpi-label{font-size:12px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.kpi-value{margin-top:12px;font-size:42px;line-height:1;font-weight:1000}
.kpi-meta{margin-top:10px;font-size:12px;font-weight:800;color:var(--muted-2)}
.kpi-card.is-danger .kpi-value{color:#ff8e8e}
.kpi-card.is-success .kpi-value{color:#67e8a3}
.kpi-card.is-warning .kpi-value{color:#ffd27a}

.panel{padding:20px}
.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.panel-title{margin:0;font-size:26px;font-weight:1000;letter-spacing:-.02em}
.panel-subtitle{margin:6px 0 0;font-size:13px;font-weight:800;color:var(--muted)}
.panel-divider{height:1px;background:var(--line);margin:16px 0 18px}
.panel-grid-2{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}
.panel-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.panel-grid-2-equal{display:grid;grid-template-columns:1fr 1fr;gap:18px}

.list-stack{display:grid;gap:10px}
.item-row,
.alert-row,
.log-row,
.user-row,
.module-row,
.permission-row,
.config-row,
.finance-row{
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;
  padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.02);border:1px solid var(--line);
}
.item-title{font-size:15px;font-weight:900;color:#eff5ff}
.item-meta{margin-top:4px;font-size:12px;font-weight:800;color:var(--muted)}
.row-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}

.badge{
  min-height:32px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);font-size:12px;font-weight:950;white-space:nowrap;background:rgba(255,255,255,.04);color:#dce8ff;
}
.badge.success{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.28);color:#7df0aa}
.badge.warn{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.28);color:#ffd580}
.badge.danger{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.26);color:#ff9f9f}
.badge.info{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.26);color:#9bc2ff}

.table-card{padding:14px;overflow:hidden}
.table-scroll{overflow:auto}
.table{width:100%;border-collapse:separate;border-spacing:0 10px}
.table th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:left;padding:0 14px 6px;font-weight:900}
.table td{padding:14px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.02);font-size:14px;font-weight:800;color:#eaf1ff}
.table td:first-child{border-left:1px solid var(--line);border-radius:16px 0 0 16px}
.table td:last-child{border-right:1px solid var(--line);border-radius:0 16px 16px 0}

.filters{display:flex;flex-wrap:wrap;gap:10px}
.search,
.select,
.input,
.textarea{
  width:100%;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.02);color:var(--text);
  padding:0 14px;outline:none;
}
.search,.select,.input{height:44px}
.textarea{min-height:110px;padding-top:12px;resize:vertical}
.filter-bar{display:grid;grid-template-columns:1.2fr repeat(3,.7fr) auto;gap:10px}

.empty-card{padding:30px;text-align:center;color:var(--muted)}
.empty-title{font-size:18px;font-weight:1000;color:#eaf1ff}
.empty-text{margin-top:8px;font-size:13px;font-weight:800}

.tabs{display:flex;flex-wrap:wrap;gap:8px}
.tab-btn{
  min-height:40px;padding:0 14px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:#dce8ff;font-weight:900;
}
.tab-btn.active{background:linear-gradient(135deg, rgba(59,130,246,.22), rgba(29,78,216,.34));border-color:rgba(125,171,255,.34)}

.stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.mini-stat{padding:16px;border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.mini-stat-label{font-size:12px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.mini-stat-value{margin-top:10px;font-size:28px;font-weight:1000}

.note-box{padding:16px;border-radius:18px;background:rgba(59,130,246,.09);border:1px solid rgba(59,130,246,.18);font-size:13px;font-weight:800;color:#bcd6ff}
.danger-box{padding:16px;border-radius:18px;background:rgba(239,68,68,.10);border:1px solid rgba(239,68,68,.18);font-size:13px;font-weight:800;color:#ffc6c6}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.three-col{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}

@media (max-width: 1280px){
  .grid-kpis,.panel-grid-3,.three-col{grid-template-columns:repeat(2,minmax(0,1fr))}
  .panel-grid-2,.panel-grid-2-equal,.two-col,.filter-bar{grid-template-columns:1fr}
}
@media (max-width: 960px){
  .dev-shell{flex-direction:column}
  .dev-sidebar{position:relative;width:100%;height:auto}
  .sidebar-brand{height:auto;padding:18px 18px 10px}
  .sidebar-nav{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sidebar-secondary{margin-top:0}
  .grid-kpis,.panel-grid-3,.three-col,.stat-grid{grid-template-columns:1fr}
  .topbar{height:auto;min-height:var(--topbar-h);padding:12px 16px;align-items:flex-start;gap:12px;flex-direction:column}
  .topbar-left,.topbar-right{width:100%;justify-content:space-between;flex-wrap:wrap}
  #app{padding:16px}
  .page-title{font-size:32px}
}

.two-col-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}

.panel-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:20px 20px 0;
}

.panel-title{
  margin:0;
  font-size:24px;
  line-height:1.04;
  font-weight:1000;
}

.panel-subtitle{
  margin:6px 0 0;
  font-size:13px;
  font-weight:800;
  color:var(--muted);
}

.panel-body{
  padding:20px;
}

.list-body{
  display:grid;
  gap:12px;
}

.list-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
}

.list-title{
  font-size:15px;
  font-weight:900;
  color:var(--text);
}

.list-subtitle{
  margin-top:4px;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
}

.list-meta{
  font-size:12px;
  font-weight:900;
  color:#bcd0f5;
  white-space:nowrap;
}

.tenant-mini-grid{
  display:grid;
  gap:12px;
}

.tenant-mini-card{
  width:100%;
  text-align:left;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--text);
  padding:16px;
}

.tenant-mini-card:hover{
  border-color:rgba(125,171,255,.28);
  background:rgba(59,130,246,.08);
}

.tenant-mini-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.tenant-mini-name{
  font-size:16px;
  font-weight:1000;
}

.tenant-mini-line{
  margin-top:8px;
  font-size:13px;
  font-weight:700;
  color:var(--muted);
}

.status-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:1000;
  letter-spacing:.04em;
  text-transform:uppercase;
  border:1px solid transparent;
}

.status-ativo{
  color:#b7ffd1;
  background:rgba(34,197,94,.14);
  border-color:rgba(34,197,94,.24);
}

.status-bloqueado,
.status-suspenso{
  color:#ffc0c0;
  background:rgba(239,68,68,.14);
  border-color:rgba(239,68,68,.24);
}

.status-implantando{
  color:#ffe3a1;
  background:rgba(245,158,11,.14);
  border-color:rgba(245,158,11,.24);
}

.table-wrap{
  padding:20px;
  overflow:auto;
}

.data-table{
  width:100%;
  border-collapse:collapse;
  min-width:980px;
}

.data-table thead th{
  text-align:left;
  font-size:12px;
  font-weight:1000;
  color:#a9bddf;
  padding:0 14px 14px;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.data-table tbody td{
  padding:16px 14px;
  border-top:1px solid var(--line);
  vertical-align:middle;
  font-size:14px;
  font-weight:700;
  color:var(--text);
}

.table-main{
  font-size:15px;
  font-weight:1000;
}

.table-sub{
  margin-top:4px;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
}

.table-actions{
  white-space:nowrap;
}

.btn-sm{
  height:32px;
  padding:0 10px;
  border-radius:10px;
  font-size:11px;
  white-space:nowrap;
  align-self:flex-start;
}

.card-grid{
  display:grid;
  gap:12px;
}

.info-card{
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:16px;
}

.info-card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.info-card-title{
  font-size:15px;
  font-weight:1000;
}

.info-card-line{
  margin-top:8px;
  font-size:13px;
  font-weight:700;
  color:var(--muted);
}

.details-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px 18px;
}

.detail-row{
  font-size:14px;
  font-weight:700;
  color:var(--text);
}

.detail-row.full{
  grid-column:1 / -1;
}

.empty-inline{
  font-size:13px;
  font-weight:800;
  color:var(--muted);
}

.empty-title{
  font-size:24px;
  font-weight:1000;
}

.empty-text{
  margin-top:8px;
  color:var(--muted);
  font-weight:700;
}

.kpi-value.small{
  font-size:24px;
}

@media (max-width: 1100px){
  .grid-kpis,
  .two-col-grid,
  .details-grid{
    grid-template-columns:1fr;
  }
}.two-col-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}

.panel-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:20px 20px 0;
}

.panel-title{
  margin:0;
  font-size:24px;
  line-height:1.04;
  font-weight:1000;
}

.panel-subtitle{
  margin:6px 0 0;
  font-size:13px;
  font-weight:800;
  color:var(--muted);
}

.panel-body{
  padding:20px;
}

.list-body{
  display:grid;
  gap:12px;
}

.list-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
}

.list-title{
  font-size:15px;
  font-weight:900;
  color:var(--text);
}

.list-subtitle{
  margin-top:4px;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
}

.list-meta{
  font-size:12px;
  font-weight:900;
  color:#bcd0f5;
  white-space:nowrap;
}

.tenant-mini-grid{
  display:grid;
  gap:12px;
}

.tenant-mini-card{
  width:100%;
  text-align:left;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--text);
  padding:16px;
}

.tenant-mini-card:hover{
  border-color:rgba(125,171,255,.28);
  background:rgba(59,130,246,.08);
}

.tenant-mini-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.tenant-mini-name{
  font-size:16px;
  font-weight:1000;
}

.tenant-mini-line{
  margin-top:8px;
  font-size:13px;
  font-weight:700;
  color:var(--muted);
}

.status-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:1000;
  letter-spacing:.04em;
  text-transform:uppercase;
  border:1px solid transparent;
}

.status-ativo{
  color:#b7ffd1;
  background:rgba(34,197,94,.14);
  border-color:rgba(34,197,94,.24);
}

.status-bloqueado,
.status-suspenso{
  color:#ffc0c0;
  background:rgba(239,68,68,.14);
  border-color:rgba(239,68,68,.24);
}

.status-implantando{
  color:#ffe3a1;
  background:rgba(245,158,11,.14);
  border-color:rgba(245,158,11,.24);
}

.table-wrap{
  padding:20px;
  overflow:auto;
}

.data-table{
  width:100%;
  border-collapse:collapse;
  min-width:980px;
}

.data-table thead th{
  text-align:left;
  font-size:12px;
  font-weight:1000;
  color:#a9bddf;
  padding:0 14px 14px;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.data-table tbody td{
  padding:16px 14px;
  border-top:1px solid var(--line);
  vertical-align:middle;
  font-size:14px;
  font-weight:700;
  color:var(--text);
}

.table-main{
  font-size:15px;
  font-weight:1000;
}

.table-sub{
  margin-top:4px;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
}

.table-actions{
  white-space:nowrap;
}

.btn-sm{
  height:32px;
  padding:0 10px;
  border-radius:10px;
  font-size:11px;
  white-space:nowrap;
  align-self:flex-start;
}

.card-grid{
  display:grid;
  gap:12px;
}

.info-card{
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:16px;
}

.info-card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.info-card-title{
  font-size:15px;
  font-weight:1000;
}

.info-card-line{
  margin-top:8px;
  font-size:13px;
  font-weight:700;
  color:var(--muted);
}

.details-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px 18px;
}

.detail-row{
  font-size:14px;
  font-weight:700;
  color:var(--text);
}

.detail-row.full{
  grid-column:1 / -1;
}

.empty-inline{
  font-size:13px;
  font-weight:800;
  color:var(--muted);
}

.empty-title{
  font-size:24px;
  font-weight:1000;
}

.empty-text{
  margin-top:8px;
  color:var(--muted);
  font-weight:700;
}

.kpi-value.small{
  font-size:24px;
}

@media (max-width: 1100px){
  .grid-kpis,
  .two-col-grid,
  .details-grid{
    grid-template-columns:1fr;
  }
}

.loading-box{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:120px;
  border-radius:18px;
  border:1px dashed var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-size:14px;
  font-weight:800;
}

.empty-card{
  border-radius:24px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:28px;
}

.info-card-button{
  width:100%;
  text-align:left;
  cursor:pointer;
  color:var(--text);
}

.info-card-button:hover{
  border-color:rgba(125,171,255,.28);
  background:rgba(59,130,246,.08);
}

.action-stack{
  display:grid;
  gap:12px;
}

.action-wide{
  width:100%;
  justify-content:center;
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px 16px;
}

.field{
  display:grid;
  gap:8px;
}

.field-full{
  grid-column:1 / -1;
}

.field-label{
  font-size:12px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#a9bddf;
}

.field-input{
  width:100%;
  min-height:46px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  color:var(--text);
  padding:0 14px;
  font-size:14px;
  font-weight:700;
  outline:none;
}

.field-input:focus{
  border-color:rgba(59,130,246,.45);
  background:rgba(255,255,255,.03);
}

.field-textarea{
  min-height:110px;
  padding:14px;
  resize:vertical;
}

.field-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
  margin-top:6px;
}

.form-feedback{
  min-height:20px;
  font-size:13px;
  font-weight:800;
}

.form-feedback.pending{
  color:#ffe3a1;
}

.form-feedback.success{
  color:#b7ffd1;
}

.form-feedback.error{
  color:#ffc0c0;
}

.checkbox-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}

.check-item{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:44px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:0 12px;
  font-size:14px;
  font-weight:700;
  color:var(--text);
}

.check-item input{
  accent-color:#5b8cff;
}

@media (max-width: 1100px){
  .form-grid,
  .checkbox-grid{
    grid-template-columns:1fr;
  }

  .field-actions{
    justify-content:stretch;
  }

  .field-actions .btn-primary,
  .field-actions .btn-ghost,
  .field-actions .btn-warning,
  .field-actions .btn-danger{
    width:100%;
    justify-content:center;
  }
}

.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.76);
  backdrop-filter:blur(6px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  z-index:999;
}

.modal-overlay.hidden{
  display:none;
}

.modal-card{
  width:min(100%, 760px);
  border-radius:26px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(14,14,18,.98), rgba(8,8,11,.98));
  box-shadow:0 20px 80px rgba(0,0,0,.52);
}

.modal-card-lg{
  width:min(100%, 980px);
}

.modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:22px 22px 0;
}

.modal-close{
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--text);
  font-size:18px;
  font-weight:900;
  cursor:pointer;
}

.modal-close:hover{
  background:rgba(255,255,255,.08);
}

.field-select{
  color-scheme:dark;
}

.field-select option{
  background:#0b1634;
  color:#eef4ff;
}

.file-input-native{
  position:absolute;
  opacity:0;
  pointer-events:none;
  width:1px;
  height:1px;
}

.file-upload-shell{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:54px;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  padding:10px 12px;
  cursor:pointer;
  transition:.18s ease;
}

.file-upload-shell:hover{
  border-color:rgba(125,171,255,.35);
  background:rgba(255,255,255,.06);
}

.file-upload-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:0 14px;
  border-radius:12px;
  border:1px solid rgba(125,171,255,.22);
  background:rgba(59,130,246,.14);
  color:#eef4ff;
  font-size:13px;
  font-weight:900;
  white-space:nowrap;
}

.file-upload-name{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:var(--text);
  font-size:14px;
  font-weight:800;
}

.file-help{
  margin-top:6px;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
}

.table-sort-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:0;
  border:none;
  background:transparent;
  color:#a9bddf;
  font-size:12px;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.table-sort-btn:hover{
  color:#dbe8ff;
}

.col-logo{
  width:72px;
}

.company-logo-cell{
  display:flex;
  align-items:center;
  justify-content:center;
}

.company-logo-thumb{
  width:42px;
  height:42px;
  border-radius:12px;
  object-fit:cover;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
}

.company-logo-fallback{
  width:42px;
  height:42px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  font-weight:1000;
  color:#eef4ff;
  border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(59,130,246,.18), rgba(29,78,216,.24));
}

.table-toolbar{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  min-width:320px;
}

.table-search-input{
  width:min(100%, 380px);
  min-height:42px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  color:var(--text);
  padding:0 14px;
  font-size:14px;
  font-weight:700;
  outline:none;
}

.table-search-input:focus{
  border-color:rgba(125,171,255,.35);
  background:rgba(255,255,255,.06);
}

.company-overview-body{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 180px;
  gap:20px;
  align-items:start;
}

.company-overview-main{
  min-width:0;
}

.company-overview-logo{
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
}

.company-overview-logo-image{
  width:160px;
  height:160px;
  border-radius:22px;
  object-fit:cover;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  box-shadow:0 12px 36px rgba(0,0,0,.24);
}

.company-overview-logo-fallback{
  width:160px;
  height:160px;
  border-radius:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:44px;
  font-weight:1000;
  color:#eef4ff;
  border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(59,130,246,.18), rgba(29,78,216,.24));
  box-shadow:0 12px 36px rgba(0,0,0,.24);
}

@media (max-width: 1100px){
  .company-overview-body{
    grid-template-columns:1fr;
  }

  .company-overview-logo{
    justify-content:flex-start;
  }

  .company-overview-logo-image,
  .company-overview-logo-fallback{
    width:120px;
    height:120px;
    border-radius:18px;
  }

  .company-overview-logo-fallback{
    font-size:32px;
  }
}

.form-section-title{
  grid-column:1 / -1;
  font-size:13px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:6px;
}

.form-divider{
  grid-column:1 / -1;
  height:1px;
  background:var(--line);
  margin:10px 0;
}

.module-permission-grid{
  display:grid;
  gap:12px;
}

.module-permission-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}

.module-permission-header{
  font-weight:700;
}

.module-kpis-compact{
  grid-template-columns:repeat(2,minmax(0,1fr));
}

.kpi-card-button{
  text-align:left;
  cursor:pointer;
  color:var(--text);
}

.kpi-card-button:hover{
  border-color:rgba(125,171,255,.28);
  background:linear-gradient(180deg, rgba(20,20,26,.98), rgba(11,11,15,.98));
  transform:translateY(-1px);
}

/* ações do módulo - compacto */

.module-actions-card{
  width:100%;
}

.module-users-card{
  width:100%;
}

.module-logs-tall{
  width:100%;
}

.module-actions-inline{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.module-actions-inline .btn-warning,
.module-actions-inline .btn-danger{
  width:auto;
  padding:10px 16px;
  font-size:13px;
  border-radius:12px;
}

.module-bottom-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);
  gap:18px;
  align-items:stretch;
}

.module-left-stack{
  display:grid;
  gap:18px;
  align-content:start;
}

.module-actions-card,
.module-users-card,
.module-logs-tall{
  height:100%;
}

.module-logs-tall{
  min-height:100%;
}

@media (max-width: 1100px){
  .module-bottom-grid{
    grid-template-columns:1fr;
  }
}

.info-card-button{
  cursor:pointer;
  transition:.18s ease;
}

.info-card-button:hover{
  transform:translateY(-2px);
  border-color:rgba(125,171,255,.28);
  background:rgba(59,130,246,.06);
}

.role-card-note{
  margin-top:10px;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
}

.system-module-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  font-size:11px;
  font-weight:900;
  color:#dce8ff;
}

.sensitive-groups{
  display:grid;
  gap:18px;
}

.sensitive-group{
  display:grid;
  gap:12px;
  padding:14px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}

.sensitive-group-title{
  font-size:14px;
  font-weight:1000;
  color:var(--text);
}

.core-role-config{
  display:grid;
  gap:18px;
}

.role-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

.role-tab-btn{
  min-height:40px;
  padding:0 14px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:#dce8ff;
  font-weight:900;
}

.role-tab-btn.active{
  background:linear-gradient(135deg, rgba(59,130,246,.22), rgba(29,78,216,.34));
  border-color:rgba(125,171,255,.34);
}

.role-selected-summary{
  display:grid;
  gap:6px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}

.role-selected-title{
  font-size:18px;
  font-weight:1000;
  color:var(--text);
}

.role-selected-subtitle{
  font-size:13px;
  font-weight:700;
  color:var(--muted);
}

.permission-tree{
  display:grid;
  gap:14px;
}

.permission-module-card.is-disabled{
  opacity:.88;
}

.permission-toggle{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:36px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  font-size:13px;
  font-weight:800;
  color:var(--text);
}

.permission-toggle input{
  accent-color:#5b8cff;
}

.permission-children{
  padding:0 20px 20px;
}

.permission-children.is-hidden{
  display:none;
}

.permission-children-empty{
  padding:0 20px 20px;
}

.check-item.is-disabled{
  opacity:.55;
}

.core-role-config{
  display:grid;
  gap:18px;
}

.role-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

.role-tab-btn{
  min-height:40px;
  padding:0 14px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:#dce8ff;
  font-weight:900;
}

.role-tab-btn.active{
  background:linear-gradient(135deg, rgba(59,130,246,.22), rgba(29,78,216,.34));
  border-color:rgba(125,171,255,.34);
}

.role-selected-summary{
  display:grid;
  gap:6px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}

.role-selected-title{
  font-size:18px;
  font-weight:1000;
  color:var(--text);
}

.role-selected-subtitle{
  font-size:13px;
  font-weight:700;
  color:var(--muted);
}

.permission-tree{
  display:grid;
  gap:14px;
}

.permission-module-card.is-disabled{
  opacity:.88;
}

.permission-toggle{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:36px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  font-size:13px;
  font-weight:800;
  color:var(--text);
}

.permission-toggle input{
  accent-color:#5b8cff;
}

.permission-children{
  padding:0 20px 20px;
}

.permission-children.is-hidden{
  display:none;
}

.permission-children-empty{
  padding:0 20px 20px;
}

.check-item.is-disabled{
  opacity:.55;
}

.users-layout-grid{
  align-items:start;
}

.user-company-list{
  display:grid;
  gap:14px;     
}

.user-company-block{
  display:grid;
  gap:10px;
  padding:14px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}

.user-company-config{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:12px;
}

.user-company-config.hidden{
  display:none;
}

@media (max-width: 900px){
  .user-company-config{
    grid-template-columns:1fr;
  }
}

.user-link-list{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.user-link-chip{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  font-size:11px;
  font-weight:900;
  color:#dce8ff;
}

.data-table tbody tr:hover td{
  background:rgba(255,255,255,.03);
}

.table-card .panel-head{
  align-items:center;
}

@media (max-width: 1100px){
  .table-card .panel-head{
    flex-direction:column;
    align-items:stretch;
  }

  .table-toolbar{
    min-width:0;
    width:100%;
    justify-content:stretch;
  }

  .table-search-input{
    width:100%;
  }
}

.membership-row{
  align-items:center;
}

.membership-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}

.membership-actions .list-meta{
  min-width:56px;
  text-align:right;
}

@media (max-width: 960px){
  .membership-actions{
    width:100%;
    justify-content:flex-start;
  }

  .membership-actions .list-meta{
    min-width:auto;
    text-align:left;
  }
}

.status-inativo,
.status-bloqueado,
.status-suspenso{
  color:#ffc0c0;
  background:rgba(239,68,68,.14);
  border-color:rgba(239,68,68,.24);
}

.membership-row{
  align-items:center;
}

.membership-row-blocked{
  opacity:.72;
  border-color:rgba(239,68,68,.24) !important;
  background:rgba(239,68,68,.05) !important;
}

.membership-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}

.membership-actions .status-badge{
  margin-right:2px;
}

@media (max-width: 960px){
  .membership-actions{
    width:100%;
    justify-content:flex-start;
  }
}

.user-avatar{
  width:56px;
  height:56px;
  border-radius:12px;
  background:#1e293b;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  font-weight:600;
}

.user-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.user-header-block{
  display:flex;
  align-items:center;
  gap:16px;
}

.user-avatar{
  width:56px;
  height:56px;
  border-radius:16px;
  background:linear-gradient(135deg, rgba(59,130,246,.18), rgba(29,78,216,.24));
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  color:#eef4ff;
  font-size:20px;
  font-weight:1000;
  flex:0 0 56px;
}

.user-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.user-avatar-lg{
  width:64px;
  height:64px;
  flex:0 0 64px;
  border-radius:18px;
  font-size:22px;
}

.modal-card-user-edit{
  width:min(100%, 980px);
}

.user-avatar-upload-row{
  display:grid;
  grid-template-columns:88px minmax(0,1fr);
  gap:14px;
  align-items:center;
}

.user-avatar-preview{
  width:88px;
  height:88px;
  flex:0 0 88px;
  border-radius:22px;
  font-size:28px;
}

.user-avatar-upload-box{
  display:grid;
  gap:8px;
  min-width:0;
}

@media (max-width: 900px){
  .user-header-block{
    align-items:flex-start;
  }

  .user-avatar-upload-row{
    grid-template-columns:1fr;
  }

  .user-avatar-preview{
    width:72px;
    height:72px;
    border-radius:18px;
    font-size:24px;
  }
}

.user-avatar-upload-actions{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
}

.file-upload-shell-compact{
  min-width:0;
}

.col-avatar{
  width:72px;
}

.user-table-avatar{
  width:42px;
  height:42px;
  border-radius:12px;
  border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(59,130,246,.18), rgba(29,78,216,.24));
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  color:#eef4ff;
  font-size:16px;
  font-weight:1000;
}

.user-table-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
}

@media (max-width: 900px){
  .user-avatar-upload-actions{
    grid-template-columns:1fr;
  }

  .user-avatar-upload-actions .btn-danger{
    width:100%;
    justify-content:center;
  }
}