/* ==========================================================
   LEGISLACAO / CATEGORIA — CSS (COMPATIVEL COM CSS BASE)
   - NAO redefine :root (tokens ficam no base)
   - NAO altera .leg-card global (somente dentro #legCategoria)
   - Escopo: #legCategoria
   ========================================================== */

/* ---------- CONTAINER / RESPIRO ---------- */
#legCategoria.leg-cat-wrap{
  max-width:1200px;
  margin:0 auto;
  padding:0 18px; /* respiro lateral (PC) */
}
@media(max-width:767px){
  #legCategoria.leg-cat-wrap{ padding:0 12px; }
}

/* evita interferencia do grid do bootstrap dentro do container */
#legCategoria *{ box-sizing:border-box; }
#legCategoria a{ text-decoration:none; color:inherit; }
#legCategoria a:hover{ text-decoration:none; }

/* ---------- BREADCRUMB ---------- */
#legCategoria .leg-crumbs{
  color:var(--leg-muted);
  font-weight:800;
  font-size:12px;
  letter-spacing:.02em;
  margin:12px 0 14px;
}
#legCategoria .leg-crumbs span{ opacity:.7; padding:0 6px; }
#legCategoria .leg-crumbs a{ color:var(--leg-muted); }
#legCategoria .leg-crumbs a:hover{ text-decoration:underline; }

/* ---------- HERO (categoria) ---------- */
#legCategoria .leg-cat-hero{
  position:relative;
  border-radius:var(--leg-radius);
  overflow:hidden;
  border:1px solid rgba(15,23,42,.06);
  box-shadow:0 16px 36px rgba(16,24,40,.10);
  background:
    radial-gradient(900px 520px at 18% 32%, rgba(255,255,255,.92) 0%, rgba(255,255,255,.72) 48%, rgba(255,255,255,0) 72%),
    linear-gradient(180deg,#fbfbfc 0%, #eef3f7 100%);
}
#legCategoria .leg-cat-hero__bg{
  position:absolute;
  inset:0;
  background-image:url("https://alimentosonline.com.br/imagens/bg_legislacao2.png");
  background-repeat:no-repeat;
  background-position:right bottom;
  background-size:76%;
  opacity:.42;
  filter:saturate(.95) contrast(.98);
}
#legCategoria .leg-cat-hero__content{
  position:relative;
  z-index:2;
  padding:22px 26px 10px;
  max-width:980px;
}
#legCategoria .leg-cat-title{
  margin:0 0 6px;
  font-size:34px;
  line-height:1.12;
  font-weight:950;
  color:var(--leg-ink);
  letter-spacing:-.35px;
}
#legCategoria .leg-cat-sub{
  margin:0 0 10px;
  max-width:680px;
  font-size:15px;
  line-height:1.6;
  color:#475467;
  font-weight:650;
}
#legCategoria .leg-cat-sub strong{ font-weight:950; color:#1f2937; }

/* pills */
#legCategoria .leg-cat-meta{
  position:relative;
  z-index:2;
  padding:0 26px 18px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
#legCategoria .leg-meta-pill{
  height:38px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.10);
  background:rgba(255,255,255,.90);
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:950;
  color:#344054;
}
#legCategoria .leg-meta-pill .muted{ color:var(--leg-muted); font-weight:950; }
#legCategoria .leg-meta-pill .leg-ico{ color:#1f7a63; }
#legCategoria .leg-meta-pill.select{ padding-right:10px; }
#legCategoria .leg-meta-pill select{
  border:0;
  outline:0;
  background:transparent;
  font-weight:950;
  color:#344054;
  cursor:pointer;
}

.leg-meta-link{
  color:inherit;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:6px;
}

.leg-meta-link:hover{
  text-decoration:underline;
  opacity:.85;
}
/* ---------- SECTION BG + GRID ---------- */
#legCategoria .leg-cat-section{
  margin-top:14px;
  border-radius:var(--leg-radius);
  background:var(--leg-bg);
  padding:14px;
}
#legCategoria .leg-cat-grid{
  display:grid;
  grid-template-columns: 1.9fr 1fr;
  gap:14px;
  align-items:start;
}
@media(max-width:992px){
  #legCategoria .leg-cat-grid{ grid-template-columns:1fr; }
}

