/* ===================================================
   FS Emendas Parlamentares v3.0 — Design Premium
   Paleta: Verde Escuro #005C5C | Verde #0B7A75
           Verde Claro #E8F5F2 | Branco #FFFFFF
           Cinza #F5F7FA
   =================================================== */

/* --- VARIAVEIS --- */
:root {
  --fs-green-dark:   #005C5C;
  --fs-green-mid:    #0B7A75;
  --fs-green-light:  #E8F5F2;
  --fs-green-border: #B2DFDB;
  --fs-white:        #FFFFFF;
  --fs-gray-bg:      #F5F7FA;
  --fs-gray-border:  #E2E8F0;
  --fs-gray-text:    #64748B;
  --fs-dark:         #1E293B;
  --fs-gold:         #B8860B;
  --fs-radius:       10px;
  --fs-shadow:       0 2px 12px rgba(0,92,92,.08);
  --fs-shadow-hover: 0 6px 24px rgba(0,92,92,.15);
  --fs-font:         -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Inter', sans-serif;
  --fs-transition:   all .22s ease;
}

/* --- WRAPPER --- */
.fs-emendas-wrapper {
  font-family: var(--fs-font);
  color: var(--fs-dark);
  max-width: 100%;
  padding: 0;
}

/* --- BREADCRUMB --- */
.fs-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .82rem;
  color: var(--fs-gray-text);
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.fs-breadcrumb-home {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--fs-green-mid);
  text-decoration: none;
  font-weight: 500;
  transition: var(--fs-transition);
}
.fs-breadcrumb-home:hover { color: var(--fs-green-dark); text-decoration: underline; }
.fs-breadcrumb-sep { color: #9CA3AF; font-size: .9rem; }
.fs-breadcrumb-current { color: var(--fs-dark); font-weight: 500; }

/* --- PORTAL HEADER --- */
.fs-portal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.fs-portal-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--fs-green-dark);
  margin: 0 0 4px;
  line-height: 1.3;
}
.fs-portal-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  background: var(--fs-green-light);
  border-radius: 10px;
  color: var(--fs-green-dark);
  flex-shrink: 0;
}
.fs-fonte {
  font-size: .8rem;
  color: var(--fs-gray-text);
  margin: 0;
}
.fs-fonte a { color: var(--fs-gold); text-decoration: none; }
.fs-fonte a:hover { text-decoration: underline; }

/* --- ULTIMA ATUALIZACAO BADGE --- */
.fs-last-update-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--fs-green-light);
  border: 1px solid var(--fs-green-border);
  color: var(--fs-green-dark);
  padding: 6px 14px;
  border-radius: 20px;
  font-size: .82rem;
  font-weight: 500;
  white-space: nowrap;
}
.fs-last-update-badge strong { font-weight: 700; }

