* {
  box-sizing: border-box;
  margin: 0;
  padding: 0
}

:root {
  --accent: #256551;
  --accent2: #2d7a62;
  --accent-soft: #e8f5f1;
  --ink: #111318;
  --ink2: #3D4452;
  --ink3: #8A93A6;
  --ink4: #B8BFCC;
  --bg: #F2F4F7;
  --bg2: #FFFFFF;
  --bg3: #F7F9FC;
  --border: #E8ECF2;
  --border2: #D4DAE4;
  --green: #10B981;
  --green-s: #ECFDF5;
  --blue: #3B82F6;
  --blue-s: #EFF6FF;
  --amber: #F59E0B;
  --amber-s: #FFFBEB;
  --r: 10px;
  --r2: 14px;
  --r3: 18px;
  --sh: 0 1px 3px rgba(0, 0, 0, .06), 0 4px 16px rgba(0, 0, 0, .06);
  --sh2: 0 2px 8px rgba(0, 0, 0, .08), 0 8px 32px rgba(0, 0, 0, .08);
}

body {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.5;
  min-height: 100vh;
  overflow-x: hidden
}

button {
  font-family: 'Inter', sans-serif;
  cursor: pointer
}

input,
select {
  font-family: 'Inter', sans-serif
}

/* ── TOPBAR ── */
.topbar {
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  height: 62px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 24px;
  gap: 0;
  position: sticky;
  top: 0;
  z-index: 300;
  position: sticky
}

.topbar-logo {
  position: absolute;
  left: 24px;
  display: flex;
  align-items: center;
  gap: 12px
}

.topbar-logo img {
  height: 40px;
  width: auto;
  object-fit: contain
}

.topbar-title-wrap {
  display: flex;
  flex-direction: column;
  gap: 1px;
  text-align: center
}

.topbar-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.3px;
  line-height: 1.2
}

.topbar-subtitle {
  font-size: 11px;
  font-weight: 500;
  color: var(--ink3);
  letter-spacing: .02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%
}

.logo-circle {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: grid;
  place-items: center
}

.logo-circle svg {
  width: 16px;
  height: 16px;
  fill: #fff
}

.logo-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.2px
}

/* ── FOOTER ── */
.site-footer {
  background: var(--bg2);
  border-top: 1px solid var(--border);
  padding: 14px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  position: static;
  margin-top: 24px;
  z-index: 200
}

.footer-left {
  flex-shrink: 0
}

.footer-left img {
  height: 34px;
  width: auto;
  object-fit: contain
}

.footer-info {
  flex: 1;
  font-size: 12px;
  color: var(--ink3);
  line-height: 1.5;
  text-align: center
}

.footer-right {
  display: flex;
  align-items: center;
  gap: 12px
}

.footer-btn {
  padding: 8px 18px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  transition: opacity .15s
}

.footer-btn:hover {
  opacity: .85
}

/* ── TAB BAR ── */
.tab-bar {
  background: var(--bg2);
  border-bottom: 2px solid var(--border);
  display: flex;
  align-items: flex-end;
  padding: 0 24px;
  gap: 0;
  position: sticky;
  top: 62px;
  z-index: 299
}

.tnav-btn {
  position: relative;
  font-size: 13px;
  font-weight: 500;
  padding: 10px 16px;
  border: none;
  background: transparent;
  color: var(--ink3);
  transition: color .15s;
  cursor: pointer;
  white-space: nowrap
}

.tnav-btn::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--accent);
  border-radius: 2px 2px 0 0;
  transform: scaleX(0);
  transition: transform .2s
}

.tnav-btn:hover {
  color: var(--ink)
}

.tnav-btn.active {
  color: var(--accent);
  font-weight: 600
}

.tnav-btn.active::after {
  transform: scaleX(1)
}

.topbar-right {
  position: absolute;
  right: 24px;
  display: flex;
  align-items: center;
  gap: 10px
}

.icon-btn {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: transparent;
  display: grid;
  place-items: center;
  color: var(--ink3);
  font-size: 15px
}

.icon-btn:hover {
  background: var(--bg3)
}

.avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #667EEA, #764BA2);
  display: grid;
  place-items: center;
  font-size: 12px;
  font-weight: 600;
  color: #fff
}

/* ── LAYOUT ── */
.layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 0;
  min-height: calc(100vh - 108px - 58px);
  height: auto;
  overflow: visible;
  align-items: start
}

.main-scroll {
  overflow: visible;
  padding: 20px 24px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 16px
}

.right-panel {
  border-right: 1px solid var(--border);
  border-left: none;
  background: var(--bg2);
  overflow: visible;
  padding: 20px 18px;
  display: flex;
  flex-direction: column;
  gap: 16px
}

/* ── TAB CONTENT ── */
.page-view {
  display: none;
  min-height: calc(100vh - 108px - 58px);
  height: auto;
  overflow: visible;
  animation: fadeIn .18s ease
}

.page-view.active {
  display: block
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(4px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.vg-wrap {
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px
}

.exec-page-wrap {
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px
}

/* ── CARDS ── */
.card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  box-shadow: var(--sh)
}

.card-head {
  padding: 16px 18px 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start
}

.card-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink)
}

.card-sub {
  font-size: 11px;
  color: var(--ink3);
  margin-top: 1px
}

.card-arrow {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: transparent;
  display: grid;
  place-items: center;
  color: var(--ink3);
  font-size: 13px
}

.card-arrow:hover {
  background: var(--bg3)
}

/* ── MÉTRICAS ── */
.metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px
}

.mcard {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 14px 16px;
  box-shadow: var(--sh);
  position: relative;
  overflow: hidden
}

.mcard::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: var(--r2) var(--r2) 0 0
}

.mcard.c-green::after {
  background: var(--green)
}

.mcard.c-blue::after {
  background: var(--blue)
}

.mcard.c-accent::after {
  background: var(--accent)
}

.mcard.c-amber::after {
  background: var(--amber)
}

.mc-lbl {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 8px
}

.mc-val {
  font-size: 19px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.5px
}

.mc-sub {
  font-size: 10px;
  color: var(--ink3);
  margin-top: 3px;
  display: flex;
  align-items: center;
  gap: 4px
}

.mc-badge {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 20px
}

.mc-badge.up {
  background: var(--green-s);
  color: var(--green)
}

.mc-badge.dn {
  background: #FEF2F2;
  color: #DC2626
}

/* ── CHART ÁREA ── */
.chart-wrap {
  padding: 14px 18px 18px
}

.chart-legend {
  display: flex;
  gap: 14px;
  margin-bottom: 12px
}

.leg-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 500;
  color: var(--ink3)
}

.leg-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%
}

.chart-canvas-wrap {
  position: relative;
  height: 210px
}

.chart-footer {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--border)
}

.cf-item {
  display: flex;
  flex-direction: column;
  gap: 2px
}

.cf-lbl {
  font-size: 10px;
  color: var(--ink3);
  font-weight: 500
}

.cf-val {
  font-size: 13px;
  font-weight: 600
}

.cf-val.reached {
  color: var(--green)
}

.cf-val.dropped {
  color: var(--accent)
}

