/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: May 09 2026 | 14:51:38 */
/* ═══════════════════════════════════════════════════════════════
 *  cp-pages-decisoes-portais.css
 *  Hub do novo Explorador de Decisões — /decisoes-explorer-novo/.
 *  Tier A (HTML server-side) com 5 portas (cards) que apontam pra
 *  sub-páginas Tier C dedicadas.
 *  Helper: PageDecisoesExplorerHubHelper.
 *  Modulo JS: cp-mod-decisoes-portais.js.
 *  Identidade editorial: paleta jurídica + 1 cor por porta
 *  (burgundy/navy/sage/ochre/gold) + cream warm.
 *  Prefix: cp-dpo- (decisoes portais).
 * ═══════════════════════════════════════════════════════════════ */

:root {
  --cp-dpo-bg: #f5f1ea;
  --cp-dpo-surface: #ffffff;
  --cp-dpo-surface-elev: #fbf7ef;
  --cp-dpo-border: #e8e0d2;
  --cp-dpo-border-strong: #d4c9b5;
  --cp-dpo-text: #1a1a1a;
  --cp-dpo-text-muted: #6b6357;
  --cp-dpo-text-subtle: #9c9486;
  --cp-dpo-accent: #f7d44a;
  --cp-dpo-accent-dark: #1A1A1A;

  --cp-dpo-burgundy: #7A2E3A;
  --cp-dpo-burgundy-soft: #f3e3e6;
  --cp-dpo-burgundy-deep: #5C1F2A;
  --cp-dpo-navy: #1E3A5F;
  --cp-dpo-navy-soft: #e3e9f2;
  --cp-dpo-navy-deep: #122548;
  --cp-dpo-sage: #5F7A5C;
  --cp-dpo-sage-soft: #e7eee5;
  --cp-dpo-sage-deep: #44593F;
  --cp-dpo-ochre: #B85C38;
  --cp-dpo-ochre-soft: #f5e3d9;
  --cp-dpo-ochre-deep: #8C3F1F;
  --cp-dpo-gold: #A37717;
  --cp-dpo-gold-soft: #f9eccc;
  --cp-dpo-gold-deep: #6F4F0E;

  --cp-dpo-radius: 8px;
  --cp-dpo-shadow: 0 1px 2px rgba(0,0,0,0.04), 0 1px 1px rgba(0,0,0,0.06);
  --cp-dpo-shadow-elev: 0 8px 24px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.04);
  --cp-dpo-serif: "Source Serif Pro", "Charter", Georgia, serif;
  --cp-dpo-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --cp-dpo-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Consolas, monospace;
}