/* ---------- CARD (somente categoria) ---------- */
#legCategoria .leg-card{
  background:var(--leg-card);
  border:1px solid rgba(15,23,42,.10);
  border-radius:var(--leg-radius-md);
  box-shadow:0 10px 18px rgba(16,24,40,.06);
  overflow:hidden;
}
#legCategoria .leg-card__head{
  padding:16px 18px 10px;
  border-bottom:1px solid rgba(15,23,42,.06);
  background:linear-gradient(180deg,#ffffff 0%, #fbfbfc 100%);
}
#legCategoria .leg-card__title{
  margin:0;
  font-size:12px;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--leg-ink);
}
#legCategoria .leg-card__sub{
  margin:6px 0 0;
  font-size:13px;
  line-height:1.45;
  color:var(--leg-muted);
  font-weight:650;
}
#legCategoria .leg-card__body{ padding:14px 18px 18px; }

/* util */
#legCategoria .leg-mt-14{ margin-top:14px !important; }

/* ---------- SEARCH (categoria) ---------- */
#legCategoria .leg-in-search{
  display:flex;
  gap:10px;
  align-items:center;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
}
#legCategoria .leg-in-search .leg-ico{ color:var(--leg-muted); }
#legCategoria .leg-in-search input{
  width:100%;
  border:0 !important;
  outline:0 !important;
  background:transparent !important;
  font-size:14px !important;
  color:var(--leg-ink) !important;
  font-weight:650 !important;
  padding:0 !important;
}
#legCategoria .leg-in-search input::placeholder{ color:#98a2b3; font-weight:650; }
#legCategoria .leg-in-search button{
  height:40px;
  padding:0 14px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.10);
  background:var(--leg-pill);
  font-weight:950;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#344054;
  cursor:pointer;
}
#legCategoria .leg-in-search button:hover{ background:var(--leg-pill-hover); }

/* ---------- FILTER ROW ---------- */
#legCategoria .leg-filter-row{
  margin-top:12px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
#legCategoria .leg-filter{
  height:38px;
  padding:0 10px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
#legCategoria .leg-filter select{
  border:0;
  outline:0;
  background:transparent;
  font-weight:900;
  color:#344054;
  cursor:pointer;
}
#legCategoria .leg-filter-apply{
  margin-left:auto;
  height:38px;
  padding:0 14px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.12);
  background:linear-gradient(180deg, #1f7a63 0%, #156553 100%);
  color:#fff;
  font-weight:950;
  cursor:pointer;
}
#legCategoria .leg-filter-apply:hover{ filter:brightness(.98); }
@media(max-width:640px){
  #legCategoria .leg-filter-apply{ width:100%; margin-left:0; }
}

/* ---------- SUBCATEGORIAS (o que estava "poracrai") ---------- */
#legCategoria .leg-sub-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
@media(max-width:640px){
  #legCategoria .leg-sub-grid{ grid-template-columns:1fr; }
}

#legCategoria .leg-sub-card{
  position:relative;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 10px 18px rgba(16,24,40,.06);
  overflow:hidden;
  min-height:96px;

  display:flex;
  align-items:center;
  padding:16px 16px;
  gap:14px;
  transition:.14s ease;

  background:
    radial-gradient(520px 240px at 92% 18%, rgba(31,122,99,.08) 0%, rgba(31,122,99,0) 62%),
    radial-gradient(420px 220px at 14% 28%, rgba(31,122,99,.10) 0%, rgba(31,122,99,0) 62%),
    linear-gradient(180deg,#ffffff 0%, #fbfbfc 100%);
}
#legCategoria .leg-sub-card:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 44px rgba(16,24,40,.10);
}
#legCategoria .leg-sub-card::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("https://alimentosonline.com.br/imagens/bg_legislacao.png");
  background-repeat:no-repeat;
  background-position:right center;
  background-size:82%;
  opacity:.10;
  filter:contrast(1) saturate(.9);
  pointer-events:none;
}

#legCategoria .leg-sub-ico{
  position:relative;
  z-index:2;
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
}
#legCategoria .leg-sub-ico .leg-ico{ color:#1f7a63; }
#legCategoria .leg-sub-ico .leg-ico svg{
  width:30px;
  height:30px;
  stroke-width:2.6;
  filter:
    drop-shadow(0 10px 18px rgba(31,122,99,.14))
    drop-shadow(0 2px 6px rgba(15,23,42,.10));
}