/* ── TABELA ── */
.tbl-header {
  padding: 12px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
  gap: 8px
}

.tbl-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--ink);
  margin-top: 2px
}

.tbl-search {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0 14px;
  min-width: 340px;
  transition: border-color .15s
}

.tbl-search:focus-within {
  border-color: var(--accent);
  background: #fff
}

.tbl-search input {
  border: none;
  background: transparent;
  outline: none;
  font-size: 14px;
  color: var(--ink);
  width: 100%;
  height: 42px;
  font-family: 'Inter', sans-serif
}

.tbl-search input::placeholder {
  color: var(--ink3)
}

.tbl-search-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tbl-actions {
  display: flex;
  gap: 6px
}

.btn-sm {
  font-size: 11px;
  font-weight: 500;
  padding: 5px 10px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--ink2)
}

.btn-sm:hover {
  background: var(--bg3)
}

.btn-sm.accent {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent)
}

.tbl-scroll {
  overflow-x: auto
}

.emendas-page {
  padding: 28px 24px 36px;
  display: flex;
  flex-direction: column;
  gap: 20px
}

.emendas-search-card,
.emendas-list-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: var(--sh);
  overflow: hidden
}

.emendas-search-card {
  padding: 22px 24px 24px;
  background:
    radial-gradient(circle at top right, rgba(37, 101, 81, .08), transparent 34%),
    linear-gradient(180deg, #FFFFFF 0%, #FBFCFE 100%)
}

.emendas-card-top {
  display: block;
  margin-bottom: 18px
}

.emendas-kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px
}

.emendas-card-title {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -.03em;
  color: var(--ink);
  line-height: 1.15
}

.emendas-card-sub {
  max-width: 640px;
  margin-top: 6px;
  font-size: 12px;
  color: var(--ink3);
  line-height: 1.5
}

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

.emendas-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0
}

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

.emendas-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink2)
}

.emendas-input,
.emendas-select {
  width: 100%;
  height: 40px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: rgba(255, 255, 255, .92);
  padding: 0 14px;
  font-size: 13px;
  color: var(--ink);
  outline: none;
  font-family: 'Inter', sans-serif;
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
  box-shadow: inset 0 1px 2px rgba(17, 19, 24, .03)
}

.emendas-input:focus,
.emendas-select:focus {
  border-color: rgba(37, 101, 81, .45);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(37, 101, 81, .08)
}

.emendas-search-actions {
  margin-top: 16px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap
}

.emendas-clear-btn,
.emendas-search-btn {
  height: 40px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease, color .16s ease
}

.emendas-clear-btn {
  min-width: 128px;
  border: 1px solid var(--border2);
  background: #fff;
  color: var(--ink2)
}

.emendas-search-btn {
  min-width: 138px;
  border: none;
  padding: 0 20px;
  background: var(--accent);
  color: #fff;
  box-shadow: 0 8px 20px rgba(37, 101, 81, .18)
}

.emendas-clear-btn:hover,
.emendas-search-btn:hover,
.emendas-detail-btn:hover,
.emendas-link-btn:hover {
  transform: translateY(-1px)
}

.emendas-clear-btn:hover {
  border-color: rgba(37, 101, 81, .32);
  color: var(--accent)
}

.emendas-results-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--bg3);
  border: 1px solid var(--border);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink2)
}

.emendas-list-toolbar {
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  background: linear-gradient(180deg, #FFFFFF 0%, #FAFBFD 100%)
}

.emendas-list-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--ink)
}

.emendas-list-sub {
  margin-top: 4px;
  font-size: 12px;
  color: var(--ink3)
}

.emendas-list-head,
.emendas-row {
  display: grid;
  grid-template-columns: 1.2fr .8fr .95fr 1.3fr 1.45fr 1.35fr .65fr 1fr .85fr;
  gap: 16px;
  align-items: center
}

.emendas-list-head {
  padding: 16px 18px;
  border-bottom: 1px solid var(--border);
  background: #FCFDFE;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 11px;
  font-weight: 700;
  color: var(--ink3)
}

.emendas-row-wrap {
  border-bottom: 1px solid var(--border);
  transition: background .18s ease, box-shadow .18s ease
}

.emendas-row-wrap:last-child {
  border-bottom: none
}

.emendas-row-wrap.open {
  background: linear-gradient(180deg, rgba(232, 245, 241, .82) 0%, rgba(247, 251, 249, .98) 100%);
  box-shadow: inset 0 0 0 1px rgba(37, 101, 81, .08)
}

.emendas-row {
  padding: 14px 18px;
  min-height: 68px;
  cursor: pointer;
  transition: background .16s ease, transform .16s ease, box-shadow .16s ease
}

.emendas-row:hover {
  background: #F6FAF8;
  transform: translateY(-1px);
  box-shadow: inset 0 0 0 1px rgba(37, 101, 81, .08)
}

.emendas-cell {
  min-width: 0;
  color: var(--ink2);
  font-size: 14px;
  position: relative
}

.emendas-row>.emendas-cell:not(:first-child)::before {
  content: '';
  position: absolute;
  left: -8px;
  top: 50%;
  width: 1px;
  height: 28px;
  transform: translateY(-50%);
  background: linear-gradient(180deg, transparent 0%, var(--border) 18%, var(--border) 82%, transparent 100%)
}

.emendas-code,
.emendas-value {
  font-weight: 700;
}

.emendas-code {
  color: var(--ink)
}

.emendas-value {
  color: var(--green);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--green-s);
  white-space: nowrap
}

.emendas-code-link {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .16s ease, color .16s ease
}

.emendas-code-link:hover {
  color: var(--accent2);
  border-color: rgba(37, 101, 81, .28)
}

.emendas-author,
.emendas-local {
  line-height: 1.35
}

.emendas-inst-main {
  font-weight: 600;
  color: var(--ink2)
}

.emendas-inst-sub {
  margin-top: 2px;
  font-size: 11px;
  color: var(--ink3)
}

.emendas-year {
  font-weight: 500;
  color: var(--ink2)
}

.emendas-esfera-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0
}

.emendas-esfera-badge.b-fed {
  background: var(--accent-soft);
  color: var(--accent)
}

.emendas-esfera-badge.b-est {
  background: var(--blue-s);
  color: var(--blue)
}

.emendas-esfera-badge.b-mun {
  background: var(--amber-s);
  color: #B45309
}

.emendas-action {
  display: flex;
  justify-content: flex-end
}

.emendas-detail-btn,
.emendas-link-btn {
  height: 34px;
  border-radius: 9px;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 600
}

.emendas-detail-btn {
  min-width: 104px;
  border: 1px solid var(--border2);
  background: #fff;
  color: var(--ink2)
}

.emendas-link-btn {
  border: none;
  padding: 0 14px;
  background: var(--accent);
  color: #fff;
  box-shadow: 0 8px 18px rgba(37, 101, 81, .16)
}

.emendas-dropdown {
  padding: 0 18px 18px
}

.emendas-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  background: linear-gradient(180deg, #F8FAFC 0%, #FDFEFE 100%);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px
}

.emendas-inline-panel {
  display: flex;
  flex-direction: column;
  gap: 14px
}