/* ── Hero ── */
.cp-dpo-hero {
  width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
  padding: 72px 32px 56px !important;
  text-align: center !important;
  background: linear-gradient(180deg, #fbf7ef 0%, #f5ecd9 100%) !important;
  border-bottom: 1px solid var(--cp-dpo-border) !important;
  position: relative !important;
  overflow: hidden !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.cp-dpo-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 30% 0%, rgba(247,212,74,0.18), transparent 60%),
    radial-gradient(ellipse at 70% 100%, rgba(122,46,58,0.06), transparent 60%);
  pointer-events: none;
}
.cp-dpo-hero-eyebrow {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
  color: var(--cp-dpo-burgundy) !important;
  margin-bottom: 16px !important;
  position: relative !important;
}
.cp-dpo-hero-eyebrow::before, .cp-dpo-hero-eyebrow::after {
  content: '';
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--cp-dpo-burgundy);
  vertical-align: middle;
  margin: 0 12px;
  opacity: 0.5;
}
.cp-dpo-hero-title {
  font-family: var(--cp-dpo-serif) !important;
  font-size: 44px !important;
  font-weight: 700 !important;
  color: var(--cp-dpo-text) !important;
  margin: 0 auto 14px !important;
  letter-spacing: -0.028em !important;
  line-height: 1.1 !important;
  position: relative !important;
}
.cp-dpo-hero-sub {
  font-size: 16px !important;
  color: var(--cp-dpo-text-muted) !important;
  margin: 0 auto !important;
  max-width: 580px !important;
  line-height: 1.55 !important;
  position: relative !important;
}
.cp-dpo-hero-stats {
  margin-top: 36px !important;
  display: inline-flex !important;
  gap: 32px !important;
  padding: 16px 32px !important;
  background: var(--cp-dpo-surface) !important;
  border: 1px solid var(--cp-dpo-border) !important;
  border-radius: var(--cp-dpo-radius) !important;
  box-shadow: var(--cp-dpo-shadow) !important;
  position: relative !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
}
.cp-dpo-hero-stat {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  align-items: center !important;
}
.cp-dpo-hero-stat-val {
  font-family: var(--cp-dpo-serif) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: -0.015em !important;
  color: var(--cp-dpo-text) !important;
}
.cp-dpo-hero-stats .cp-dpo-hero-stat:nth-child(1) .cp-dpo-hero-stat-val { color: var(--cp-dpo-burgundy) !important; }
.cp-dpo-hero-stats .cp-dpo-hero-stat:nth-child(2) .cp-dpo-hero-stat-val { color: var(--cp-dpo-navy) !important; }
.cp-dpo-hero-stats .cp-dpo-hero-stat:nth-child(3) .cp-dpo-hero-stat-val { color: var(--cp-dpo-sage) !important; }
.cp-dpo-hero-stats .cp-dpo-hero-stat:nth-child(4) .cp-dpo-hero-stat-val { color: var(--cp-dpo-ochre) !important; }
.cp-dpo-hero-stats .cp-dpo-hero-stat:nth-child(5) .cp-dpo-hero-stat-val { color: var(--cp-dpo-gold) !important; }
.cp-dpo-hero-stat-lab {
  font-size: 10px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: var(--cp-dpo-text-muted) !important;
}

/* ── Portais wrap ── */
.cp-dpo-portais-wrap {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 56px 32px 32px !important;
  background: var(--cp-dpo-bg) !important;
}
.cp-dpo-portais-head {
  text-align: center !important;
  margin-bottom: 32px !important;
}
.cp-dpo-portais-head h2 {
  font-family: var(--cp-dpo-serif) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  margin: 0 0 6px 0 !important;
  letter-spacing: -0.015em !important;
  color: var(--cp-dpo-text) !important;
}
.cp-dpo-portais-head p {
  font-size: 13px !important;
  color: var(--cp-dpo-text-muted) !important;
  margin: 0 !important;
}

/* ── Portais grid ── */
.cp-dpo-portais {
  display: grid !important;
  grid-template-columns: repeat(5, 1fr) !important;
  gap: 16px !important;
}

/* ── Portal card ── */
.cp-dpo-portal {
  --pcolor: var(--cp-dpo-accent-dark);
  --pcolor-soft: var(--cp-dpo-bg);
  background: var(--cp-dpo-surface) !important;
  border: 1px solid var(--cp-dpo-border) !important;
  border-radius: var(--cp-dpo-radius) !important;
  padding: 24px 20px 20px !important;
  text-decoration: none !important;
  color: inherit !important;
  display: flex !important;
  flex-direction: column !important;
  cursor: pointer !important;
  position: relative !important;
  overflow: hidden !important;
  transition: all 0.2s ease !important;
}
.cp-dpo-portal::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--pcolor);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.3s ease;
}
.cp-dpo-portal:hover {
  border-color: var(--pcolor) !important;
  box-shadow: 0 12px 28px rgba(0,0,0,0.06), 0 2px 8px rgba(0,0,0,0.04) !important;
  transform: translateY(-2px) !important;
  text-decoration: none !important;
  color: inherit !important;
}
.cp-dpo-portal:hover::before { transform: scaleX(1); }
.cp-dpo-portal-icon {
  width: 40px !important;
  height: 40px !important;
  border-radius: 4px !important;
  background: var(--pcolor-soft) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--pcolor) !important;
  margin-bottom: 16px !important;
}
.cp-dpo-portal-icon i { font-size: 17px !important; }
.cp-dpo-portal-name {
  font-family: var(--cp-dpo-serif) !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--cp-dpo-text) !important;
  margin: 0 0 6px 0 !important;
  letter-spacing: -0.012em !important;
}
.cp-dpo-portal-desc {
  font-size: 12px !important;
  color: var(--cp-dpo-text-muted) !important;
  line-height: 1.45 !important;
  margin: 0 0 18px 0 !important;
  flex: 1 !important;
}