/* --- STATS CARDS --- */
.fs-stats-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin-bottom: 20px;
}
.fs-stat-card {
  background: var(--fs-white);
  border: 1px solid var(--fs-gray-border);
  border-radius: var(--fs-radius);
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: var(--fs-shadow);
  transition: var(--fs-transition);
  position: relative;
  overflow: hidden;
}
.fs-stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--fs-green-dark), var(--fs-green-mid));
}
.fs-stat-card:hover { box-shadow: var(--fs-shadow-hover); transform: translateY(-2px); }
.fs-stat-value {
  font-size: 1.7rem;
  font-weight: 700;
  color: var(--fs-green-dark);
  line-height: 1;
}
.fs-stat-label {
  font-size: .78rem;
  color: var(--fs-gray-text);
  text-transform: uppercase;
  letter-spacing: .5px;
  font-weight: 500;
}
.fs-stat-icon {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--fs-green-light);
  opacity: .8;
}
/* Skeleton dos cards */
.fs-stat-card--loading { pointer-events: none; }
.fs-stat-skeleton {
  height: 60px;
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: fs-shimmer 1.4s infinite;
  border-radius: 6px;
}
@keyframes fs-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* --- PAINEL DE FILTROS --- */
.fs-filters-panel {
  background: var(--fs-white);
  border: 1px solid var(--fs-gray-border);
  border-radius: var(--fs-radius);
  box-shadow: var(--fs-shadow);
  margin-bottom: 16px;
  overflow: hidden;
}
.fs-filters-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  background: var(--fs-green-light);
  border-bottom: 1px solid var(--fs-green-border);
  cursor: pointer;
}
.fs-filters-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: .9rem;
  color: var(--fs-green-dark);
}
.fs-toggle-filters-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--fs-green-dark);
  padding: 2px;
  display: flex;
  align-items: center;
  transition: var(--fs-transition);
}
.fs-toggle-filters-btn:hover { color: var(--fs-green-mid); }
.fs-filters-body { padding: 20px; }
.fs-filters-body.fs-collapsed { display: none; }
.fs-filters-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 14px;
  margin-bottom: 16px;
}
.fs-filter-group--wide { grid-column: span 2; }
.fs-filter-group {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.fs-filter-group label {
  font-size: .76rem;
  font-weight: 600;
  color: var(--fs-gray-text);
  text-transform: uppercase;
  letter-spacing: .5px;
  display: flex;
  align-items: center;
  gap: 5px;
}
.fs-input, .fs-select {
  border: 1.5px solid var(--fs-gray-border);
  border-radius: 7px;
  padding: 8px 12px;
  font-size: .88rem;
  font-family: var(--fs-font);
  background: var(--fs-gray-bg);
  color: var(--fs-dark);
  transition: var(--fs-transition);
  width: 100%;
  box-sizing: border-box;
}
.fs-input:focus, .fs-select:focus {
  border-color: var(--fs-green-mid);
  outline: none;
  box-shadow: 0 0 0 3px rgba(11,122,117,.12);
  background: var(--fs-white);
}
.fs-filters-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.fs-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 20px;
  border-radius: 7px;
  font-size: .88rem;
  font-weight: 600;
  font-family: var(--fs-font);
  cursor: pointer;
  transition: var(--fs-transition);
  border: 1.5px solid transparent;
  text-decoration: none;
}
.fs-btn-primary {
  background: var(--fs-green-dark);
  color: var(--fs-white);
  border-color: var(--fs-green-dark);
}
.fs-btn-primary:hover { background: var(--fs-green-mid); border-color: var(--fs-green-mid); transform: translateY(-1px); }
.fs-btn-outline {
  background: transparent;
  color: var(--fs-green-dark);
  border-color: var(--fs-green-border);
}
.fs-btn-outline:hover { background: var(--fs-green-light); border-color: var(--fs-green-dark); }

/* --- TOOLBAR (META + EXPORTACAO) --- */
.fs-table-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.fs-table-meta {
  font-size: .84rem;
  color: var(--fs-gray-text);
  font-weight: 500;
}
.fs-export-btns {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.fs-export-label {
  font-size: .78rem;
  color: var(--fs-gray-text);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .4px;
}
.fs-export-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--fs-white);
  border: 1.5px solid var(--fs-gray-border);
  border-radius: 6px;
  padding: 6px 12px;
  font-size: .8rem;
  font-weight: 600;
  font-family: var(--fs-font);
  color: var(--fs-dark);
  cursor: pointer;
  transition: var(--fs-transition);
}
.fs-export-btn:hover {
  background: var(--fs-green-light);
  border-color: var(--fs-green-mid);
  color: var(--fs-green-dark);
}