.emendas-summary-item {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px 14px;
  min-width: 0
}

.emendas-summary-k {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--ink3);
  margin-bottom: 6px
}

.emendas-summary-v {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink2);
  line-height: 1.35
}

.emendas-summary-item-exec .emendas-summary-k,
.emendas-summary-item.money.emp .emendas-summary-k {
  color: var(--accent)
}

.emendas-summary-item.money.liq .emendas-summary-k {
  color: var(--blue)
}

.emendas-summary-item.money.pag .emendas-summary-k {
  color: var(--green)
}

.emendas-summary-item.money.rp .emendas-summary-k {
  color: var(--amber)
}

.emendas-summary-item-exec .emendas-summary-v,
.emendas-summary-item.money.emp .emendas-summary-v {
  color: var(--accent)
}

.emendas-summary-item.money.liq .emendas-summary-v {
  color: var(--blue)
}

.emendas-summary-item.money.pag .emendas-summary-v {
  color: var(--green)
}

.emendas-summary-item.money.rp .emendas-summary-v {
  color: var(--amber)
}

.emendas-inline-detail {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: linear-gradient(180deg, #FBFCFE 0%, #FFFFFF 100%);
  overflow: hidden
}

.emendas-inline-detail-head {
  padding: 14px 16px 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent)
}

.emendas-inline-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 12px 16px 16px
}

.emendas-inline-field {
  background: #F7F9FC;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  min-width: 0
}

.emendas-inline-field-full {
  grid-column: 1 / -1
}

.emendas-inline-k {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 6px
}

.emendas-inline-v {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.45
}

.emendas-dropdown-actions {
  margin-top: 12px;
  display: flex;
  justify-content: flex-end
}

.emendas-empty {
  padding: 30px 18px;
  text-align: center;
  color: var(--ink3)
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px
}

thead tr {
  border-bottom: 1px solid var(--border)
}

th {
  padding: 9px 12px;
  text-align: left;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--ink3);
  white-space: nowrap;
  cursor: pointer;
  user-select: none
}

th:hover {
  color: var(--ink)
}

td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle
}

tr:last-child td {
  border-bottom: none
}

tr:hover td {
  background: var(--bg3)
}

.td-no {
  font-size: 11px;
  color: var(--ink3);
  font-weight: 500
}

.td-name {
  display: flex;
  align-items: center;
  gap: 8px
}

.td-avatar {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0
}

.td-autor {
  font-weight: 600;
  font-size: 12px;
  color: var(--ink)
}

.td-uf {
  font-size: 10px;
  color: var(--ink3)
}

.flag {
  width: 18px;
  height: 13px;
  border-radius: 2px;
  object-fit: cover
}

.device-icon {
  font-size: 14px
}

.td-val {
  font-weight: 700;
  font-size: 12px;
  color: var(--ink)
}

.td-date {
  font-size: 11px;
  color: var(--ink3)
}

.td-time {
  font-size: 11px;
  color: var(--ink3)
}

.badge-sm {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px
}

.b-ind {
  background: #F3F0FF;
  color: #6D28D9
}

.b-ban {
  background: #ECFDF5;
  color: #065F46
}

.b-com {
  background: #FEF3C7;
  color: #92400E
}

.b-rel {
  background: #FFF1F2;
  color: #9F1239
}

.b-fed {
  background: var(--accent-soft);
  color: var(--accent)
}

.b-est {
  background: var(--blue-s);
  color: var(--blue)
}

.b-mun {
  background: var(--amber-s);
  color: #B45309
}

.btn-det {
  font-size: 10px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--ink3)
}

.btn-det:hover {
  border-color: var(--accent);
  color: var(--accent)
}

.pag {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 12px;
  border-top: 1px solid var(--border)
}

.pag-btn {
  font-size: 11px;
  padding: 5px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--ink2)
}

.pag-btn:hover:not(:disabled) {
  background: var(--bg3)
}

.pag-btn:disabled {
  opacity: .35;
  cursor: default
}

.pag-info {
  font-size: 11px;
  color: var(--ink3);
  padding: 0 6px
}

/* ── RIGHT PANEL ── */
.rp-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 2px
}

.rp-sub {
  font-size: 11px;
  color: var(--ink3)
}

.rp-card {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 14px 14px
}

.rp-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px
}

/* Tipo bar */
.tipo-bar-wrap {
  margin-bottom: 10px
}

.tipo-bar-track {
  height: 10px;
  border-radius: 5px;
  background: var(--border);
  overflow: hidden;
  display: flex;
  gap: 2px;
  margin: 10px 0 8px
}

.tipo-seg {
  height: 100%;
  border-radius: 3px;
  transition: width .5s
}

.tipo-legend {
  display: flex;
  flex-direction: column;
  gap: 6px
}

.tipo-leg-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px
}

.tipo-leg-left {
  display: flex;
  align-items: center;
  gap: 7px;
  color: var(--ink2);
  font-weight: 500
}

.tipo-leg-dot {
  width: 8px;
  height: 8px;
  border-radius: 2px;
  flex-shrink: 0
}

.tipo-leg-pct {
  font-weight: 700;
  color: var(--ink)
}

/* Mapa mini */
.map-mini-wrap {
  position: relative
}

#mini-svg {
  width: 100%;
  height: auto;
  display: block
}

.map-mini-legend {
  display: flex;
  gap: 4px;
  margin-top: 8px;
  flex-wrap: wrap
}

.ml-item {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  color: var(--ink3)
}

.ml-sq {
  width: 10px;
  height: 10px;
  border-radius: 2px
}

/* Ranking */
.rank-list {
  display: flex;
  flex-direction: column;
  gap: 4px
}

.rank-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 0;
  border-bottom: 1px solid var(--border)
}

.rank-row:last-child {
  border-bottom: none
}

.rank-num {
  font-size: 10px;
  font-weight: 700;
  color: var(--ink4);
  width: 16px;
  text-align: right;
  flex-shrink: 0
}

.rank-info {
  flex: 1;
  min-width: 0
}

.rank-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis
}

.rank-meta {
  font-size: 10px;
  color: var(--ink3);
  margin-top: 1px
}

.rank-track {
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  margin-top: 4px;
  overflow: hidden
}

.rank-fill {
  height: 3px;
  border-radius: 2px;
  background: var(--accent)
}

.rank-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 20px;
  background: var(--accent-soft);
  color: var(--accent);
  white-space: nowrap
}

/* Execução donut */
.donut-wrap {
  display: flex;
  align-items: center;
  gap: 14px
}

.donut-chart {
  position: relative;
  width: 90px;
  height: 90px;
  flex-shrink: 0
}

.donut-canvas {
  width: 90px;
  height: 90px
}

.donut-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center
}

.donut-pct {
  font-size: 16px;
  font-weight: 700;
  color: var(--ink)
}

.donut-lbl {
  font-size: 9px;
  color: var(--ink3);
  font-weight: 500
}

.donut-legend {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1
}

.dl-row {
  display: flex;
  align-items: flex-start;
  font-size: 11px
}

.dl-left {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  color: var(--ink2)
}

.dl-text {
  display: flex;
  flex-direction: column;
  gap: 2px
}