/* Mini-thumb (mini-bars no rodapé do card) */
.cp-dpo-portal-thumb {
  height: 32px !important;
  display: flex !important;
  align-items: end !important;
  gap: 1px !important;
  margin-bottom: 12px !important;
}
.cp-dpo-portal-thumb span {
  flex: 1 !important;
  background: var(--pcolor) !important;
  opacity: 0.85 !important;
  border-radius: 1px 1px 0 0 !important;
  display: inline-block !important;
  min-height: 2px !important;
}

.cp-dpo-portal-stat {
  font-family: var(--cp-dpo-mono) !important;
  font-size: 11px !important;
  color: var(--cp-dpo-text-muted) !important;
  font-variant-numeric: tabular-nums !important;
  padding-top: 12px !important;
  border-top: 1px solid var(--cp-dpo-border) !important;
}
.cp-dpo-portal-stat strong {
  color: var(--pcolor) !important;
  font-weight: 700 !important;
}

/* Search input no portal Termo */
.cp-dpo-portal-search {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  height: 38px !important;
  padding: 0 12px !important;
  background: var(--cp-dpo-surface-elev) !important;
  border: 1px solid var(--cp-dpo-border) !important;
  border-radius: 4px !important;
  margin-bottom: 14px !important;
}
.cp-dpo-portal-search i {
  color: var(--cp-dpo-text-muted) !important;
  font-size: 12px !important;
}
.cp-dpo-portal-search input {
  border: none !important;
  background: transparent !important;
  outline: none !important;
  font-size: 12px !important;
  color: var(--cp-dpo-text) !important;
  flex: 1 !important;
  font-family: var(--cp-dpo-sans) !important;
}
.cp-dpo-portal-search input::placeholder {
  color: var(--cp-dpo-text-subtle) !important;
}

/* Cores por porta */
.cp-dpo-portal-ministro  { --pcolor: var(--cp-dpo-burgundy);  --pcolor-soft: var(--cp-dpo-burgundy-soft); }
.cp-dpo-portal-classe    { --pcolor: var(--cp-dpo-navy);      --pcolor-soft: var(--cp-dpo-navy-soft); }
.cp-dpo-portal-tempo     { --pcolor: var(--cp-dpo-sage);      --pcolor-soft: var(--cp-dpo-sage-soft); }
.cp-dpo-portal-colegiado { --pcolor: var(--cp-dpo-ochre);     --pcolor-soft: var(--cp-dpo-ochre-soft); }
.cp-dpo-portal-termo     { --pcolor: var(--cp-dpo-gold);      --pcolor-soft: var(--cp-dpo-gold-soft); }

/* Construction note (em desenvolvimento) */
.cp-dpo-construction-note {
  margin-top: 28px !important;
  padding: 12px 18px !important;
  background: var(--cp-dpo-surface-elev) !important;
  border: 1px dashed var(--cp-dpo-border-strong) !important;
  border-radius: var(--cp-dpo-radius) !important;
  font-size: 12px !important;
  color: var(--cp-dpo-text-muted) !important;
  text-align: center !important;
}