#legCategoria .leg-sub-main{ position:relative; z-index:2; min-width:0; }
#legCategoria .leg-sub-name{
  font-weight:950;
  color:var(--leg-ink);
  line-height:1.15;
  font-size:14px;
  letter-spacing:-.1px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
#legCategoria .leg-sub-meta{
  margin-top:6px;
  font-size:12px;
  color:var(--leg-muted);
  font-weight:800;
}
#legCategoria .leg-sub-star{
  color:#f59e0b;
  font-weight:950;
  font-size:14px;
  line-height:1;
}
#legCategoria .leg-sub-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:22px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(31,122,99,.18);
  background:rgba(31,122,99,.08);
  color:#1f7a63;
  font-weight:950;
  font-size:11px;
}

#legCategoria .leg-sub-card.is-active{
  background:
    radial-gradient(520px 240px at 92% 18%, rgba(31,122,99,.16) 0%, rgba(31,122,99,0) 62%),
    radial-gradient(420px 220px at 14% 28%, rgba(31,122,99,.14) 0%, rgba(31,122,99,0) 62%),
    linear-gradient(180deg, #e8f3ef 0%, #f3fbf8 100%);
  border-color:rgba(31,122,99,.22);
}
#legCategoria .leg-sub-card.is-active .leg-sub-ico .leg-ico{ color:#156553; }

/* ---------- RIGHT: ACTION CARDS ---------- */
#legCategoria .leg-rail-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

#legCategoria .leg-action-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:14px 14px;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  background:linear-gradient(180deg,#ffffff 0%, #fbfbfc 100%);
  box-shadow:0 10px 18px rgba(16,24,40,.06);
  transition:.14s ease;
}
#legCategoria .leg-action-card:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 44px rgba(16,24,40,.10);
}
#legCategoria .leg-action-left{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:950;
  color:var(--leg-ink);
}
#legCategoria .leg-action-left .leg-ico{ color:#1f7a63; }
#legCategoria .leg-action-card > .leg-ico{ color:var(--leg-muted-2); }

/* ---------- LISTAS (ultimas/top) ---------- */
#legCategoria .leg-list{ display:flex; flex-direction:column; gap:10px; }

#legCategoria .leg-row{
  display:flex;
  gap:10px;
  padding:12px 12px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  transition:.12s ease;
}
#legCategoria .leg-row:hover{ background:#f9fafb; }

#legCategoria .leg-badge{
  height:22px;
  padding:0 10px;
  border-radius:999px;
  font-weight:950;
  font-size:11px;
  letter-spacing:.02em;
  flex:0 0 auto;
  margin-top:2px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid transparent;
}

/* badges do mock */
#legCategoria .badge-alter{ background:rgba(29,78,216,.12); color:#1d4ed8; border-color:rgba(29,78,216,.26); }
#legCategoria .badge-revog{ background:rgba(239,68,68,.12); color:#b91c1c; border-color:rgba(239,68,68,.24); }
#legCategoria .badge-top  { background:rgba(31,122,99,.10); color:#1f7a63; border-color:rgba(31,122,99,.20); }

#legCategoria .leg-row__main{ flex:1; min-width:0; }
#legCategoria .leg-ref{ font-weight:950; color:var(--leg-ink); }
#legCategoria .leg-txt{ margin-top:4px; font-size:12.5px; line-height:1.35; color:#475467; font-weight:650; }

#legCategoria .leg-link{
  margin-top:10px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:950;
  color:var(--leg-ink);
}
#legCategoria .leg-link:hover{ text-decoration:underline; }

/* ---------- TABLE ---------- */
#legCategoria .leg-table-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:16px 18px 10px;
  border-bottom:1px solid rgba(15,23,42,.06);
  background:linear-gradient(180deg,#ffffff 0%, #fbfbfc 100%);
}
#legCategoria .leg-table-title{
  margin:0;
  font-size:14px;
  font-weight:950;
  color:var(--leg-ink);
}
#legCategoria .leg-mini-btn{
  height:34px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  font-weight:900;
  color:#344054;
  cursor:pointer;
}
#legCategoria .leg-mini-btn:hover{ background:#f9fafb; }

#legCategoria .leg-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
}
#legCategoria .leg-table th,
#legCategoria .leg-table td{
  padding:12px 12px;
  border-bottom:1px solid rgba(15,23,42,.06);
  font-size:13px;
  vertical-align:top;
}
#legCategoria .leg-table th{
  text-align:left;
  color:var(--leg-muted);
  font-weight:900;
  font-size:12px;
}
#legCategoria .leg-table tr:last-child td{ border-bottom:0; }