/* --- TABELA --- */
.fs-table-container {
  background: var(--fs-white);
  border: 1px solid var(--fs-gray-border);
  border-radius: var(--fs-radius);
  box-shadow: var(--fs-shadow);
  overflow: hidden;
  overflow-x: auto;
}
.fs-emendas-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}
.fs-emendas-table thead tr {
  background: var(--fs-green-dark);
  color: var(--fs-white);
}
.fs-emendas-table thead th {
  padding: 14px 16px;
  text-align: left;
  font-weight: 600;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .5px;
  white-space: nowrap;
  border: none;
}
.fs-emendas-table thead th.fs-sortable {
  cursor: pointer;
  user-select: none;
  transition: var(--fs-transition);
}
.fs-emendas-table thead th.fs-sortable:hover { background: var(--fs-green-mid); }
.fs-emendas-table thead th.fs-sort-asc .fs-sort-icon::after { content: ' ▲'; font-size: .7rem; }
.fs-emendas-table thead th.fs-sort-desc .fs-sort-icon::after { content: ' ▼'; font-size: .7rem; }
.fs-emendas-table thead th.fs-col-status,
.fs-emendas-table thead th.fs-col-action { text-align: center; }
.fs-emendas-table tbody tr {
  border-bottom: 1px solid var(--fs-gray-border);
  transition: var(--fs-transition);
}
.fs-emendas-table tbody tr:hover { background: var(--fs-green-light); }
.fs-emendas-table tbody tr:last-child { border-bottom: none; }
.fs-emendas-table tbody tr:nth-child(even) { background: #FAFCFB; }
.fs-emendas-table tbody tr:nth-child(even):hover { background: var(--fs-green-light); }
.fs-emendas-table tbody td {
  padding: 13px 16px;
  vertical-align: middle;
  color: var(--fs-dark);
  border: none;
}
.fs-td-emenda { font-weight: 700; color: var(--fs-green-dark); font-size: .95rem; }
.fs-td-year {
  display: inline-block;
  background: var(--fs-green-dark);
  color: var(--fs-white);
  padding: 2px 10px;
  border-radius: 20px;
  font-size: .78rem;
  font-weight: 700;
}
.fs-td-autor { color: var(--fs-dark); font-size: .86rem; max-width: 260px; }
.fs-td-destino { color: var(--fs-gray-text); font-size: .86rem; max-width: 200px; }
.fs-td-valor {
  font-weight: 700;
  color: var(--fs-green-dark);
  text-align: right;
  white-space: nowrap;
  font-size: .92rem;
}
.fs-td-status, .fs-td-action { text-align: center; }

/* Badges de situacao */
.fs-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: .76rem;
  font-weight: 600;
  white-space: nowrap;
}
.fs-badge--pago    { background: #DCFCE7; color: #166534; }
.fs-badge--parcial { background: #FEF3C7; color: #92400E; }
.fs-badge--pendente{ background: #FEE2E2; color: #991B1B; }
.fs-badge--empenho { background: #DBEAFE; color: #1E40AF; }
.fs-badge--sem     { background: #F1F5F9; color: #64748B; }

/* Botao Ver */
.fs-btn-ver {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--fs-green-dark);
  color: var(--fs-white);
  border: none;
  border-radius: 6px;
  padding: 6px 14px;
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--fs-transition);
  white-space: nowrap;
  font-family: var(--fs-font);
}
.fs-btn-ver:hover { background: var(--fs-green-mid); transform: translateY(-1px); box-shadow: 0 3px 8px rgba(0,92,92,.2); }

/* Skeleton rows */
.fs-skeleton-row td { padding: 16px; }
.fs-skeleton-cell {
  height: 16px;
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: fs-shimmer 1.4s infinite;
  border-radius: 4px;
}
.fs-skeleton-cell--short { width: 60%; }
.fs-skeleton-cell--long  { width: 90%; }
.fs-skeleton-cell--btn   { width: 60px; height: 28px; border-radius: 6px; }

/* --- PAGINACAO --- */
.fs-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 20px;
  flex-wrap: wrap;
}
.fs-page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1.5px solid var(--fs-gray-border);
  border-radius: 7px;
  background: var(--fs-white);
  color: var(--fs-dark);
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--fs-transition);
  font-family: var(--fs-font);
}
.fs-page-btn:hover { background: var(--fs-green-light); border-color: var(--fs-green-mid); color: var(--fs-green-dark); }
.fs-page-btn.fs-active { background: var(--fs-green-dark); color: var(--fs-white); border-color: var(--fs-green-dark); }
.fs-page-btn:disabled { opacity: .4; cursor: default; }
.fs-page-ellipsis { padding: 0 4px; color: var(--fs-gray-text); font-size: .85rem; }
.fs-pagination-info {
  font-size: .82rem;
  color: var(--fs-gray-text);
  margin-left: 8px;
}