/* CTA pro Panorama */
.cp-dpo-panorama-cta {
  max-width: 1280px !important;
  margin: 32px auto 64px !important;
  padding: 28px 32px !important;
  background: linear-gradient(135deg, var(--cp-dpo-burgundy-deep) 0%, var(--cp-dpo-burgundy) 100%) !important;
  border-radius: var(--cp-dpo-radius) !important;
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  color: #fff !important;
  box-shadow: 0 4px 18px rgba(0,0,0,0.08) !important;
  flex-wrap: wrap !important;
}
.cp-dpo-panorama-cta-body {
  flex: 1 !important;
  min-width: 240px !important;
}
.cp-dpo-panorama-cta-eyebrow {
  font-family: var(--cp-dpo-mono) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: var(--cp-dpo-accent) !important;
  margin-bottom: 6px !important;
}
.cp-dpo-panorama-cta h2 {
  font-family: var(--cp-dpo-serif) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin: 0 0 6px 0 !important;
  letter-spacing: -0.015em !important;
}
.cp-dpo-panorama-cta p {
  font-size: 14px !important;
  color: rgba(255,255,255,0.85) !important;
  margin: 0 !important;
}
.cp-dpo-panorama-cta-btn {
  background: var(--cp-dpo-accent) !important;
  color: var(--cp-dpo-accent-dark) !important;
  border: none !important;
  padding: 12px 22px !important;
  border-radius: 4px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
  transition: transform 0.15s !important;
}
.cp-dpo-panorama-cta-btn:hover, a.cp-dpo-panorama-cta-btn:hover {
  transform: translateX(2px) !important;
  color: var(--cp-dpo-accent-dark) !important;
  text-decoration: none !important;
}

