:root {
  --bg: #020604;
  --card: rgba(6, 18, 10, 0.94);
  --card-soft: rgba(3, 10, 5, 0.68);
  --field: rgba(2, 8, 4, 0.86);

  --border: rgba(120, 185, 87, 0.42);
  --border-soft: rgba(120, 185, 87, 0.26);
  --border-strong: rgba(144, 214, 95, 0.7);

  --text: #f4fff0;
  --muted: #b7c7ad;
  --muted-dark: #7f946f;

  --green: #356b24;
  --green-light: #78b957;
  --green-neon: #90d65f;
  --green-dark: #173d17;

  --red: #b84343;
  --yellow: #d8bd58;

  --shadow: 0 30px 90px rgba(0, 0, 0, 0.62);
  --radius: 22px;
}

/* =========================
   RESET / BASE
========================= */

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
  font-family: Arial, Helvetica, sans-serif;
  color: var(--text);
  background:
    linear-gradient(90deg, rgba(120, 185, 87, 0.025) 1px, transparent 1px),
    linear-gradient(0deg, rgba(120, 185, 87, 0.02) 1px, transparent 1px),
    radial-gradient(circle at 18% 0%, rgba(120, 185, 87, 0.16), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(53, 107, 36, 0.22), transparent 30%),
    linear-gradient(135deg, #010402 0%, #061008 46%, #020604 100%);
  background-size: 42px 42px, 42px 42px, auto, auto, auto;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.22;
  background:
    linear-gradient(45deg, transparent 0 18%, rgba(60, 92, 43, 0.22) 18% 29%, transparent 29% 55%, rgba(24, 65, 26, 0.28) 55% 68%, transparent 68%),
    linear-gradient(-45deg, transparent 0 23%, rgba(92, 126, 57, 0.12) 23% 36%, transparent 36% 62%, rgba(17, 52, 22, 0.22) 62% 75%, transparent 75%);
  background-size: 96px 96px, 128px 128px;
  mix-blend-mode: screen;
}

button,
input,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

a {
  color: inherit;
  text-decoration: none;
}

.hidden {
  display: none !important;
}

/* =========================
   LAYOUT
========================= */

.page {
  min-height: 100vh;
  padding: 24px;
}

.app-shell {
  width: min(100%, 1180px);
  margin: 0 auto;
}

.page-admin .app-shell {
  width: min(100%, 1320px);
}

.page-member .app-shell {
  width: min(100%, 1120px);
}

.hero {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  margin-bottom: 22px;
}

.eyebrow {
  margin: 0 0 6px;
  color: var(--green-neon);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-shadow: 0 0 18px rgba(144, 214, 95, 0.36);
}

h1 {
  margin: 0;
  color: var(--green-light);
  font-size: clamp(34px, 5vw, 64px);
  line-height: 0.92;
  letter-spacing: -0.05em;
  text-transform: uppercase;
  text-shadow:
    0 2px 0 rgba(0, 0, 0, 0.55),
    0 0 22px rgba(120, 185, 87, 0.22);
}

.subtitle,
.footer-note {
  color: #c8d7be;
}

.subtitle {
  margin: 12px 0 0;
  max-width: 680px;
}

.footer-note {
  margin-top: 18px;
  text-align: center;
  font-size: 13px;
}

.footer-note::before {
  content: " ";
  color: var(--green-light);
}

/* =========================
   CARDS
========================= */

.card {
  padding: 22px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(8, 22, 11, 0.95), rgba(5, 13, 8, 0.94)),
    repeating-linear-gradient(45deg, rgba(57, 86, 38, 0.16) 0 12px, rgba(22, 54, 22, 0.08) 12px 24px);
  box-shadow: var(--shadow), inset 0 0 0 1px rgba(144, 214, 95, 0.055);
}

/* =========================
   TEXTOS / TÍTULOS
========================= */

.form-group label,
.material-input label,
.section-title span {
  color: var(--green-light);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-shadow: 0 0 16px rgba(120, 185, 87, 0.18);
}