.dl-lbl {
  line-height: 1.2
}

.dl-sq {
  width: 8px;
  height: 8px;
  border-radius: 2px
}

.dl-val {
  font-weight: 700;
  color: var(--ink);
  line-height: 1.2
}

/* Filtros rápidos */
.filt-grid {
  display: flex;
  flex-direction: column;
  gap: 6px
}

.filt-row {
  display: flex;
  gap: 6px
}

.filt-btn {
  flex: 1;
  font-size: 12px;
  font-weight: 500;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--bg2);
  color: var(--ink2);
  text-align: center;
  transition: all .15s
}

.filt-btn:hover {
  border-color: var(--accent);
  color: var(--accent)
}

.filt-btn.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent)
}

.filt-select {
  width: 100%;
  height: 36px;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0 12px;
  font-size: 13px;
  background: var(--bg2);
  color: var(--ink);
  outline: none;
  white-space: nowrap
}

.filt-select:focus {
  border-color: var(--accent)
}

.detail-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .4);
  z-index: 500;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px
}

.detail-overlay.open {
  display: flex
}

.detail-box {
  background: var(--bg2);
  border-radius: var(--r3);
  box-shadow: var(--sh2);
  padding: 24px;
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  overflow-y: auto
}

.db-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--border)
}

.db-sec {
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border)
}

.db-sec:last-child {
  border-bottom: none;
  margin-bottom: 0
}

.db-sec-lbl {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px
}

.db-row2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 8px
}

.dbf {
  background: var(--bg3);
  border-radius: var(--r);
  padding: 9px 11px;
  margin-bottom: 8px
}

.dbf:last-child {
  margin-bottom: 0
}

.dbf-k {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 2px
}

.dbf-v {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink)
}

.db-money {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 14px
}

.dbm {
  padding: 12px 14px;
  border-radius: var(--r2)
}

.dbm.emp {
  background: var(--accent-soft)
}

.dbm.liq {
  background: var(--blue-s)
}

.dbm.pag {
  background: var(--green-s)
}

.dbm-k {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 3px
}

.dbm.emp .dbm-k {
  color: var(--accent)
}

.dbm.liq .dbm-k {
  color: var(--blue)
}

.dbm.pag .dbm-k {
  color: var(--green)
}

.dbm-v {
  font-size: 13px;
  font-weight: 700
}

.dbm.emp .dbm-v {
  color: var(--accent)
}

.dbm.liq .dbm-v {
  color: var(--blue)
}

.dbm.pag .dbm-v {
  color: var(--green)
}

.exec-row {
  margin-bottom: 8px
}

.exec-lbl {
  font-size: 11px;
  color: var(--ink3);
  margin-bottom: 5px;
  font-weight: 500
}

.exec-bar {
  height: 6px;
  background: var(--bg);
  border-radius: 3px;
  overflow: hidden
}

.exec-fill {
  height: 6px;
  border-radius: 3px;
  background: var(--green)
}

.close-x {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--ink3);
  font-size: 16px;
  display: grid;
  place-items: center;
  flex-shrink: 0
}

.close-x:hover {
  background: var(--bg3)
}

/* Tooltip mapa */
.map-tt {
  position: fixed;
  background: var(--ink);
  color: #fff;
  border-radius: 10px;
  padding: 9px 12px;
  font-size: 11px;
  pointer-events: none;
  display: none;
  z-index: 999;
  min-width: 140px;
  box-shadow: var(--sh2)
}

.tt-name {
  font-weight: 700;
  margin-bottom: 3px
}

.tt-row {
  color: rgba(255, 255, 255, .65);
  margin-top: 1px
}

.tt-row span {
  color: #fff;
  font-weight: 600
}

/* Popup Parlamentar */
.parl-det-box {
  max-width: 800px
}

.parl-det-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
  padding: 16px;
  background: var(--bg3);
  border-radius: var(--r2)
}

.parl-det-av {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 20px;
  font-weight: 700;
  color: #fff
}

.parl-det-name {
  font-size: 18px;
  font-weight: 700;
  color: var(--ink)
}

.parl-det-uf {
  font-size: 12px;
  color: var(--ink3)
}

.parl-det-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 20px
}

.pd-stat {
  background: var(--bg2);
  border: 1px solid var(--border);
  padding: 14px;
  border-radius: var(--r2);
  text-align: center
}

.pd-stat-k {
  font-size: 9px;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 4px;
  letter-spacing: .05em
}

.pd-stat-v {
  font-size: 16px;
  font-weight: 700;
  color: var(--ink)
}

.parl-emendas-list {
  display: flex;
  flex-direction: column;
  gap: 10px
}

.pe-item {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all .2s
}

.pe-item:hover {
  border-color: var(--accent);
  transform: translateX(4px)
}

.pe-main {
  display: flex;
  flex-direction: column;
  gap: 3px
}

.pe-cod {
  font-size: 10px;
  font-family: monospace;
  color: var(--ink3)
}

.pe-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink)
}

.pe-loc {
  font-size: 11px;
  color: var(--ink3)
}

.pe-vals {
  text-align: right
}

.pe-emp {
  font-size: 13px;
  font-weight: 700;
  color: var(--accent)
}

.pe-pag {
  font-size: 11px;
  color: var(--green);
  font-weight: 500
}

/* ── PAGES ── */
.page-view {
  display: none
}

.page-view.active {
  display: block
}

/* ── PARLAMENTARES ── */
.parl-header {
  padding: 14px 24px;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px
}

.parl-header select {
  flex-shrink: 0;
  white-space: nowrap;
  min-width: 130px;
  height: 36px;
  padding: 0 12px;
  font-size: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
  color: var(--ink);
  outline: none
}

.parl-header select:focus {
  border-color: var(--accent)
}

.parl-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px;
  padding: 20px 24px;
  overflow: visible;
  height: auto
}

#pg-parlamentares {
  height: auto;
  overflow: visible
}

.parl-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  padding: 18px 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  box-shadow: var(--sh);
  transition: all .2s;
  cursor: pointer
}

.parl-card:hover {
  box-shadow: var(--sh2);
  border-color: var(--accent);
  transform: translateY(-2px)
}

.parl-av {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 10px
}

.parl-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 3px;
  line-height: 1.3
}

.parl-uf-lbl {
  font-size: 10px;
  color: var(--ink3);
  margin-bottom: 10px
}

.parl-val {
  font-size: 14px;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 2px
}

.parl-exec {
  font-size: 10px;
  color: var(--ink3);
  margin-top: 2px
}

.parl-prog {
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
  width: 100%;
  margin-top: 8px
}

.parl-prog-fill {
  height: 3px;
  border-radius: 2px;
  background: var(--accent)
}

.parl-count-lbl {
  font-size: 10px;
  color: var(--ink3);
  margin-top: 4px
}

/* ── MAPA FULL ── */
.map-page {
  display: grid;
  grid-template-columns: 1fr 300px;
  height: calc(100vh - 56px);
  overflow: hidden
}

.map-svg-area {
  background: var(--bg3);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px
}

.map-svg-area svg {
  width: 100%;
  height: 100%;
  max-height: calc(100vh - 96px)
}