@media (max-width: 1024px) {
  .cp-dpo-portais { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 768px) {
  .cp-dpo-hero { padding: 56px 20px 40px !important; }
  .cp-dpo-hero-title { font-size: 32px !important; }
  .cp-dpo-hero-stats { gap: 18px !important; padding: 12px 20px !important; }
  .cp-dpo-portais { grid-template-columns: 1fr !important; }
  .cp-dpo-panorama-cta { flex-direction: column !important; text-align: center !important; }
}

/* ═══════════════════════════════════════════════════════════════
 *  PORTAS INDIVIDUAIS (Tier C)
 *  Cada porta herda --pcolor da classe modificadora
 *  (cp-dpo-porta-ministro, cp-dpo-porta-classe, etc).
 * ═══════════════════════════════════════════════════════════════ */

/* Cor por porta no header — pinta o bullet do título */
.cp-dpo-porta-ministro  { --pcolor: var(--cp-dpo-burgundy);  --pcolor-soft: var(--cp-dpo-burgundy-soft);  --pcolor-deep: var(--cp-dpo-burgundy-deep); }
.cp-dpo-porta-classe    { --pcolor: var(--cp-dpo-navy);      --pcolor-soft: var(--cp-dpo-navy-soft);      --pcolor-deep: var(--cp-dpo-navy-deep); }
.cp-dpo-porta-tempo     { --pcolor: var(--cp-dpo-sage);      --pcolor-soft: var(--cp-dpo-sage-soft);      --pcolor-deep: var(--cp-dpo-sage-deep); }
.cp-dpo-porta-colegiado { --pcolor: var(--cp-dpo-ochre);     --pcolor-soft: var(--cp-dpo-ochre-soft);     --pcolor-deep: var(--cp-dpo-ochre-deep); }
.cp-dpo-porta-termo     { --pcolor: var(--cp-dpo-gold);      --pcolor-soft: var(--cp-dpo-gold-soft);      --pcolor-deep: var(--cp-dpo-gold-deep); }

/* Header da porta */
.cp-dpo-porta-header {
  width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
  background: var(--cp-dpo-surface) !important;
  border-bottom: 1px solid var(--cp-dpo-border) !important;
  padding: 36px 32px 28px !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.cp-dpo-porta-header-inner {
  max-width: 1280px !important;
  margin: 0 auto !important;
}
.cp-dpo-porta-crumb {
  font-size: 12px !important;
  color: var(--cp-dpo-text-muted) !important;
  margin-bottom: 8px !important;
}
.cp-dpo-porta-crumb a {
  color: var(--cp-dpo-text-muted) !important;
  text-decoration: none !important;
}
.cp-dpo-porta-crumb a:hover {
  color: var(--pcolor) !important;
  text-decoration: underline !important;
}
.cp-dpo-porta-crumb-sep {
  margin: 0 6px !important;
  color: var(--cp-dpo-text-subtle) !important;
}
.cp-dpo-porta-title {
  font-family: var(--cp-dpo-serif) !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  color: var(--pcolor-deep) !important;
  margin: 0 0 6px 0 !important;
  letter-spacing: -0.022em !important;
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 12px !important;
}
.cp-dpo-porta-title-bullet {
  display: inline-block !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: var(--pcolor) !important;
  align-self: center !important;
}
.cp-dpo-porta-deck {
  font-size: 14px !important;
  color: var(--cp-dpo-text-muted) !important;
  margin: 0 !important;
  max-width: 640px !important;
}

/* Wrapper externo do conteúdo */
.cp-dpo-porta-controls,
.cp-dpo-porta-grid {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 32px !important;
}

/* Sub-header com summary + toggle */
.cp-dpo-porta-controls {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding-top: 18px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--cp-dpo-border) !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
}
.cp-dpo-porta-summary {
  font-family: var(--cp-dpo-mono) !important;
  font-size: 12px !important;
  color: var(--cp-dpo-text-muted) !important;
  font-variant-numeric: tabular-nums !important;
}
.cp-dpo-porta-summary strong {
  color: var(--pcolor) !important;
  font-weight: 700 !important;
}

/* Scope toggle inline (espelha padrao do Panorama) */
.cp-dpo-scope {
  display: inline-flex !important;
  background: var(--cp-dpo-bg) !important;
  border: 1px solid var(--cp-dpo-border) !important;
  border-radius: 4px !important;
  padding: 2px !important;
  flex-shrink: 0 !important;
}
.cp-dpo-scope-btn {
  background: transparent !important;
  border: none !important;
  padding: 4px 10px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--cp-dpo-text-muted) !important;
  cursor: pointer !important;
  border-radius: 3px !important;
  font-family: var(--cp-dpo-sans) !important;
  letter-spacing: 0 !important;
  transition: all 0.15s !important;
  white-space: nowrap !important;
}
.cp-dpo-scope-btn:hover { color: var(--cp-dpo-text) !important; }
.cp-dpo-scope-btn.cp-dpo-scope-active {
  color: #fff !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.08) !important;
}
.cp-dpo-scope-btn[data-scope="crim"].cp-dpo-scope-active { background: var(--pcolor) !important; }
.cp-dpo-scope-btn[data-scope="all"].cp-dpo-scope-active { background: var(--cp-dpo-text) !important; }

/* Grid: lista + detalhe */
.cp-dpo-porta-grid {
  display: grid !important;
  grid-template-columns: 320px 1fr !important;
  gap: 20px !important;
  padding-top: 24px !important;
  padding-bottom: 80px !important;
  align-items: start !important;
}