.form-group small,
.section-title small,
.upload-box small,
.preview-actions span {
  color: #afc7a4;
}

.section-title {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
  margin-bottom: 16px;
}

.section-title span {
  font-size: 18px;
}

/* =========================
   FORMULÁRIOS
========================= */

.registro-form,
.form-group {
  display: grid;
  gap: 22px;
}

.form-group {
  gap: 9px;
}

.combo {
  position: relative;
}

.combo input,
.material-input input,
.filters-grid input,
.filters-grid select,
.member-form input,
.edit-form input,
.edit-form select {
  width: 100%;
  min-height: 52px;
  border: 1px solid rgba(120, 185, 87, 0.34);
  border-radius: 16px;
  outline: 0;
  background: var(--field);
  color: var(--text);
  padding: 0 16px;
  box-shadow: inset 0 0 18px rgba(0, 0, 0, 0.32);
}

.combo input:focus,
.material-input input:focus,
.filters-grid input:focus,
.filters-grid select:focus,
.member-form input:focus,
.edit-form input:focus,
.edit-form select:focus {
  border-color: var(--green-neon);
  box-shadow:
    0 0 0 4px rgba(120, 185, 87, 0.13),
    inset 0 0 18px rgba(0, 0, 0, 0.34);
}

.combo-dropdown {
  position: absolute;
  z-index: 20;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  max-height: 240px;
  overflow-y: auto;
  padding: 8px;
  border: 1px solid rgba(120, 185, 87, 0.44);
  border-radius: 16px;
  background: #07120a;
  box-shadow: var(--shadow);
}

.combo-item {
  width: 100%;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--text);
  text-align: left;
  padding: 12px 14px;
}

.combo-item:hover {
  background: rgba(120, 185, 87, 0.14);
  color: var(--green-neon);
}

.combo-empty {
  color: var(--muted);
  padding: 12px 14px;
}

/* =========================
   DATA / HORA
========================= */

.auto-info {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.auto-info div {
  border: 1px solid rgba(120, 185, 87, 0.36);
  border-radius: 16px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(5, 14, 8, 0.85), rgba(3, 9, 5, 0.75));
}

.auto-info span {
  display: block;
  color: var(--green-light);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.auto-info strong {
  display: block;
  margin-top: 6px;
  color: #fff;
  font-size: 18px;
}

/* =========================
   UPLOAD
========================= */

.upload-box {
  min-height: 235px;
  border: 2px dashed rgba(120, 185, 87, 0.5);
  border-radius: 20px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 26px;
  cursor: pointer;
  background:
    radial-gradient(circle at center, rgba(120, 185, 87, 0.07), transparent 38%),
    linear-gradient(180deg, rgba(6, 18, 10, 0.72), rgba(2, 7, 4, 0.62));
}

.upload-box:hover,
.upload-box.dragging {
  border-color: var(--green-neon);
  background: rgba(53, 107, 36, 0.13);
}

.upload-icon {
  display: block;
  margin-bottom: 8px;
  color: var(--green-neon);
  font-size: 42px;
  filter: drop-shadow(0 0 12px rgba(144, 214, 95, 0.35));
}

.preview-area {
  display: grid;
  gap: 12px;
}

.preview-area img {
  width: 100%;
  max-height: 520px;
  object-fit: contain;
  border: 1px solid rgba(120, 185, 87, 0.45);
  border-radius: 18px;
  background: #020604;
}

.preview-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

/* =========================
   MATERIAIS
========================= */

.materials-panel,
.summary-box {
  border: 1px solid rgba(120, 185, 87, 0.42);
  border-radius: 20px;
  padding: 18px;
  background: rgba(3, 10, 5, 0.58);
}

.materials-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  align-items: end;
}

.material-input {
  display: grid;
  gap: 10px;
  text-align: center;
}

.material-input label {
  display: block;
  width: 100%;
  text-align: center;
  color: var(--green-light);
}

.material-input label::before,
.material-input label::after {
  content: none !important;
}

.material-input input {
  color: #fff;
  font-size: 25px;
  font-weight: 900;
  text-align: center;
}