#legCategoria .leg-td-norma{ font-weight:900; color:var(--leg-ink); }
#legCategoria .leg-td-orgao{ color:#475467; font-weight:800; text-align:center; }
#legCategoria .leg-td-data{ color:#475467; font-weight:800; }

#legCategoria .leg-status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:22px;
  padding:0 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:950;
  border:1px solid transparent;
  white-space:nowrap;
}

/* status do mock */
#legCategoria .status-vigente{ background:rgba(31,122,99,.10); color:#1f7a63; border-color:rgba(31,122,99,.20); }
#legCategoria .status-alterada{ background:rgba(245,158,11,.16); color:#b45309; border-color:rgba(245,158,11,.28); }
#legCategoria .status-revogada{ background:rgba(239,68,68,.12); color:#b91c1c; border-color:rgba(239,68,68,.24); }

#legCategoria .leg-fav-star{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
}
#legCategoria .leg-fav-star .leg-ico{ color:#f59e0b; }
#legCategoria .leg-fav-star .leg-ico svg{
  width:18px;
  height:18px;
  stroke-width:1.5;
}

/* ---------- BOTTOM BUTTONS ---------- */
#legCategoria .leg-bottom{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
@media(max-width:820px){
  #legCategoria .leg-bottom{ grid-template-columns:1fr; }
}
#legCategoria .leg-bottom-btn{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
  padding:14px 14px;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  background:linear-gradient(180deg,#ffffff 0%, #fbfbfc 100%);
  box-shadow:0 10px 18px rgba(16,24,40,.06);
  font-weight:950;
  color:var(--leg-ink);
  transition:.14s ease;
}
#legCategoria .leg-bottom-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 44px rgba(16,24,40,.10);
}
#legCategoria .leg-bottom-btn .leg-ico{ color:#1f7a63; }
#legCategoria .leg-bottom-btn .leg-ico svg{ width:22px; height:22px; }

/* =========================================================
   legislacao/assets/css/legislacao_categoria_extra.css
   - Overrides e ajustes do template legislacao_categoria.php
   - Sem duplicações
   ========================================================= */

/* -------------------------
   Helpers de UI / estado
   ------------------------- */
.leg-sub-card.is-hidden{
  display:none !important;
}

#legCategoria .leg-table tbody tr.is-hidden{
  display:none !important;
}

/* A-Z */
.leg-az .leg-pill.is-disabled{
  opacity:.35;
  pointer-events:none;
}

.leg-az .leg-pill.is-active{
  background: rgba(34,197,94,.12);  /* verde claro */
  color: #15803d;
  border-color: #22c55e;
  box-shadow: 0 4px 12px rgba(34,197,94,.25);
}

/* -------------------------
   "Ver mais" (subcategorias)
   ------------------------- */
.leg-sub-more{
  display:flex;
  justify-content:center;
  margin-top:18px;
}