/* Lista navegável */
.cp-dpo-porta-list {
  background: var(--cp-dpo-surface) !important;
  border: 1px solid var(--cp-dpo-border) !important;
  border-radius: var(--cp-dpo-radius) !important;
  padding: 12px !important;
  position: sticky !important;
  top: 16px !important;
  max-height: calc(100vh - 32px) !important;
  display: flex !important;
  flex-direction: column !important;
}
.cp-dpo-porta-list-search {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 36px !important;
  padding: 0 12px !important;
  background: var(--cp-dpo-surface-elev) !important;
  border: 1px solid var(--cp-dpo-border) !important;
  border-radius: 4px !important;
  margin-bottom: 8px !important;
  flex-shrink: 0 !important;
}
.cp-dpo-porta-list-search i {
  color: var(--cp-dpo-text-muted) !important;
  font-size: 12px !important;
}
.cp-dpo-porta-list-search input {
  border: none !important;
  background: transparent !important;
  outline: none !important;
  font-size: 13px !important;
  color: var(--cp-dpo-text) !important;
  flex: 1 !important;
  font-family: var(--cp-dpo-sans) !important;
}
.cp-dpo-porta-list-items {
  overflow-y: auto !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 1px !important;
  padding-right: 2px !important;
}
.cp-dpo-porta-list-item {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 8px 10px !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  font-size: 13px !important;
  color: var(--cp-dpo-text) !important;
  transition: background 0.1s !important;
  border: none !important;
  background: transparent !important;
  text-align: left !important;
  font-family: var(--cp-dpo-sans) !important;
}
.cp-dpo-porta-list-item:hover { background: var(--cp-dpo-surface-elev) !important; }
.cp-dpo-porta-list-item.cp-dpo-active {
  background: var(--pcolor) !important;
  color: #fff !important;
}
.cp-dpo-porta-list-item.cp-dpo-active .cp-dpo-porta-list-item-count {
  color: var(--cp-dpo-accent) !important;
}
.cp-dpo-porta-list-item-name { flex: 1 !important; }
.cp-dpo-porta-list-item-count {
  font-family: var(--cp-dpo-mono) !important;
  font-size: 11px !important;
  color: var(--cp-dpo-text-muted) !important;
  font-variant-numeric: tabular-nums !important;
  white-space: nowrap !important;
}

/* Detail panel */
.cp-dpo-porta-detail {
  background: var(--cp-dpo-surface) !important;
  border: 1px solid var(--cp-dpo-border) !important;
  border-radius: var(--cp-dpo-radius) !important;
  padding: 28px !important;
  box-shadow: var(--cp-dpo-shadow) !important;
  min-height: 540px !important;
}
.cp-dpo-porta-detail-empty {
  text-align: center !important;
  padding: 80px 20px !important;
  color: var(--cp-dpo-text-subtle) !important;
}
.cp-dpo-porta-detail-empty i {
  font-size: 48px !important;
  color: var(--cp-dpo-border-strong) !important;
  margin-bottom: 16px !important;
  display: block !important;
}
.cp-dpo-porta-detail-empty p {
  margin: 0 !important;
  font-size: 14px !important;
}
.cp-dpo-porta-detail-head {
  display: flex !important;
  align-items: baseline !important;
  gap: 14px !important;
  padding-bottom: 18px !important;
  border-bottom: 1px solid var(--cp-dpo-border) !important;
  margin-bottom: 24px !important;
  flex-wrap: wrap !important;
}
.cp-dpo-porta-detail-name {
  font-family: var(--cp-dpo-serif) !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  color: var(--pcolor-deep) !important;
  margin: 0 !important;
  letter-spacing: -0.018em !important;
}
.cp-dpo-porta-detail-tag {
  font-size: 11px !important;
  padding: 3px 10px !important;
  border-radius: 10px !important;
  background: var(--pcolor-soft) !important;
  color: var(--pcolor) !important;
  font-weight: 600 !important;
}

/* KPIs grid */
.cp-dpo-porta-kpis {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 14px !important;
  margin-bottom: 28px !important;
}
.cp-dpo-porta-kpi {
  padding: 14px 16px !important;
  background: var(--cp-dpo-surface-elev) !important;
  border: 1px solid var(--cp-dpo-border) !important;
  border-left: 3px solid var(--pcolor) !important;
  border-radius: 4px !important;
}
.cp-dpo-porta-kpi-lab {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--cp-dpo-text-muted) !important;
  margin-bottom: 6px !important;
}
.cp-dpo-porta-kpi-val {
  font-family: var(--cp-dpo-serif) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: -0.015em !important;
  color: var(--pcolor-deep) !important;
}
.cp-dpo-porta-kpi-val .cp-dpo-unit {
  font-size: 14px !important;
  color: var(--cp-dpo-text-muted) !important;
  margin-left: 2px !important;
  font-weight: 500 !important;
}