.material-input input::placeholder {
  color: #6f8068;
}

/* =========================
   RESUMO
========================= */

.summary-box {
  border-color: rgba(144, 214, 95, 0.55);
  background: rgba(53, 107, 36, 0.11);
}

.summary-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}

.summary-grid div {
  border: 1px solid rgba(120, 185, 87, 0.36);
  border-radius: 16px;
  padding: 14px;
  background: rgba(2, 8, 4, 0.65);
  text-align: center;
}

.summary-grid strong {
  display: block;
  color: var(--green-light);
  font-size: 13px;
  text-transform: uppercase;
}

.summary-grid span {
  display: block;
  margin-top: 8px;
  font-size: 18px;
  font-weight: 900;
}

/* =========================
   BOTÕES
========================= */

.btn,
.admin-link {
  min-height: 52px;
  border-radius: 16px;
  padding: 0 18px;
  font-weight: 900;
}

.admin-link {
  display: inline-grid;
  place-items: center;
  padding: 12px 18px;
  border: 1px solid rgba(120, 185, 87, 0.42);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(11, 31, 14, 0.94), rgba(4, 12, 7, 0.92));
  color: #eaffde;
  box-shadow:
    inset 0 0 0 1px rgba(144, 214, 95, 0.08),
    0 18px 50px rgba(0, 0, 0, 0.34);
}

.admin-link:hover {
  border-color: var(--green-neon);
  color: var(--green-neon);
}

.btn {
  display: inline-grid;
  place-items: center;
  border: 0;
  text-align: center;
}

.btn-primary {
  color: #071006;
  border: 1px solid rgba(144, 214, 95, 0.62);
  background: linear-gradient(135deg, #78b957, #356b24 58%, #224b1c);
  box-shadow:
    0 18px 44px rgba(53, 107, 36, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.btn-primary:hover {
  filter: brightness(1.08);
}

.btn-ghost {
  border: 1px solid rgba(120, 185, 87, 0.34);
  background: rgba(6, 18, 10, 0.78);
  color: #eaffde;
}

.btn-ghost:hover {
  border-color: var(--green-neon);
  color: var(--green-neon);
}

.btn-danger {
  border: 1px solid rgba(184, 67, 67, 0.45);
  background: rgba(184, 67, 67, 0.16);
  color: #ffd1d1;
}

.btn-approve {
  border: 1px solid rgba(120, 185, 87, 0.45);
  background: rgba(53, 107, 36, 0.18);
  color: #d9ffd0;
}

.btn-reject {
  border: 1px solid rgba(216, 189, 88, 0.45);
  background: rgba(216, 189, 88, 0.14);
  color: #fff0b0;
}

.btn-small {
  min-height: 38px;
  border-radius: 12px;
  padding: 0 12px;
  font-size: 13px;
}

.form-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.form-actions .btn {
  flex: 1;
  min-width: 180px;
}

/* =========================
   FEEDBACK
========================= */

.feedback {
  border-radius: 14px;
  padding: 14px 16px;
  font-weight: 800;
}

.feedback.sucesso {
  background: rgba(53, 107, 36, 0.16);
  color: #d9ffd0;
  border: 1px solid rgba(120, 185, 87, 0.48);
}

.feedback.erro {
  background: rgba(184, 67, 67, 0.16);
  color: #ffd1d1;
  border: 1px solid rgba(184, 67, 67, 0.46);
}

/* =========================
   PAINEL GESTOR
========================= */

.stats-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.stat-card {
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(6, 18, 10, 0.88);
}

.stat-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.stat-card strong {
  display: block;
  margin-top: 8px;
  font-size: 28px;
  line-height: 1;
}

.filters-card {
  margin-bottom: 18px;
  overflow: hidden;
}

.filters-grid,
.filters-grid-v07 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  gap: 12px;
  align-items: stretch;
}

.filters-grid input,
.filters-grid select,
.filters-grid button,
.filters-grid label.btn {
  width: 100%;
  min-width: 0;
  white-space: normal;
  text-align: center;
}

.admin-layout,
.admin-layout-v07 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 390px);
  gap: 18px;
  align-items: start;
}

