/* ===== Fundo + texto ===== */

:root{
      --bg1:#0e256e;
      --bg2:#6576ad;

      --card:#ffffff;
      --cardSoft: rgba(255,255,255,.92);

      --text:#0f172a;
      --muted:#475569;

      --line:rgba(15,23,42,.10);

      --primary:#1f3a8a;
      --primaryHover:#2547a6;

      --shadow: 0 18px 50px rgba(0,0,0,.22);
      --shadowSoft: 0 10px 24px rgba(0,0,0,.08);

      --rCard:22px;
      --rBox:18px;
      --rInput:16px;
      --rPill:999px;
}


body{
 margin:0;
      font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
      color:var(--text);
      background:linear-gradient(135deg,var(--bg1),var(--bg2));
      min-height:100vh;
}

/* ===== Topbar ===== */
.topbar{
position: static;
      top: 0;
      z-index: 20;
      background: #fff;
      border-bottom: 1px solid var(--line);
      padding: 14px 22px;

      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:16px;
}

.brand{
    display:flex;
      align-items:center;
      gap:14px;
      min-width:0;
}

.brand-logo{
    width:44px;
      height:44px;
      object-fit:contain;
}

    .topbar-title{
      margin:0;
      font-size:22px;
      font-weight:900;
      line-height:1.1;
      letter-spacing:.2px;
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }

    .topbar-subtitle{
        margin:0;
      font-size:13px;
      color:var(--muted);
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }

    .topbar-right{
      display:flex;
      align-items:center;
      gap:10px;
    }

/* Pill usuário */
#userName{
  background:#323e7d;
  border: 1px solid rgba(255,255,255,.22);
  padding: 7px 12px;
  border-radius: 999px;
  backdrop-filter: blur(6px);
  color: #ffffff;
  font-weight: 900;
}

/* ===== Conteúdo ===== */
.page{
  padding: 18px 16px 44px;
}

.page-head{
  max-width:1100px;
  margin: 0 auto 14px;
  color: #ffff;
}

.breadcrumb{
  font-size:14px;
  margin: 6px 0 10px;
  opacity: .9;
}
.breadcrumb a{ color:#dfe7ff; text-decoration:underline; }

.page-title{
  margin:0;
  font-size: 28px;
  letter-spacing: .2px;
  color: #ffff;
}

.page-desc{
  margin: 8px 0 0;
  opacity: .92;
  color: #e8edff;
}

/* ===== Cards ===== */
.card{
  background: rgba(255,255,255,.95);
  border-radius: 14px;
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
  max-width:1100px;
  margin: 14px auto;
  padding: 12px 18px;
}

.card-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap: 10px;
  margin-bottom: 14px;
}

.card-title{
  margin:0;
  font-size: 18px;
}

.muted{ opacity: .72; }
.small{ font-size: .85rem; }
.mono{ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }

/* ===== Campos/Filtros ===== */
.filters{
  display:grid;
  grid-template-columns: repeat(3, minmax(200px, 1fr));
  gap: 14px 16px;
 
}

.field label{
  display:block;
  font-size: 13px;
  margin-bottom: 6px;
}

#searchUser, #roleFilter, #sectorFilter, .role-select{
  width: 90%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(25,58,119,.18);
  background: #fff;
  outline: none;
}


#searchUser:focus, #roleFilter:focus, #sectorFilter:focus, .role-select:focus{
  border-color: rgba(66,74,194,.55);
  box-shadow: 0 0 0 4px rgba(66,74,194,.14);
}

/* ===== Botões ===== */
#btnLogout {
  background:#323e7d;
  border: 1px solid rgba(255,255,255,.22);
  padding: 7px 12px;
  border-radius: 999px;
  backdrop-filter: blur(6px);
  color: #ffffff;
  text-decoration: underline;
   font-weight: 900;
}

#btnLogout:hover,
.btn.btn-small.btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(0,0,0,.14);
}

/* ===== Tabela (grid) ===== */
.table{
width: 100%;
 }

.admin-table .admin-row{
  display:grid;
  grid-template-columns: 1.2fr 1.4fr 0.8fr 1.6fr 0.6fr;
  gap: 10px 14px;
  align-items:center;
}

.row-head{
  padding: 12px 12px;
  border-radius: 12px;
  background: rgba(25,58,119,.06);
  border: 1px solid rgba(25,58,119,.10);
  font-weight: 700;
  color: #234a92;
}

.row.admin-row{
  padding: 12px 12px;
  border-radius: 12px;
  background: rgba(66,74,194,.08);
  border: 1px solid rgba(66,74,194,.10);
  margin-top: 10px;
}

.col.name strong{
  display:block;
  font-size: 15px;
  color: #163a7d;
}

.col.email{ color:#163a7d; }

/* ===== Managed Sectors como “chips” ===== */
.sectors-box{
  display:grid;
  grid-template-columns: repeat(3, minmax(130px, 1fr));
  gap: 8px 10px;
}

/* O checkbox fica “invisível” e o chip vira o clique */
.chip{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(25,58,119,.16);
  background: rgba(255,255,255,.70);
  font-size: 13px;
  color: #163a7d;
  cursor: pointer;
  user-select:none;
  transition: transform .12s, box-shadow .12s, background .12s;
}

.chip input{
  width: 14px;
  height: 14px;
  accent-color: #424ac2;
}

.chip:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(0,0,0,.10);
  background: rgba(255,255,255,.88);
}

/* ===== Responsivo ===== */
@media (max-width: 980px){
  .filters{ grid-template-columns: 1fr; }
  .admin-table .admin-row{ grid-template-columns: 1fr; }
  .row-head{ display:none; }
  .sectors-box{ grid-template-columns: repeat(2, minmax(140px, 1fr)); }
}

@media (max-width: 520px){
  .sectors-box{ grid-template-columns: 1fr; }
  .topbar-title{ font-size: 17px; }
}