.map-info-panel {
  border-left: 1px solid var(--border);
  background: var(--bg2);
  overflow-y: auto;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px
}

.ms-card {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 12px 14px
}

.ms-row {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  padding: 4px 0;
  border-bottom: 1px solid var(--border)
}

.ms-row:last-child {
  border-bottom: none
}

.ms-k {
  color: var(--ink3)
}

.ms-v {
  font-weight: 600;
  color: var(--ink)
}

/* ── EXECUÇÃO PAGE ── */
.exec-page-wrap {
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  height: calc(100vh - 56px);
  overflow-y: auto
}

.exec-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px
}

.stage-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px
}

.stage-card {
  padding: 14px;
  border-radius: var(--r2);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px
}

.stage-card.emp {
  background: var(--accent-soft)
}

.stage-card.liq {
  background: var(--blue-s)
}

.stage-card.pag {
  background: var(--green-s)
}

.stage-k {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 4px
}

.stage-card.emp .stage-k {
  color: var(--accent)
}

.stage-card.liq .stage-k {
  color: var(--blue)
}

.stage-card.pag .stage-k {
  color: var(--green)
}

.stage-v {
  font-size: 16px;
  font-weight: 700
}

.stage-s {
  font-size: 11px;
  font-weight: 600;
  color: var(--ink3)
}

.stage-card.emp .stage-v {
  color: var(--accent)
}

.stage-card.liq .stage-v {
  color: var(--blue)
}

.stage-card.pag .stage-v {
  color: var(--green)
}

.stage-card.pag .stage-s {
  color: var(--green)
}

.exec-fn-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  border-bottom: 1px solid var(--border)
}

.exec-fn-row:last-child {
  border-bottom: none
}

.exec-fn-lbl {
  font-size: 12px;
  color: var(--ink2);
  min-width: 130px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap
}

.exec-fn-track {
  flex: 1;
  height: 8px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden
}

.exec-fn-fill {
  height: 8px;
  border-radius: 4px;
  background: var(--accent)
}

.exec-fn-val {
  font-size: 11px;
  font-weight: 600;
  color: var(--ink);
  min-width: 70px;
  text-align: right
}

/* ── VISÃO GERAL ── */
.vg-wrap {
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  height: calc(100vh - 56px);
  overflow-y: auto
}

.vg-2col {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 16px
}

.vg-right {
  display: flex;
  flex-direction: column;
  gap: 12px
}

@media(max-width:1100px) {
  .vg-2col {
    grid-template-columns: 1fr
  }

  .exec-2col {
    grid-template-columns: 1fr
  }
}

/* ═══════════════════════════════════
   MOBILE DRAWER MENU
═══════════════════════════════════ */
.mob-btn {
  display: none;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--bg2);
  color: var(--ink);
  font-size: 20px;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  line-height: 1
}

.drawer-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .45);
  z-index: 800;
  backdrop-filter: blur(3px);
  transition: opacity .3s
}

.drawer-overlay.open {
  display: block
}

.drawer {
  position: fixed;
  right: 0;
  left: auto;
  top: 0;
  bottom: 0;
  width: 285px;
  background: var(--bg2);
  z-index: 900;
  transform: translateX(100%);
  transition: transform .32s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  flex-direction: column;
  box-shadow: -4px 0 32px rgba(0, 0, 0, .15)
}

.drawer.open {
  transform: translateX(0)
}

.drawer-head {
  padding: 20px 18px 16px;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center
}

.drawer-logo-wrap {
  display: flex;
  align-items: center;
  gap: 10px
}

.drawer-logo-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink)
}

.drawer-logo-sub {
  font-size: 10px;
  color: var(--ink3);
  font-weight: 500;
  margin-top: 1px
}

.drawer-close {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--ink3);
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer
}

.drawer-close:hover {
  background: var(--bg3)
}

.drawer-nav {
  flex: 1;
  padding: 10px 10px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 3px
}

.drawer-nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 13px 14px;
  border-radius: 11px;
  border: none;
  background: transparent;
  color: var(--ink2);
  font-size: 14px;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  transition: all .15s
}

.drawer-nav-item:hover {
  background: var(--bg3);
  color: var(--ink)
}

.drawer-nav-item.active {
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: 600
}

.drawer-nav-icon {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  background: var(--bg3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
  transition: background .15s
}

.drawer-nav-item.active .drawer-nav-icon {
  background: rgba(37, 101, 81, .15)
}

.drawer-divider {
  height: 1px;
  background: var(--border);
  margin: 6px 10px
}

.drawer-footer {
  padding: 16px 18px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 8px
}

.drawer-sys-btn {
  width: 100%;
  padding: 13px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: .01em;
  transition: opacity .15s
}

.drawer-sys-btn:hover {
  opacity: .88
}

.drawer-version {
  font-size: 10px;
  color: var(--ink3);
  text-align: center
}

/* Mobile filter panel */
.mob-filter-bar {
  display: none;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  gap: 10px
}

.mob-filter-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink2);
  cursor: pointer
}

.mob-filter-btn:hover {
  border-color: var(--accent);
  color: var(--accent)
}

.mob-filter-panel {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  z-index: 700;
  background: var(--bg2);
  flex-direction: column;
  overflow-y: auto
}

.mob-filter-panel.open {
  display: flex
}

.mob-filter-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 18px;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--bg2)
}

.mob-filter-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--ink)
}

.mob-filter-content {
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px
}