.side-stack,
.records-list,
.members-list,
.ranking-list {
  display: grid;
  gap: 14px;
}

/* =========================
   REGISTROS
========================= */

.record-card {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(2, 8, 4, 0.52);
}

.record-image {
  width: 100%;
  min-height: 170px;
  border: 0;
  border-radius: 14px;
  overflow: hidden;
  cursor: pointer;
  background: #020604;
}

.record-image img {
  width: 100%;
  height: 100%;
  max-height: none;
  display: block;
  object-fit: cover;
}

.record-content {
  display: grid;
  gap: 12px;
  min-width: 0;
}

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

.record-header strong {
  display: block;
  font-size: 18px;
}

.record-header small,
.member-item small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
}

.status-badge {
  flex: 0 0 auto;
  padding: 7px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.status-badge.pendente {
  color: #fff0b0;
  background: rgba(216, 189, 88, 0.14);
  border: 1px solid rgba(216, 189, 88, 0.34);
}

.status-badge.aprovado {
  color: #d9ffd0;
  background: rgba(53, 107, 36, 0.18);
  border: 1px solid rgba(120, 185, 87, 0.42);
}

.status-badge.rejeitado {
  color: #ffd1d1;
  background: rgba(184, 67, 67, 0.16);
  border: 1px solid rgba(184, 67, 67, 0.42);
}

.record-materials {
  display: grid;
  grid-template-columns: repeat(4, minmax(90px, 1fr));
  gap: 8px;
}

.record-materials span {
  padding: 10px;
  border-radius: 14px;
  background: rgba(4, 13, 7, 0.88);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.record-materials strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 18px;
}

.record-actions,
.member-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

/* =========================
   RANKING / MEMBROS
========================= */

.ranking-item {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 76px;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(2, 8, 4, 0.52);
}

.ranking-pos {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  color: #d9ffd0;
  background: rgba(53, 107, 36, 0.18);
  border: 1px solid rgba(120, 185, 87, 0.4);
  font-size: 13px;
  font-weight: 900;
}

.ranking-body strong {
  display: block;
  font-size: 15px;
}

.ranking-body small {
  display: block;
  color: var(--muted);
  margin-top: 3px;
}

.ranking-materials {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.ranking-materials span {
  padding: 5px 7px;
  border-radius: 999px;
  background: rgba(4, 13, 7, 0.88);
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.ranking-total {
  color: var(--green-neon);
  font-size: 24px;
  font-weight: 900;
  text-align: right;
}

.member-form {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}

.members-management-grid {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.member-toolbar {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 14px;
}

.member-toolbar label {
  display: grid;
  gap: 6px;
  min-width: 180px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.member-toolbar select {
  width: 100%;
  min-height: 42px;
  border: 1px solid rgba(120, 185, 87, 0.34);
  border-radius: 12px;
  background: var(--field);
  color: var(--text);
  padding: 0 12px;
  font-weight: 800;
}

.member-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(2, 8, 4, 0.52);
}

.member-item > div:first-child {
  min-width: 0;
}

.member-item strong {
  display: block;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  line-height: 1.15;
}

.member-item.inactive {
  opacity: 0.48;
}

/* =========================
   MODAIS
========================= */

.modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  place-items: center;
  padding: 22px;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.82);
}

.modal-content {
  position: relative;
  z-index: 1;
  width: min(1180px, 96vw);
  max-height: 92vh;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: #020604;
  box-shadow: var(--shadow);
}

.modal-content img {
  width: 100%;
  max-height: 86vh;
  object-fit: contain;
  display: block;
  border-radius: 16px;
}

.modal-close {
  position: absolute;
  top: -14px;
  right: -14px;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 50%;
  background: var(--red);
  color: white;
  font-size: 28px;
  line-height: 1;
}

.edit-modal-content {
  width: min(680px, 96vw);
}

.edit-form {
  display: grid;
  gap: 16px;
}

.edit-form label {
  display: grid;
  gap: 8px;
  color: var(--text);
  font-weight: 800;
}

/* =========================
   ESTADOS
========================= */

.empty-state {
  border: 1px dashed var(--border);
  border-radius: 18px;
  padding: 24px;
  color: var(--muted);
  text-align: center;
  background: rgba(2, 8, 4, 0.34);
}

.import-btn {
  display: inline-grid;
  place-items: center;
  text-align: center;
}

/* =========================
   RESPONSIVO
========================= */

@media (max-width: 1180px) {
  .stats-grid {
    grid-template-columns: repeat(3, minmax(150px, 1fr));
  }

  .admin-layout,
  .admin-layout-v07 {
    grid-template-columns: 1fr;
  }

  .record-card {
    grid-template-columns: 240px minmax(0, 1fr);
  }
}

@media (max-width: 760px) {
  .hero {
    align-items: flex-start;
  }

  .stats-grid {
    grid-template-columns: repeat(2, minmax(130px, 1fr));
  }

  .auto-info {
    grid-template-columns: 1fr;
  }

  .record-card {
    grid-template-columns: 1fr;
  }

  .record-image {
    min-height: 230px;
  }

  .materials-grid,
  .record-materials,
  .summary-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .preview-actions {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 520px) {
  .page {
    padding: 14px;
  }

  h1 {
    font-size: clamp(34px, 11vw, 54px);
  }

  .hero {
    display: grid;
  }

  .card {
    padding: 16px;
  }

  .stats-grid,
  .filters-grid,
  .filters-grid-v07,
  .materials-grid,
  .record-materials,
  .summary-grid {
    grid-template-columns: 1fr;
  }

  .record-image {
    min-height: 190px;
  }

  .member-item {
    align-items: flex-start;
    flex-direction: column;
  }

  .member-item strong {
    max-width: 100%;
  }
}
/* =========================
   V10 - Painel gestor em abas
========================= */
.admin-tabs {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin: 0 0 18px;
}

.tab-btn {
  min-height: 56px;
  border: 1px solid rgba(120, 185, 87, 0.34);
  border-radius: 16px;
  background: rgba(6, 18, 10, 0.78);
  color: #eaffde;
  padding: 0 10px;
  font-size: 14px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.tab-btn:hover,
.tab-btn.active {
  border-color: var(--green-neon);
  color: #071006;
  background: linear-gradient(135deg, #78b957, #356b24 58%, #224b1c);
  box-shadow: 0 18px 44px rgba(53, 107, 36, 0.22);
}

.tab-btn span {
  display: inline-grid;
  place-items: center;
  min-width: 26px;
  height: 26px;
  margin-left: 8px;
  border-radius: 999px;
  background: rgba(2, 8, 4, 0.55);
  color: #fff;
  font-size: 12px;
}

@media (max-width: 980px) {
  .admin-tabs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .members-management-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  .admin-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.tab-panel {
  display: none;
}

.tab-panel.active {
  display: block;
}

.approval-list .record-card {
  grid-template-columns: 260px minmax(0, 1fr);
}

.approval-card .record-image {
  min-height: 205px;
}

.filters-grid-table {
  grid-template-columns: minmax(180px, 1.4fr) 150px 150px 180px auto auto;
}

.table-wrap {
  width: 100%;
  overflow-x: auto;
  border: 1px solid rgba(120, 185, 87, 0.28);
  border-radius: 18px;
}

.records-table {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
  background: rgba(2, 8, 4, 0.36);
}

.records-table th,
.records-table td {
  padding: 13px 12px;
  border-bottom: 1px solid rgba(120, 185, 87, 0.18);
  text-align: left;
  vertical-align: middle;
}

.records-table th {
  color: var(--green-light);
  background: rgba(2, 8, 4, 0.72);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.records-table td {
  color: var(--text);
  font-size: 14px;
}

.records-table tr:hover td {
  background: rgba(120, 185, 87, 0.05);
}

.table-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.table-empty {
  padding: 28px !important;
  color: var(--muted) !important;
  text-align: center !important;
}

.chart-card {
  display: grid;
  gap: 16px;
  margin-top: 16px;
  padding: 16px;
  border: 1px solid rgba(120, 185, 87, 0.28);
  border-radius: 18px;
  background: rgba(2, 8, 4, 0.36);
}

.chart-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
}

.chart-head strong {
  color: var(--green-light);
  text-transform: uppercase;
}

.chart-head small {
  color: var(--muted);
}

.line-chart {
  min-height: 210px;
  display: flex;
  gap: 10px;
  align-items: end;
  overflow-x: auto;
  padding: 12px 6px 0;
}

.line-point {
  position: relative;
  flex: 0 0 54px;
  display: grid;
  align-content: end;
  justify-items: center;
  border-radius: 14px 14px 8px 8px;
  background: linear-gradient(180deg, rgba(144,214,95,.9), rgba(53,107,36,.72));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 12px 30px rgba(53,107,36,.18);
}

.line-point span {
  position: absolute;
  top: -26px;
  color: var(--text);
  font-size: 12px;
  font-weight: 900;
}

.line-point small {
  position: absolute;
  bottom: -26px;
  color: var(--muted);
  font-size: 11px;
  white-space: nowrap;
}

.bar-chart {
  display: grid;
  gap: 12px;
}

.bar-row {
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr) 70px;
  gap: 12px;
  align-items: center;
}

.bar-row strong {
  color: var(--green-light);
  text-transform: uppercase;
  font-size: 13px;
}

.bar-row em {
  color: var(--text);
  font-style: normal;
  font-weight: 900;
  text-align: right;
}

.bar-track {
  height: 18px;
  overflow: hidden;
  border: 1px solid rgba(120, 185, 87, 0.28);
  border-radius: 999px;
  background: rgba(2, 8, 4, 0.72);
}

.bar-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #356b24, #90d65f);
}

.config-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(150px, 1fr));
  gap: 12px;
}

.settings-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
}

.settings-card {
  width: min(100%, 980px);
}

.config-grid .btn {
  min-height: 54px;
}

.password-box {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid rgba(120, 185, 87, 0.22);
}

.compact-title {
  margin-bottom: 12px;
}

.password-grid {
  grid-template-columns: repeat(4, minmax(150px, 1fr));
}

.password-grid .btn {
  min-height: 52px;
}

.password-grid input:disabled,
.password-grid button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

@media (max-width: 1000px) {
  .admin-tabs {
    grid-template-columns: repeat(2, 1fr);
  }

  .approval-list .record-card {
    grid-template-columns: 1fr;
  }

  .filters-grid-table,
  .config-grid,
  .password-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 620px) {
  .admin-tabs,
  .filters-grid-table,
  .config-grid,
  .password-grid {
    grid-template-columns: 1fr;
  }

  .bar-row {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .bar-row em {
    text-align: left;
  }
}

/* ========================
   V11 - Produção Acapofol
======================== */
.production-hero-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1.6fr) repeat(3, minmax(190px, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.production-main-card,
.production-info-card {
  display: grid;
  gap: 8px;
}

.production-main-card span,
.production-info-card span,
.recipe-box span,
.stock-card span,
.leftover-item span,
.planner-form label,
.planner-missing span {
  color: var(--green-light);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.production-main-card strong {
  color: var(--green-neon);
  font-size: clamp(42px, 5vw, 72px);
  line-height: .95;
  text-shadow: 0 0 24px rgba(144, 214, 95, .22);
}

.production-info-card strong {
  color: var(--text);
  font-size: 34px;
  line-height: 1;
}

.production-main-card small,
.production-info-card small,
.stock-card small,
.balance-row small {
  color: var(--muted);
}

.production-layout {
  align-items: start;
}

.recipe-box {
  display: grid;
  grid-template-columns: 1.3fr .7fr;
  gap: 12px;
  margin-bottom: 20px;
}

.recipe-box > div,
.stock-card,
.leftover-item,
.planner-result {
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  background: rgba(2, 8, 4, 0.54);
  padding: 14px;
}

.recipe-box strong {
  display: block;
  margin-top: 8px;
  color: var(--text);
  font-size: 18px;
}

.production-subtitle {
  margin-top: 18px;
}

.production-stock-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.stock-card strong {
  display: block;
  margin: 8px 0 4px;
  color: var(--text);
  font-size: 30px;
}

.balance-list {
  display: grid;
  gap: 12px;
}

.balance-row {
  display: grid;
  gap: 8px;
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  padding: 12px;
  background: rgba(2, 8, 4, 0.42);
}

.balance-row.is-bottleneck {
  border-color: rgba(216, 189, 88, 0.65);
  background: rgba(216, 189, 88, 0.08);
}

.balance-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.balance-head strong {
  color: var(--text);
}

.balance-head span {
  color: var(--green-neon);
  font-weight: 900;
}

.leftover-list {
  display: grid;
  gap: 10px;
}

.leftover-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.leftover-item strong {
  color: var(--text);
  font-size: 22px;
}

.planner-form {
  display: grid;
  gap: 12px;
}

.planner-form label {
  display: grid;
  gap: 8px;
}

.planner-form input {
  width: 100%;
  min-height: 52px;
  border: 1px solid rgba(120, 185, 87, 0.34);
  border-radius: 16px;
  outline: 0;
  background: var(--field);
  color: var(--text);
  padding: 0 16px;
}

.planner-result {
  margin-top: 14px;
}

.planner-summary {
  display: grid;
  gap: 5px;
  margin-bottom: 12px;
}

.planner-summary strong {
  color: var(--green-neon);
  font-size: 18px;
}

.planner-summary span {
  color: var(--muted);
  font-size: 13px;
}

.planner-missing {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}

.planner-missing div {
  border-radius: 12px;
  background: rgba(4, 13, 7, 0.84);
  padding: 10px;
}

.planner-missing strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 20px;
}

@media (max-width: 1180px) {
  .production-hero-grid {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }

  .production-stock-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .production-hero-grid,
  .recipe-box,
  .production-stock-grid,
  .planner-missing {
    grid-template-columns: 1fr;
  }
}

/* ========================
   V12 - Ajuste de fonte + descarte de estoque
======================== */
.page-admin h1 {
  font-size: clamp(34px, 4.2vw, 54px);
}

.page-admin .subtitle {
  font-size: 15px;
}

.page-admin .stat-card strong {
  font-size: 24px;
}

.page-admin .card {
  padding: 18px;
}

.page-admin .section-title span {
  font-size: 16px;
}

.page-admin .section-title small,
.production-main-card small,
.production-info-card small,
.stock-card small,
.balance-row small,
.planner-summary span {
  font-size: 12px;
}

.production-main-card strong {
  font-size: clamp(36px, 4.2vw, 58px);
}

.production-info-card strong {
  font-size: 28px;
}

.recipe-box strong {
  font-size: 16px;
}

.stock-card strong {
  font-size: 25px;
}

.leftover-item strong,
.planner-missing strong {
  font-size: 18px;
}

.admin-tabs .tab-btn,
.btn,
.admin-link {
  font-size: 14px;
}

.production-hero-grid {
  grid-template-columns: minmax(260px, 1.45fr) repeat(3, minmax(170px, 1fr));
}

.production-layout {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 360px);
}

.discard-form {
  display: grid;
  gap: 12px;
}

.discard-form input,
.discard-grid input {
  width: 100%;
  min-height: 46px;
  border: 1px solid rgba(120, 185, 87, 0.34);
  border-radius: 14px;
  outline: 0;
  background: var(--field);
  color: var(--text);
  padding: 0 12px;
  box-shadow: inset 0 0 18px rgba(0,0,0,.28);
}

.discard-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.discard-grid label {
  display: grid;
  gap: 7px;
  color: var(--green-light);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.discard-grid input {
  text-align: center;
  font-size: 18px;
  font-weight: 900;
}

.discard-list {
  display: grid;
  gap: 10px;
}

.discard-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  padding: 11px;
  background: rgba(2, 8, 4, .48);
}

.discard-item strong {
  display: block;
  font-size: 14px;
  color: var(--text);
}

.discard-item small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 11px;
}

.discard-materials {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-top: 7px;
}

.discard-materials span {
  padding: 4px 6px;
  border-radius: 999px;
  background: rgba(4, 13, 7, .9);
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
}

.compact-title {
  margin-top: 16px;
  margin-bottom: 10px;
}

.compact-empty {
  padding: 14px;
  font-size: 12px;
}

@media (max-width: 1180px) {
  .production-layout,
  .production-hero-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 760px) {
  .production-layout,
  .production-hero-grid,
  .discard-grid,
  .discard-item {
    grid-template-columns: 1fr;
  }
}

/* =====================================================
   V13 - EXTRATO DA FAMÍLIA
===================================================== */

.member-tabs{
    display:flex;
    gap:12px;
    margin-bottom:20px;
}

.member-tab{
    flex:1;
    padding:16px;
    border:none;
    border-radius:16px;
    background:#1b241d;
    color:#c7d8c8;
    font-weight:700;
    cursor:pointer;
    transition:.25s;
}

.member-tab:hover{
    background:#2d4532;
}

.member-tab.active{
    background:#3f6e46;
    color:#fff;
}

.member-tab-panel{
    display:none;
}

.member-tab-panel.active{
    display:block;
}

.member-extract-layout{
    display:grid;
    grid-template-columns:2fr 1fr;
    gap:20px;
}

.extract-highlight-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:15px;
    margin-bottom:20px;
}