.leg-btn-more{
  display:inline-flex;
  align-items:center;
  gap:8px;

  padding:10px 16px;
  border-radius:999px;

  font-weight:700;
  font-size:13px;

  border:1px solid rgba(15,23,42,.18);
  background: linear-gradient(180deg,#ffffff,#f4f6f8);
  color:#374151;

  box-shadow: 0 6px 14px rgba(16,24,40,.08);
  cursor:pointer;
  transition: all .15s ease;
}

.leg-btn-more:hover{
  background: linear-gradient(180deg,#ffffff,#eef1f4);
  box-shadow: 0 10px 20px rgba(16,24,40,.12);
  transform: translateY(-1px);
}

.leg-btn-more:active{
  background:#eef1f4;
  box-shadow: 0 4px 10px rgba(16,24,40,.12);
  transform: translateY(0);
}

.leg-btn-more:focus{
  outline:none;
}

.leg-btn-more:focus-visible{
  box-shadow: 0 0 0 3px rgba(15,23,42,.15), 0 8px 18px rgba(16,24,40,.12);
}

/* -------------------------
   Tabela (normas)
   ------------------------- */
.leg-td-norma{
  line-height:1.25;
}

.leg-td-norma a{
  display:block;
  font-weight:600;
}

.leg-norma-desc{
  display:block;
  margin-top:4px;
  font-size:12px;
  color:#6b7280;
  line-height:1.4;
}

.leg-td-situacao{
  text-align:center;
}

/* -------------------------
   Campo "Dica" (leg-filter)
   ------------------------- */
.leg-filter{
  height:34px;
  border:1px solid var(--leg-line);
  border-radius:12px;
  padding:0 10px;
  background:#fff;
  color:var(--leg-ink);
  font-size:13px;
}

/* -------------------------
   Select invisível (Filtro)
   ------------------------- */
.leg-table-actions{
  display:flex;
  align-items:center;
  gap:8px;
}

.leg-filter-wrap{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:8px;

  height:32px;
  padding:0 34px 0 12px; /* espaço seta direita */
  border:1px solid var(--leg-line);
  border-radius:12px;

  background:var(--leg-card);
  color:var(--leg-ink);

  box-shadow:0 1px 2px rgba(0,0,0,.04);
  cursor:pointer;
  transition:.15s ease;
}

.leg-filter-wrap:hover{
  background:#f9fafb;
  border-color:#cbd5e1;
}

.leg-filter-wrap:focus-within{
  border-color:#6366f1;
  box-shadow:0 0 0 3px rgba(99,102,241,.15);
}

.leg-filter-wrap .leg-ico{
  color:var(--leg-muted);
  width:16px;
  height:16px;
}

.leg-filter-label{
  font-size:12px;
  font-weight:600;
  line-height:1;
  white-space:nowrap;
}

.leg-filter-wrap:after{
  content:'';
  position:absolute;
  right:12px;
  top:50%;
  width:0;
  height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-top:5px solid var(--leg-muted);
  transform:translateY(-30%);
  pointer-events:none;
}

.leg-filter-select{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor:pointer;
  border:0;
  background:transparent;
}

.leg-filter-select:focus{
  outline:none;
}

/* -------------------------
   Action cards (coluna direita)
   ------------------------- */
.leg-action-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;

  padding:12px 12px;
  border:1px solid var(--leg-line);
  border-radius:14px;
  background:var(--leg-card);
  color:var(--leg-ink);

  box-shadow:0 6px 16px rgba(16,24,40,.06);
  transition:.15s ease;
}

.leg-action-card:hover{
  transform:translateY(-1px);
  border-color:rgba(15,23,42,.18);
}

.leg-action-left{
  display:flex;
  align-items:flex-start;
  gap:10px;
  min-width:0;
}

.leg-action-title{
  display:block;
  font-size:13px;
  font-weight:700;
  line-height:1.2;
}

.leg-action-sub{
  display:block;
  margin-top:2px;
  font-size:12px;
  color:var(--leg-muted);
  line-height:1.25;
}

.leg-action-strong{
  font-weight:800;
}

.leg-action-card--info{
  cursor:default;
}

/* Pills (favorita / não favorita) */
.leg-pill{
  display:inline-flex;
  align-items:center;
  height:22px;
  padding:0 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;

  border:1px solid var(--leg-line);
  background:#f8fafc;
  color:var(--leg-muted);
  white-space:nowrap;
}

.leg-pill--on{
  background:rgba(250,204,21,.16);
  border-color:rgba(250,204,21,.35);
  color:#a16207;
  box-shadow:0 0 0 1px rgba(250,204,21,.15) inset;
}

/* Salvando favorito */
.link_favorito_categoria.is-saving{
  opacity:.65;
  pointer-events:none;
}

/* Ícone estrela */
.link_favorito_categoria [data-lucide="star"]{
  color:var(--leg-muted);
  transition:.15s ease;
}

.link_favorito_categoria[data-fav="s"] [data-lucide="star"]{
  color:#facc15 !important;
  filter:drop-shadow(0 0 4px rgba(250,204,21,.35));
}

/* Badge TOP */
.badge-top{
  background: rgba(245, 158, 11, .14) !important;
  color: #b45309 !important;
  border: 1px solid rgba(245, 158, 11, .35) !important;
}


/* =========================================================
   FIX MOBILE COMPLETO — TABELA "NORMAS"
   Layout profissional, alinhado e estável
   ========================================================= */
@media (max-width: 820px){

  /* esconde o cabeçalho da tabela */
  #legCategoria .leg-table thead{
    display:none !important;
  }

  /* estrutura base */
  #legCategoria .leg-table,
  #legCategoria .leg-table tbody{
    display:block;
    width:100%;
  }

  /* cada TR vira um CARD com GRID */
  #legCategoria .leg-table tbody tr{
    display:grid !important;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "norma norma"
      "orgao data"
      "situacao situacao";

    row-gap:8px;
    column-gap:10px;

    background:#fff;
    border:1px solid rgba(15,23,42,.10);
    border-radius:14px;
    padding:12px;
    margin:10px 0;
    box-shadow:0 6px 16px rgba(16,24,40,.06);
  }

  /* remove comportamento de tabela */
  #legCategoria .leg-table td{
    display:block;
    width:100%;
    padding:0 !important;
    border:0 !important;
    text-align:left !important;
  }

  /* ===============================
     POSICIONAMENTO GRID
     =============================== */
  #legCategoria .leg-td-norma{ grid-area:norma; }
  #legCategoria .leg-td-orgao{ grid-area:orgao; }
  #legCategoria .leg-td-data{ grid-area:data; }
  #legCategoria .leg-td-situacao{ grid-area:situacao; }

  /* ===============================
     NORMA (TÍTULO)
     =============================== */
  #legCategoria .leg-td-norma{
    line-height:1.25;
  }

  #legCategoria .leg-td-norma > a{
    display:block;
    font-size:14px;
    font-weight:850;
    color:var(--leg-ink);
  }

  #legCategoria .leg-td-norma .leg-norma-desc{
    margin-top:6px;
    font-size:12.5px;
    line-height:1.35;
    color:#6b7280;
  }

  #legCategoria .leg-td-norma .leg-norma-desc a{
    display:block;
    color:inherit;
  }

  /* ===============================
     ÓRGÃO
     =============================== */
  #legCategoria .leg-td-orgao{
    font-size:11.5px;
    font-weight:700;
    color:#667085;

    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  /* remove qualquer bolinha */
  #legCategoria .leg-td-orgao:after{
    content:"" !important;
  }

  /* ===============================
     DATA (ALINHADA PERFEITAMENTE)
     =============================== */
  #legCategoria .leg-td-data{
    font-size:11.5px;
    font-weight:700;
    color:#667085;

    text-align:right !important;
    justify-self:end; /* ESSENCIAL para alinhamento perfeito */
    white-space:nowrap;
  }

  /* remove qualquer float antigo */
  #legCategoria .leg-td-data{
    float:none !important;
  }

  /* ===============================
     SITUAÇÃO (BADGE)
     =============================== */
  #legCategoria .leg-td-situacao{
    margin-top:2px;
  }

  #legCategoria .leg-td-situacao .leg-badge{
    font-size:11px;
    padding:6px 10px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }

}