/* ═════════════════════════════════
   RESPONSIVE BREAKPOINTS
═════════════════════════════════ */
@media(max-width:900px) {
  .page-view,
  .layout,
  .main-scroll,
  .right-panel,
  .card,
  .chart-wrap,
  .chart-footer,
  .donut-wrap,
  .tipo-legend,
  .rank-list,
  .parl-header,
  .parl-grid {
    min-width: 0;
  }

  .layout {
    grid-template-columns: 1fr;
    height: auto;
    overflow: visible
  }

  .right-panel {
    display: none
  }

  .page-view {
    height: auto
  }

  body,
  html {
    overflow-x: hidden !important;
    width: 100%
  }

  .main-scroll {
    height: auto;
    overflow: visible;
    padding: 64px 14px 40px 14px !important;
    width: 100%;
    box-sizing: border-box
  }

  .topbar {
    justify-content: space-between;
    padding: 0 14px
  }

  .topbar-right {
    position: static;
    display: flex;
    align-items: center
  }

  .mob-btn {
    display: flex
  }

  .mob-filter-bar {
    display: flex
  }

  .topbar-right button:not(.mob-btn) {
    display: none
  }

  .topbar-title-wrap {
    display: none
  }

  .topbar-logo {
    position: static;
    display: flex;
    align-items: center
  }

  .topbar-logo img {
    height: 30px
  }

  .tab-bar {
    padding: 0 12px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none
  }

  .tab-bar::-webkit-scrollbar {
    display: none
  }

  .parl-header {
    flex-direction: column;
    align-items: stretch;
    padding: 10px 14px;
    gap: 8px
  }

  .parl-header>div:last-child {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px
  }

  .parl-header>div:last-child>* {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100%;
  }

  .parl-header select,
  .parl-header .tbl-search {
    width: 100% !important;
    min-width: 0 !important;
  }

  .parl-grid {
    padding: 12px 14px;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    height: auto
  }

  .chart-canvas-wrap {
    height: 180px !important
  }

  .chart-footer {
    flex-wrap: wrap;
    gap: 12px;
    justify-content: flex-start
  }

  .cf-item {
    flex: 1;
    min-width: 40%
  }

  .tbl-header {
    flex-direction: column;
    gap: 10px;
    padding: 14px
  }

  .tbl-header>div:last-child {
    width: 100%
  }

  .tbl-search {
    min-width: unset !important;
    width: 100% !important;
    box-sizing: border-box
  }

  .tbl-scroll {
    overflow-x: auto
  }

  .vg-wrap {
    height: auto;
    padding: 14px
  }

  .metrics-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px
  }

  .emendas-page {
    padding: 18px 14px 32px
  }

  .emendas-search-card {
    padding: 18px
  }

  .emendas-card-top,
  .emendas-list-toolbar {
    flex-direction: column;
    align-items: flex-start
  }

  .emendas-card-title {
    font-size: 20px
  }

  .emendas-card-chip {
    max-width: none;
    width: 100%
  }

  .emendas-form-grid {
    grid-template-columns: 1fr
  }

  .emendas-search-actions {
    justify-content: stretch
  }

  .emendas-clear-btn,
  .emendas-search-btn {
    width: 100%
  }

  .emendas-list-head {
    display: none
  }

  .emendas-row {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 16px
  }

  .emendas-cell {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start
  }

  .emendas-cell::before {
    content: attr(data-label);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--ink3);
    min-width: 92px
  }

  .emendas-row > .emendas-cell:not(:first-child)::before {
    display: none
  }

  .emendas-action {
    justify-content: flex-start
  }

  .emendas-results-count {
    width: 100%;
    justify-content: flex-start
  }

  .emendas-summary-grid {
    grid-template-columns: 1fr 1fr
  }

  .emendas-dropdown {
    padding: 8px 12px 12px
  }

  .emendas-inline-panel {
    gap: 10px
  }

  .emendas-inline-detail-head {
    padding: 12px 14px 0
  }

  .emendas-inline-detail-grid {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 10px 12px 12px
  }

  .emendas-inline-field {
    padding: 10px 12px
  }

  .emendas-inline-v {
    font-size: 12px
  }
}

.mobile-only-header {
  display: none
}

@media(max-width:900px) {
  .perfil-topbar {
    grid-template-columns: 1fr;
    gap: 10px;
    text-align: center
  }

  .perfil-tabs {
    justify-content: center
  }

  .btn-det {
    display: none
  }

  .mobile-only-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 4px 0 10px;
    text-align: center;
    gap: 2px;
  }

  .mobile-only-header .topbar-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--ink);
  }

  .mobile-only-header .topbar-subtitle {
    font-size: 12px;
    color: var(--ink3);
  }
}

@media(max-width:600px) {
  .metrics-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px
  }

  .donut-wrap {
    flex-wrap: wrap;
  }

  .mcard {
    padding: 12px 10px
  }

  .mc-val {
    font-size: 20px !important
  }

  .db-money {
    grid-template-columns: 1fr
  }

  .parl-grid {
    grid-template-columns: 1fr 1fr
  }

  .topbar {
    padding: 0 12px
  }

  .tab-bar {
    display: none
  }

  table thead tr th:nth-child(4),
  table tbody tr td:nth-child(4),
  table thead tr th:nth-child(5),
  table tbody tr td:nth-child(5),
  table thead tr th:nth-child(8),
  table tbody tr td:nth-child(8) {
    display: none;
  }

  table th,
  table td {
    padding: 8px 8px;
    font-size: 11px;
  }

  .tbl-scroll table {
    min-width: unset;
    width: 100%;
  }

  .site-footer {
    padding: 10px 14px;
    flex-direction: column;
    text-align: center;
    gap: 10px
  }

  .emendas-results-count {
    padding-left: 0
  }

  .emendas-summary-grid {
    grid-template-columns: 1fr
  }

  .emendas-inline-detail-grid {
    grid-template-columns: 1fr
  }

  .footer-left {
    flex-direction: column;
    text-align: center
  }

  .footer-right {
    display: none
  }
}

/* ══════════════════════════════════
   FULL PAGE: PERFIL DO PARLAMENTAR
══════════════════════════════════ */
.perfil-page {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
  width: 100%
}

.perfil-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px 0;
  transition: opacity .15s
}

.perfil-back-btn:hover {
  opacity: .7
}

.perfil-hero {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  box-shadow: var(--sh);
  padding: 28px;
  display: flex;
  align-items: center;
  gap: 24px
}

.perfil-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 28px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .15)
}

.perfil-hero-info {
  flex: 1
}

.perfil-hero-name {
  font-size: 22px;
  font-weight: 800;
  color: var(--ink);
  margin-bottom: 4px;
  letter-spacing: -.3px
}

.perfil-hero-meta {
  font-size: 13px;
  color: var(--ink3);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap
}

.perfil-hero-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  background: var(--accent-soft);
  color: var(--accent)
}

.perfil-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px
}

.perfil-stat {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 18px;
  box-shadow: var(--sh);
  position: relative;
  overflow: hidden
}

.perfil-stat::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: var(--r2) var(--r2) 0 0
}

.perfil-stat.c-green::after {
  background: var(--green)
}

.perfil-stat.c-blue::after {
  background: var(--blue)
}

.perfil-stat.c-accent::after {
  background: var(--accent)
}

.perfil-stat.c-amber::after {
  background: var(--amber)
}

.perfil-stat-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 6px
}

.perfil-stat-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.5px
}

.perfil-2col {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 16px
}

.perfil-chart-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  box-shadow: var(--sh);
  padding: 20px
}

.perfil-chart-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 16px
}

.perfil-donut-wrap {
  display: flex;
  align-items: center;
  gap: 20px;
  justify-content: center
}

.perfil-donut-container {
  position: relative;
  width: 120px;
  height: 120px
}

.perfil-donut-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center
}

.perfil-donut-pct {
  font-size: 20px;
  font-weight: 700;
  color: var(--ink)
}

.perfil-donut-lbl {
  font-size: 9px;
  color: var(--ink3);
  font-weight: 500
}

.perfil-emendas-table {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  box-shadow: var(--sh);
  overflow: hidden
}

/* ══════════════════════════════════
   FULL PAGE: DETALHE DA EMENDA
══════════════════════════════════ */
.detalhe-page {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%
}

.detalhe-hero {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  box-shadow: var(--sh);
  padding: 24px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  flex-wrap: wrap
}

.detalhe-hero-left {
  flex: 1;
  min-width: 200px
}

.detalhe-hero-codigo {
  font-size: 11px;
  font-family: monospace;
  color: var(--ink3);
  margin-bottom: 6px
}

.detalhe-hero-autor {
  font-size: 20px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -.3px;
  margin-bottom: 4px
}

.detalhe-hero-meta {
  font-size: 12px;
  color: var(--ink3);
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap
}

.detalhe-hero-right {
  text-align: right
}

.detalhe-hero-valor {
  font-size: 22px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: -.5px
}