/* --- MODAL --- */
.fs-modal {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.fs-modal-overlay {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(3px);
  cursor: pointer;
}
.fs-modal-inner {
  position: relative;
  background: var(--fs-white);
  border-radius: 14px;
  max-width: 780px;
  width: 100%;
  max-height: 88vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
  animation: fs-modal-in .22s ease;
}
@keyframes fs-modal-in {
  from { opacity: 0; transform: scale(.95) translateY(10px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.fs-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  background: var(--fs-green-dark);
  color: var(--fs-white);
  flex-shrink: 0;
}
.fs-modal-title {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0;
  color: var(--fs-white);
}
.fs-modal-close {
  background: rgba(255,255,255,.15);
  border: none;
  color: var(--fs-white);
  border-radius: 6px;
  width: 32px;
  height: 32px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--fs-transition);
}
.fs-modal-close:hover { background: rgba(255,255,255,.3); }
.fs-modal-content {
  padding: 24px;
  overflow-y: auto;
  flex: 1;
}
/* Modal loading */
.fs-modal-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 40px 0;
  color: var(--fs-gray-text);
}
.fs-spinner {
  width: 36px;
  height: 36px;
  border: 3px solid var(--fs-green-light);
  border-top-color: var(--fs-green-dark);
  border-radius: 50%;
  animation: fs-spin .7s linear infinite;
}
@keyframes fs-spin { to { transform: rotate(360deg); } }

/* Modal detalhe grid */
.fs-detail-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--fs-green-light);
}
.fs-detail-emenda-num {
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--fs-green-dark);
  line-height: 1;
}
.fs-detail-emenda-label {
  font-size: .78rem;
  color: var(--fs-gray-text);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.fs-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
  margin-bottom: 16px;
}
.fs-detail-item { display: flex; flex-direction: column; gap: 3px; }
.fs-detail-item-label {
  font-size: .72rem;
  font-weight: 700;
  color: var(--fs-gray-text);
  text-transform: uppercase;
  letter-spacing: .4px;
}
.fs-detail-item-value {
  font-size: .9rem;
  color: var(--fs-dark);
  font-weight: 500;
}
.fs-detail-item-value--valor {
  color: var(--fs-green-dark);
  font-weight: 700;
  font-size: 1.05rem;
}
.fs-detail-section-title {
  font-size: .85rem;
  font-weight: 700;
  color: var(--fs-green-dark);
  text-transform: uppercase;
  letter-spacing: .6px;
  padding: 10px 0 8px;
  border-top: 1px solid var(--fs-gray-border);
  margin-top: 6px;
}
.fs-detail-objeto {
  background: var(--fs-gray-bg);
  border-radius: 8px;
  padding: 12px 16px;
  font-size: .88rem;
  color: var(--fs-dark);
  line-height: 1.6;
  border: 1px solid var(--fs-gray-border);
  margin-top: 6px;
}

/* --- LOADING STATE --- */
.fs-loading-overlay {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.7);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--fs-radius);
  z-index: 10;
}
.fs-table-container { position: relative; }

/* --- RESPONSIVO --- */
@media (max-width: 768px) {
  .fs-portal-header { flex-direction: column; gap: 10px; }
  .fs-portal-title { font-size: 1.15rem; }
  .fs-stats-cards { grid-template-columns: repeat(2, 1fr); }
  .fs-filters-grid { grid-template-columns: 1fr; }
  .fs-filter-group--wide { grid-column: span 1; }
  .fs-table-toolbar { flex-direction: column; align-items: flex-start; }
  .fs-emendas-table thead th:not(.fs-col-emenda):not(.fs-col-valor):not(.fs-col-action) {
    display: none;
  }
  .fs-emendas-table tbody td:not(.fs-td-emenda-col):not(.fs-td-valor-col):not(.fs-td-action-col) {
    display: none;
  }
  .fs-modal-inner { margin: 10px; max-height: 92vh; }
  .fs-detail-grid { grid-template-columns: 1fr; }
  .fs-pagination { gap: 4px; }
  .fs-page-btn { width: 30px; height: 30px; font-size: .78rem; }
}
@media (max-width: 480px) {
  .fs-stats-cards { grid-template-columns: 1fr; }
  .fs-export-btns { display: none; } /* oculta em mobile muito pequeno */
}

/* --- PRINT --- */
@media print {
  .fs-filters-panel, .fs-table-toolbar, .fs-pagination, .fs-modal, .fs-last-update-badge { display: none !important; }
  .fs-emendas-table { font-size: .78rem; }
  .fs-emendas-table thead tr { background: #333 !important; -webkit-print-color-adjust: exact; }
  .fs-portal-title { font-size: 1.1rem; }
}