.extract-big-card{
    background:#172419;
    border:1px solid rgba(110,180,120,.25);
    border-radius:18px;
    padding:20px;
    text-align:center;
}

.extract-big-card span{
    display:block;
    color:#8fb28f;
    font-size:13px;
}

.extract-big-card strong{
    display:block;
    margin:12px 0;
    font-size:34px;
    color:#7dce7d;
}

.extract-big-card small{
    color:#b7c5b8;
}

.public-ranking-list{
    display:flex;
    flex-direction:column;
    gap:12px;
}

.public-ranking-item{
    display:flex;
    justify-content:space-between;
    align-items:center;
    background:#111916;
    border:1px solid rgba(90,160,90,.18);
    border-radius:14px;
    padding:16px;
}

.public-ranking-left{
    display:flex;
    gap:15px;
    align-items:center;
}

.public-ranking-position{

    width:42px;
    height:42px;

    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    font-weight:bold;

    background:#335f36;
}

.public-ranking-info strong{

    display:block;
    font-size:17px;
}

.public-ranking-info small{

    color:#9eb69f;
}

.public-ranking-total{

    font-size:24px;
    font-weight:bold;
    color:#7ad57a;
}

.my-position-card{

    margin-top:15px;

    background:#111916;

    border-radius:16px;

    padding:22px;

    text-align:center;
}

.my-position-card h2{

    margin:0;

    color:#7ad57a;

    font-size:40px;
}

.my-position-card h3{

    margin:8px 0;

    font-size:22px;
}

.my-position-card p{

    margin:6px 0;
}

.personal-history-list{

    margin-top:15px;

    display:flex;

    flex-direction:column;

    gap:10px;
}

.personal-history-item{

    display:flex;

    justify-content:space-between;

    padding:12px;

    background:#121c15;

    border-radius:12px;
}

.compact-title{

    margin-top:25px;
}

@media(max-width:900px){

.member-extract-layout{

grid-template-columns:1fr;

}

.extract-highlight-grid{

grid-template-columns:1fr;

}

}
/* =========================
   V15 - Login Cloudflare
========================= */
.admin-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.admin-logout {
  border-color: rgba(184, 67, 67, 0.45);
  background: rgba(184, 67, 67, 0.14);
  color: #ffd1d1;
}

.login-shell {
  width: min(100%, 720px);
}

.login-hero {
  justify-content: center;
  text-align: center;
}

.login-card {
  max-width: 560px;
  margin: 0 auto;
}

@media (max-width: 760px) {
  .admin-actions {
    justify-content: flex-start;
  }
}