.detalhe-hero-ano {
  font-size: 12px;
  color: var(--ink3);
  margin-top: 2px
}

.detalhe-section {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  box-shadow: var(--sh);
  overflow: hidden
}

.detalhe-section-head {
  padding: 16px 20px 0;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px
}

.detalhe-section-body {
  padding: 0 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px
}

.detalhe-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px
}

.detalhe-field {
  background: var(--bg3);
  border-radius: var(--r);
  padding: 10px 13px
}

.detalhe-field-k {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 3px
}

.detalhe-field-v {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink)
}

.detalhe-money-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px
}

.detalhe-money-card {
  padding: 14px 16px;
  border-radius: var(--r2);
  text-align: center
}

.detalhe-money-card.emp {
  background: var(--accent-soft)
}

.detalhe-money-card.liq {
  background: var(--blue-s)
}

.detalhe-money-card.pag {
  background: var(--green-s)
}

.detalhe-money-k {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 4px
}

.detalhe-money-card.emp .detalhe-money-k {
  color: var(--accent)
}

.detalhe-money-card.liq .detalhe-money-k {
  color: var(--blue)
}

.detalhe-money-card.pag .detalhe-money-k {
  color: var(--green)
}

.detalhe-money-v {
  font-size: 16px;
  font-weight: 700
}

.detalhe-money-card.emp .detalhe-money-v {
  color: var(--accent)
}

.detalhe-money-card.liq .detalhe-money-v {
  color: var(--blue)
}

.detalhe-money-card.pag .detalhe-money-v {
  color: var(--green)
}

.detalhe-timeline-wrap {
  padding: 0 20px 8px
}

.detalhe-timeline-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  max-width: 820px;
  margin: 0 auto 10px
}

.detalhe-timeline-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink)
}

.detalhe-timeline-sub {
  font-size: 11px;
  color: var(--ink3);
  margin-top: 2px
}

.detalhe-timeline-pct {
  font-size: 11px;
  font-weight: 700;
  color: var(--accent2);
  background: var(--accent-soft);
  padding: 5px 9px;
  border-radius: 999px;
  white-space: nowrap
}

.detalhe-timeline {
  display: flex;
  align-items: stretch;
  gap: 18px;
  justify-content: space-between;
  position: relative;
  max-width: 820px;
  margin: 8px auto 0;
  padding-top: 20px
}

.detalhe-tl-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  z-index: 1;
  position: relative;
  flex: 1;
  min-width: 0
}

.detalhe-tl-step::after {
  content: '';
  position: absolute;
  top: 18px;
  left: calc(50% + 22px);
  width: calc(100% - 8px);
  height: 4px;
  border-radius: 999px;
  background: #E6EBF2;
  z-index: -1
}

.detalhe-tl-step:last-child::after {
  display: none
}

.detalhe-tl-step.tl-done::after {
  background: linear-gradient(90deg, rgba(37, 101, 81, .55), rgba(16, 185, 129, .45))
}

.detalhe-tl-dot {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  border: 4px solid #fff;
  box-shadow: 0 6px 18px rgba(17, 19, 24, .12)
}

.detalhe-tl-step.tl-emp .detalhe-tl-dot {
  background: var(--accent)
}

.detalhe-tl-step.tl-liq .detalhe-tl-dot {
  background: var(--blue)
}

.detalhe-tl-step.tl-pag .detalhe-tl-dot {
  background: var(--green)
}

.detalhe-tl-step.tl-rp .detalhe-tl-dot {
  background: var(--amber)
}

.detalhe-tl-step.tl-pending .detalhe-tl-dot {
  background: #D1D5DB;
  color: #F8FAFC;
  box-shadow: none
}

.detalhe-tl-step.tl-current .detalhe-tl-dot {
  background: var(--green);
  box-shadow: 0 0 0 6px rgba(16, 185, 129, .16)
}

.detalhe-tl-card {
  width: 100%;
  min-height: 144px;
  background: linear-gradient(180deg, #fff, #f9fbfd);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px 14px 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-align: center;
  box-shadow: 0 10px 30px rgba(17, 19, 24, .05);
  position: relative;
  overflow: hidden
}

.detalhe-tl-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: #E6EBF2
}

.detalhe-tl-step.tl-emp.tl-done .detalhe-tl-card::before {
  background: var(--accent)
}

.detalhe-tl-step.tl-liq.tl-done .detalhe-tl-card::before {
  background: var(--blue)
}

.detalhe-tl-step.tl-pag.tl-done .detalhe-tl-card::before {
  background: var(--green)
}

.detalhe-tl-step.tl-rp.tl-done .detalhe-tl-card::before {
  background: var(--amber)
}

.detalhe-tl-step.tl-current .detalhe-tl-card {
  border-color: rgba(16, 185, 129, .38);
  box-shadow: 0 12px 30px rgba(16, 185, 129, .10)
}

.detalhe-tl-step.tl-current .detalhe-tl-card::before {
  background: var(--green)
}

.detalhe-tl-status {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent2);
  background: var(--accent-soft);
  padding: 4px 8px;
  border-radius: 999px;
  margin-bottom: 2px
}

.detalhe-tl-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink2);
  text-align: center;
  max-width: 120px;
  line-height: 1.25
}

.detalhe-tl-val {
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.03em
}

.detalhe-tl-date {
  font-size: 12px;
  font-weight: 500;
  color: var(--ink3);
  margin-top: auto
}

.detalhe-tl-step.tl-pending .detalhe-tl-card {
  background: #fbfcfd;
  border-color: #E5E7EB;
  box-shadow: none
}

.detalhe-tl-step.tl-pending .detalhe-tl-status {
  color: #98A2B3;
  background: #F2F4F7
}

.detalhe-tl-step.tl-current .detalhe-tl-status {
  color: #0F766E;
  background: #DCFCE7
}

.detalhe-tl-step.tl-pending .detalhe-tl-label,
.detalhe-tl-step.tl-pending .detalhe-tl-val,
.detalhe-tl-step.tl-pending .detalhe-tl-date {
  color: #B8BFCC
}