/* Ajuste leve tablet */
@media (max-width:1024px){
  #legCategoria .leg-td-orgao{
    font-size:12px;
  }
}

/* Centralizar o conteúdo da célula SITUAÇÃO (desktop/table) */
#legCategoria .leg-td-situacao{
  text-align:center;
  vertical-align:middle; /* ajuda no td */
}

/* O wrapper do status precisa centralizar */
#legCategoria .leg-td-situacao .leg-row__aside{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:34px; /* garante “miolo” central no row */
}

/* Badge lock: remove o empurrão pra cima e centraliza o svg */
#legCategoria .leg-badge.badge-lock{
  margin-top:0 !important;          /* remove o margin-top:2px do .leg-badge */
  height:26px;                      /* um pouco maior p/ ficar bonito */
  width:26px;                       /* deixa quadradinho (ícone central perfeito) */
  padding:0 !important;             /* não precisa padding quando é só ícone */
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

/* Tamanho do ícone */
#legCategoria .leg-badge.badge-lock .ico{
  width:16px;
  height:16px;
  display:block;
}

/* Centraliza o botão + Resultados dentro da tabela */
#legCategoria .leg-sub-more-search{
  text-align:center;
}

#legCategoria .leg-sub-more-search .leg-btn-more{
  margin: 0 auto;
}

@media (max-width: 820px){
  #legCategoria .leg-more-row{
    display:block !important; /* não virar card grid */
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    padding:0 !important;
    margin:10px 0 !important;
  }

  #legCategoria .leg-more-row td{
    display:block !important;
    padding:0 !important;
    border:0 !important;
  }

  #legCategoria .leg-sub-more-search{
    display:flex;
    justify-content:center;
  }
}