/* Sections de viz no detail */
.cp-dpo-porta-section {
  margin-bottom: 28px !important;
}
.cp-dpo-porta-section h4 {
  font-family: var(--cp-dpo-serif) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  color: var(--cp-dpo-text) !important;
  margin: 0 0 12px 0 !important;
}
.cp-dpo-porta-chart {
  height: 260px !important;
  position: relative !important;
}
.cp-dpo-porta-chart-tall {
  height: 320px !important;
}

/* Tags de colegiado no detail */
.cp-dpo-porta-colegiados {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}
.cp-dpo-porta-colegiados-tag {
  font-size: 11px !important;
  font-weight: 600 !important;
  padding: 4px 10px !important;
  border-radius: 12px !important;
  background: var(--pcolor-soft) !important;
  color: var(--pcolor) !important;
}

@media (max-width: 1024px) {
  .cp-dpo-porta-grid { grid-template-columns: 1fr !important; }
  .cp-dpo-porta-list { position: static !important; max-height: 280px !important; }
  .cp-dpo-porta-kpis { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 768px) {
  .cp-dpo-porta-header { padding: 28px 20px 20px !important; }
  .cp-dpo-porta-title { font-size: 26px !important; }
  .cp-dpo-porta-controls,
  .cp-dpo-porta-grid { padding: 0 20px !important; }
  .cp-dpo-porta-detail { padding: 20px !important; }
  .cp-dpo-porta-kpis { grid-template-columns: 1fr !important; }
}

/* ═══════════════════════════════════════════════════════════════
 *  LOADING STATES — Portas Tier C
 *  Aplicados durante refetch (clique em outro item da lista,
 *  troca de toggle, etc). Cache cliente (Map em JS) elimina
 *  o fetch quando se revisita um item ja carregado.
 * ═══════════════════════════════════════════════════════════════ */

/* Skeleton pulse animation — barras que indicam "carregando" */
@keyframes cpDpoSkelPulse {
  0%   { background-color: #ece6db; }
  50%  { background-color: #d8cfbc; }
  100% { background-color: #ece6db; }
}

.cp-dpo-skel-text {
  display: inline-block !important;
  height: 1em !important;
  border-radius: 3px !important;
  background-color: #ece6db !important;
  animation: cpDpoSkelPulse 1.4s ease-in-out infinite !important;
  color: transparent !important;
  user-select: none !important;
}
.cp-dpo-porta-detail-name.cp-dpo-skel-text {
  height: 28px !important;
  vertical-align: middle !important;
}
.cp-dpo-porta-kpi-val.cp-dpo-skel-text {
  height: 22px !important;
  margin-top: 2px !important;
}

.cp-dpo-skel-block {
  background-color: #ece6db !important;
  border-radius: 4px !important;
  animation: cpDpoSkelPulse 1.4s ease-in-out infinite !important;
}

/* Item placeholder na sidebar durante carga inicial */
.cp-dpo-porta-list-item-skel {
  padding: 9px 10px !important;
  border-radius: 4px !important;
  display: block !important;
}

/* Item da lista em estado loading — spinner inline + sutil opacity */
.cp-dpo-porta-list-item.cp-dpo-item-loading {
  position: relative !important;
}
.cp-dpo-porta-list-item.cp-dpo-item-loading .cp-dpo-porta-list-item-count {
  visibility: hidden !important;
}
.cp-dpo-porta-list-item.cp-dpo-item-loading::after {
  content: '';
  position: absolute;
  right: 12px;
  top: 50%;
  width: 12px;
  height: 12px;
  margin-top: -6px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  opacity: 0.6;
  animation: cpDpoSpin 0.7s linear infinite;
}
@keyframes cpDpoSpin {
  to { transform: rotate(360deg); }
}

/* Toggle scope durante loading: cursor + opacity sutil */
.cp-dpo-scope.cp-dpo-loading {
  opacity: 0.7 !important;
  pointer-events: none !important;
}