@media(max-width:900px) {
  .perfil-page,
  .detalhe-page {
    padding: 0;
    width: 100%;
    box-sizing: border-box;
    overflow-x: hidden
  }

  .perfil-layout {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    gap: 0;
    align-items: stretch
  }

  .perfil-sidebar-container {
    padding: 14px;
    width: 100%;
    box-sizing: border-box
  }

  .perfil-sidebar {
    width: 100%;
    max-width: 100%;
    padding: 24px 20px;
    box-sizing: border-box;
    border: none;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    background: #fff;
    border-radius: 16px
  }

  .perfil-sidebar-row {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 14px 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.03)
  }

  .perfil-sidebar-header {
    flex-direction: column;
    align-items: center;
    gap: 16px;
    width: 100%;
    margin-bottom: 8px
  }

  .perfil-avatar {
    margin-bottom: 12px;
    width: 72px;
    height: 72px;
    font-size: 24px
  }

  .perfil-sidebar-info {
    text-align: center
  }

  .perfil-sidebar-name {
    text-align: center;
    margin-bottom: 4px;
    font-size: 18px
  }

  .perfil-sidebar-badges {
    justify-content: center
  }

  .perfil-main-grid {
    display: flex !important;
    flex-direction: column !important;
    padding: 0 14px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    gap: 14px !important;
  }

  .perfil-value-cards {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
    padding: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  .perfil-vcard {
    flex: unset !important;
    padding: 16px !important;
    min-height: unset !important;
    border-left: 4px solid transparent !important;
    border-top: none !important;
    text-align: left !important;
    align-items: flex-start !important;
  }

  .perfil-vcard.vc-emp {
    border-left-color: #4EB58A !important
  }

  .perfil-vcard.vc-liq {
    border-left-color: #3B82F6 !important
  }

  .perfil-vcard.vc-pag {
    border-left-color: #10B981 !important
  }

  .perfil-vcard.vc-exec {
    border-left-color: #F59E0B !important
  }

  .perfil-vcard-value {
    font-size: 20px !important
  }

  .perfil-vcard-label {
    font-size: 10px !important
  }

  .perfil-main-grid>.card {
    margin: 0 !important
  }

  .card {
    padding: 14px;
    gap: 10px
  }

  .chart-canvas-wrap {
    height: 160px !important
  }

  .chart-legend {
    gap: 10px;
    margin-bottom: 8px
  }

  .chart-wrap {
    padding: 10px 0
  }

  .detalhe-hero {
    flex-direction: column;
    gap: 10px
  }

  #perfil-fn-btns .filt-btn[data-fn="Infraestrutura"],
  #perfil-fn-btns .filt-btn[data-fn="Cultura"],
  #perfil-fn-btns .filt-btn[data-fn="Esporte"],
  #perfil-fn-btns .filt-btn[data-fn="Assistência Social"] {
    display: none
  }

  .perfil-topbar {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    padding: 0 14px;
    width: 100%;
    box-sizing: border-box
  }

  .perfil-back-btn {
    position: static !important;
    width: 100%;
    text-align: center;
    background: var(--bg2);
    border: 1px solid var(--border);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05)
  }

  .perfil-tabs {
    width: 100%;
    justify-content: center;
    border-bottom: 2px solid var(--border)
  }

  .detalhe-hero-right {
    text-align: left
  }

  .detalhe-field-row {
    grid-template-columns: 1fr;
    gap: 10px
  }

  .detalhe-money-grid {
    grid-template-columns: 1fr 1fr
  }

  .detalhe-timeline {
    flex-wrap: wrap;
    gap: 16px;
    justify-content: center;
    max-width: 100%
  }

  .detalhe-timeline-head {
    max-width: 100%
  }

  .detalhe-tl-step {
    flex: 0 0 calc(50% - 8px)
  }

  .detalhe-tl-step::after {
    display: none
  }

  .detalhe-tl-card {
    width: 100%
  }
}

@media(max-width:480px) {
  .detalhe-money-grid {
    grid-template-columns: 1fr
  }

  .detalhe-timeline-head {
    flex-direction: column;
    align-items: flex-start
  }

  .detalhe-tl-step {
    flex-basis: 100%
  }
}

/* ══ PERFIL DO PARLAMENTAR — NEW LAYOUT ══ */
.perfil-page {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%
}

.perfil-topbar {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin-bottom: 24px;
  min-height: 40px
}

.perfil-back-btn {
  position: absolute;
  left: 0;
  padding: 8px 16px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink);
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  transition: all .15s
}

.perfil-back-btn:hover {
  background: var(--bg3)
}

.perfil-tabs {
  display: flex;
  justify-content: center;
  gap: 0;
  border-bottom: 2px solid var(--border)
}

.perfil-tab-btn {
  padding: 10px 20px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink3);
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  transition: all .15s
}

.perfil-tab-btn.active {
  color: var(--ink);
  border-bottom-color: var(--accent)
}

.perfil-tab-btn:hover {
  color: var(--ink)
}

.perfil-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 20px;
  align-items: start
}

/* Sidebar */
.perfil-sidebar {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  box-shadow: var(--sh);
  padding: 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0
}

.perfil-sidebar-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
  align-self: flex-start
}

.perfil-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 26px;
  font-weight: 700;
  color: #fff;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .15);
  margin-bottom: 12px
}

.perfil-sidebar-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%
}

.perfil-sidebar-name {
  font-size: 16px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -.2px;
  text-align: center;
  margin-bottom: 8px
}

.perfil-sidebar-badges {
  display: flex;
  gap: 6px;
  margin-bottom: 18px
}

.perfil-sidebar-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  background: var(--bg3);
  color: var(--ink3)
}

.perfil-sidebar-divider {
  width: 100%;
  height: 1px;
  background: var(--border);
  margin: 0 0 12px
}

.perfil-sidebar-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 10px 0;
  border-bottom: 1px solid var(--bg3)
}

.perfil-sidebar-row:last-child {
  border-bottom: none
}

.perfil-sidebar-k {
  font-size: 11px;
  font-weight: 600;
  color: var(--ink3);
  text-transform: uppercase;
  letter-spacing: .03em
}

.perfil-sidebar-v {
  font-size: 12px;
  font-weight: 700;
  color: var(--ink)
}

.perfil-status-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  background: var(--green-s);
  color: var(--green)
}

/* Value Cards */
.perfil-value-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px
}

.perfil-vcard {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 14px 10px;
  box-shadow: var(--sh);
  border-left: 4px solid transparent;
  display: flex;
  flex-direction: column;
  gap: 4px
}

.perfil-vcard.vc-emp {
  border-left-color: #4EB58A
}

.perfil-vcard.vc-liq {
  border-left-color: #3B82F6
}

.perfil-vcard.vc-pag {
  border-left-color: #10B981
}

.perfil-vcard.vc-exec {
  border-left-color: #F59E0B
}

.perfil-vcard-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink3)
}

.perfil-vcard-value {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -.5px
}

@media(min-width:901px) {
  .perfil-vcard {
    border-left: none;
    border-top: 4px solid transparent;
    padding: 18px 14px;
    text-align: center;
    align-items: center
  }

  .perfil-vcard.vc-emp {
    border-top-color: #4EB58A
  }

  .perfil-vcard.vc-liq {
    border-top-color: #3B82F6
  }

  .perfil-vcard.vc-pag {
    border-top-color: #10B981
  }

  .perfil-vcard.vc-exec {
    border-top-color: #F59E0B
  }

  .perfil-vcard-value {
    font-size: 22px
  }

  .perfil-value-cards {
    grid-template-columns: repeat(4, 1fr)
  }
}

.perfil-vcard.vc-emp .perfil-vcard-value {
  color: #4EB58A
}

.perfil-vcard.vc-liq .perfil-vcard-value {
  color: #3B82F6
}

.perfil-vcard.vc-pag .perfil-vcard-value {
  color: #10B981
}

.perfil-vcard.vc-exec .perfil-vcard-value {
  color: #F59E0B
}

/* Tab content areas */
.perfil-tab-content {
  display: none
}

.perfil-tab-content.active {
  display: block
}

.perfil-emendas-table {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r3);
  box-shadow: var(--sh);
  overflow: hidden
}
