/* ──────────────────────────────────────────────────────────
   NR1-X · COMPONENTES (refinados, mais leves, mais sérios)
   ────────────────────────────────────────────────────────── */

/* ═══════════════ BOTÕES ═══════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s2);
  height: 44px;
  padding: 0 var(--s5);
  border-radius: var(--r-sm);
  font-weight: var(--w-medium);
  font-size: 14px;
  letter-spacing: -0.005em;
  transition: transform 200ms var(--ease-out), background 200ms var(--ease-out), box-shadow 240ms var(--ease-out), opacity 200ms var(--ease-out), color 200ms var(--ease-out);
  white-space: nowrap;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  position: relative; overflow: hidden;
}
.btn:active { transform: scale(0.97); }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }

.btn-primary { background: var(--roxo); color: var(--branco); }
.btn-primary:hover { background: #5E125E; box-shadow: var(--el-roxo); }

.btn-secondary { background: var(--surface-soft); color: var(--cinza); }
.btn-secondary:hover { background: var(--surface-line); }

.btn-amarelo { background: var(--amarelo); color: var(--cinza); font-weight: var(--w-semi); }
.btn-amarelo:hover { background: #ECC400; box-shadow: 0 12px 24px rgba(255,212,0,0.35); }

.btn-dark { background: var(--cinza); color: var(--branco); }
.btn-dark:hover { background: #1A1A1A; }

.btn-ghost { background: transparent; color: var(--cinza); }
.btn-ghost:hover { background: var(--surface-soft); }

.btn-on-roxo { background: rgba(255,255,255,0.12); color: var(--branco); }
.btn-on-roxo:hover { background: rgba(255,255,255,0.22); }

.btn-full { width: 100%; }
.btn-sm { height: 36px; padding: 0 var(--s4); font-size: 13px; border-radius: var(--r-xs); }
.btn-lg { height: 52px; padding: 0 var(--s6); font-size: 15px; }

.btn-square { width: 44px; height: 44px; padding: 0; }

/* ═══════════════ CARDS ═══════════════ */
.card {
  background: var(--branco);
  border-radius: var(--r-lg);
  padding: var(--s6);
  box-shadow: var(--el-1);
}
.card-soft {
  background: var(--surface-soft);
  border-radius: var(--r-lg);
  padding: var(--s6);
}
.card-roxo {
  background: var(--roxo);
  color: var(--branco);
  border-radius: var(--r-lg);
  padding: var(--s6);
}
.card-amarelo {
  background: var(--amarelo);
  color: var(--cinza);
  border-radius: var(--r-lg);
  padding: var(--s6);
}
.card-dark {
  background: var(--cinza);
  color: var(--branco);
  border-radius: var(--r-lg);
  padding: var(--s6);
}

.card-title {
  font-size: 17px;
  font-weight: var(--w-medium);
  color: var(--cinza);
  margin-bottom: var(--s1);
  letter-spacing: -0.01em;
}
.card-roxo .card-title, .card-dark .card-title { color: var(--branco); }
.card-amarelo .card-title { color: var(--cinza); }

.card-sub {
  font-size: 13px;
  color: var(--cinza);
  opacity: 0.55;
  font-weight: var(--w-regular);
}
.card-roxo .card-sub, .card-dark .card-sub { color: rgba(255,255,255,0.65); opacity: 1; }

/* ═══════════════ BADGES (cores fortes, NUNCA pasteis) ═══════════════ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s1);
  height: 22px;
  padding: 0 10px;
  border-radius: var(--r-full);
  font-size: 11px;
  font-weight: var(--w-semi);
  letter-spacing: 0;
  color: var(--branco);
}
.badge-azul     { background: var(--azul); }
.badge-laranja  { background: var(--laranja); }
.badge-vermelho { background: var(--vermelho); }
.badge-roxo     { background: var(--roxo); }
.badge-amarelo  { background: var(--amarelo); color: var(--cinza); }
.badge-dark     { background: var(--cinza); color: var(--branco); }

.badge-dot {
  width: 6px; height: 6px; border-radius: 50%;
  display: inline-block;
}

/* ═══════════════ AVATAR ═══════════════ */
.avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--roxo);
  color: var(--branco);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--w-medium);
  font-size: 13px;
  letter-spacing: 0;
  flex-shrink: 0;
}
.avatar-sm { width: 28px; height: 28px; font-size: 11px; }
.avatar-lg { width: 60px; height: 60px; font-size: 18px; }
.avatar-amarelo { background: var(--amarelo); color: var(--cinza); }
.avatar-dark    { background: var(--cinza); color: var(--branco); }
.avatar-soft    { background: var(--surface-soft); color: var(--cinza); }

/* ═══════════════ FORMS ═══════════════ */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--s2);
}
.field-label {
  font-size: 11px;
  font-weight: var(--w-medium);
  color: var(--cinza);
  opacity: 0.65;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.field-input,
.field-select,
.field-textarea {
  height: 44px;
  background: var(--surface-soft);
  border-radius: var(--r-sm);
  padding: 0 var(--s4);
  font-size: 14px;
  color: var(--cinza);
  font-weight: var(--w-regular);
  transition: background 200ms var(--ease-out), box-shadow 200ms var(--ease-out);
  width: 100%;
}
.field-textarea {
  height: auto;
  padding: var(--s4);
  min-height: 96px;
  resize: vertical;
  font-family: inherit;
}
.field-input:focus,
.field-select:focus,
.field-textarea:focus {
  background: var(--branco);
  box-shadow: 0 0 0 2px var(--roxo);
}
.field-input::placeholder, .field-textarea::placeholder {
  color: var(--cinza); opacity: 0.35;
}

.field-input.on-roxo, .field-select.on-roxo {
  background: rgba(255,255,255,0.12);
  color: var(--branco);
}
.field-input.on-roxo::placeholder { color: rgba(255,255,255,0.55); }
.field-input.on-roxo:focus { background: rgba(255,255,255,0.22); box-shadow: 0 0 0 2px var(--amarelo); }

/* search-input */
.search-box {
  position: relative;
  display: flex; align-items: center;
}
.search-box svg { position: absolute; left: 14px; color: var(--cinza); opacity: 0.4; }
.search-box input { padding-left: 42px; }

/* ═══════════════ TABLE ═══════════════ */
.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 14px;
}
.table thead th {
  text-align: left;
  font-weight: var(--w-medium);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cinza);
  opacity: 0.45;
  padding: var(--s4) var(--s4);
  background: var(--branco);
}
.table tbody td {
  padding: var(--s4);
  color: var(--cinza);
  vertical-align: middle;
  font-weight: var(--w-regular);
}
.table tbody tr { transition: background 160ms ease-out; }
.table tbody tr:hover td { background: var(--surface-soft); }
.table tbody tr td:first-child { border-top-left-radius: var(--r-xs); border-bottom-left-radius: var(--r-xs); }
.table tbody tr td:last-child  { border-top-right-radius: var(--r-xs); border-bottom-right-radius: var(--r-xs); }
.table tbody tr + tr td { box-shadow: inset 0 1px 0 var(--surface-soft); }

/* ═══════════════ PROGRESS BAR ═══════════════ */
.prog {
  height: 6px;
  background: var(--surface-soft);
  border-radius: var(--r-full);
  overflow: hidden;
  width: 100%;
}
.prog-fill {
  height: 100%;
  background: var(--roxo);
  border-radius: var(--r-full);
  transition: width 900ms var(--ease-out);
}
.prog-fill.amarelo { background: var(--amarelo); }
.prog-fill.azul { background: var(--azul); }
.prog-fill.vermelho { background: var(--vermelho); }

.prog.on-roxo { background: rgba(255,255,255,0.18); }
.prog.on-roxo .prog-fill { background: var(--amarelo); }

/* ═══════════════ TOAST ═══════════════ */
.toast-stack {
  position: fixed;
  bottom: calc(var(--footer-h) + var(--s5));
  right: var(--s6);
  display: flex;
  flex-direction: column;
  gap: var(--s2);
  z-index: 9999;
  pointer-events: none;
  align-items: flex-end;
}
@media(max-width: 768px) {
  .toast-stack { right: var(--s4); left: var(--s4); bottom: calc(var(--footer-h) + var(--s4)); }
}
.toast {
  pointer-events: auto;
  background: var(--cinza);
  color: var(--branco);
  padding: var(--s3) var(--s5);
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: var(--w-medium);
  box-shadow: var(--el-3);
  display: flex;
  align-items: center;
  gap: var(--s3);
  max-width: 380px;
  min-width: 240px;
  animation: toast-in 360ms cubic-bezier(0.34,1.56,0.64,1) both;
}
.toast.removing { animation: toast-out 220ms cubic-bezier(0.65,0,0.35,1) forwards; }
.toast.success { background: var(--azul); }
.toast.warning { background: var(--laranja); }
.toast.error   { background: var(--vermelho); }

@keyframes toast-in {
  from { transform: translateY(20px) scale(0.95); opacity: 0; }
  to   { transform: translateY(0) scale(1); opacity: 1; }
}
@keyframes toast-out {
  to { transform: translateY(10px) scale(0.95); opacity: 0; }
}

/* ═══════════════ MODAL ═══════════════ */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(43,43,43,0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  padding: var(--s5);
  animation: fade-in 220ms ease-out;
}
.modal-overlay.open { display: flex; }
.modal {
  background: var(--branco);
  border-radius: var(--r-xl);
  padding: var(--s7);
  max-width: 480px;
  width: 100%;
  box-shadow: var(--el-3);
  animation: modal-pop 320ms cubic-bezier(0.34,1.56,0.64,1);
}
.modal-title {
  font-size: 22px;
  font-weight: var(--w-medium);
  color: var(--cinza);
  margin-bottom: var(--s2);
  letter-spacing: -0.015em;
}
.modal-sub { font-size: 14px; color: var(--cinza); opacity: 0.6; margin-bottom: var(--s6); }
.modal-actions { display: flex; gap: var(--s3); margin-top: var(--s6); }

@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes modal-pop {
  from { transform: translateY(20px) scale(0.96); opacity: 0; }
  to   { transform: translateY(0) scale(1); opacity: 1; }
}

/* ═══════════════ CHIP / SEGMENTED ═══════════════ */
.chips { display: flex; gap: var(--s2); flex-wrap: wrap; }
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--s2);
  height: 34px;
  padding: 0 var(--s4);
  border-radius: var(--r-full);
  font-size: 13px;
  font-weight: var(--w-medium);
  color: var(--cinza);
  background: var(--surface-soft);
  cursor: pointer;
  transition: all 220ms var(--ease-out);
  user-select: none;
  opacity: 0.7;
}
.chip:hover { background: var(--surface-line); opacity: 1; }
.chip.active {
  background: var(--roxo);
  color: var(--branco);
  opacity: 1;
}
.chip-count {
  background: rgba(0,0,0,0.08);
  border-radius: var(--r-full);
  padding: 1px 8px;
  font-size: 10px;
  font-weight: var(--w-semi);
  font-variant-numeric: tabular-nums;
}
.chip.active .chip-count { background: rgba(255,255,255,0.22); }

/* ═══════════════ APP SHELL · SIDEBAR (DESKTOP) ═══════════════ */
.app-shell {
  display: flex;
  min-height: 100vh;
  background: var(--branco);
}
.sidebar {
  width: var(--sidebar-w);
  background: var(--roxo);
  color: var(--branco);
  flex-shrink: 0;
  padding: var(--s6) var(--s4);
  display: flex;
  flex-direction: column;
  gap: var(--s5);
  transition: width 320ms var(--ease-out);
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
}
.sidebar.collapsed { width: var(--sidebar-w-collapsed); }

.sidebar-header {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: 0 var(--s2);
  height: 40px;
}
.sidebar-header .nrx-lockup-text { color: var(--branco); }
.sidebar-header .nrx-lockup-mark { background: var(--amarelo); color: var(--roxo); }
.sidebar-header .nrx-lockup-mark::before { content: 'X'; color: var(--roxo); }
.sidebar.collapsed .nrx-lockup-text { opacity: 0; pointer-events: none; }

.sidebar-toggle {
  position: absolute;
  top: 24px; right: 14px;
  width: 28px; height: 28px;
  background: rgba(255,255,255,0.10);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--branco);
  cursor: pointer;
  transition: background 180ms ease-out, transform 360ms var(--ease-out);
}
.sidebar-toggle:hover { background: rgba(255,255,255,0.22); }
.sidebar.collapsed .sidebar-toggle { transform: rotate(180deg); right: 22px; }

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: var(--s4);
}
.sidebar-nav-section {
  font-size: 9px;
  font-weight: var(--w-semi);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.42);
  padding: var(--s4) var(--s3) var(--s2);
  transition: opacity 200ms ease-out;
}
.sidebar.collapsed .sidebar-nav-section { opacity: 0; }

.nav-item {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: 10px var(--s3);
  border-radius: var(--r-sm);
  color: rgba(255,255,255,0.72);
  font-size: 13.5px;
  font-weight: var(--w-medium);
  cursor: pointer;
  transition: background 220ms var(--ease-out), color 200ms ease-out, transform 280ms var(--ease-out);
  position: relative;
  overflow: hidden;
  white-space: nowrap;
}
.nav-item:hover {
  background: rgba(255,255,255,0.08);
  color: var(--branco);
}
.nav-item.active {
  background: var(--amarelo);
  color: var(--roxo);
  font-weight: var(--w-semi);
}
.nav-item svg { width: 18px; height: 18px; flex-shrink: 0; stroke-width: 1.75; }
.nav-item .label { transition: opacity 200ms ease-out; }
.sidebar.collapsed .nav-item .label,
.sidebar.collapsed .nav-item .nav-badge { opacity: 0; }
.nav-badge {
  margin-left: auto;
  background: rgba(255,255,255,0.14);
  color: var(--branco);
  font-size: 10px;
  font-weight: var(--w-semi);
  padding: 1px 8px;
  border-radius: var(--r-full);
  transition: opacity 200ms ease-out;
  font-variant-numeric: tabular-nums;
}
.nav-item.active .nav-badge { background: var(--roxo); color: var(--amarelo); }

.sidebar-footer-user {
  margin-top: auto;
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: var(--s3);
  border-radius: var(--r-sm);
  background: rgba(255,255,255,0.06);
  transition: padding 200ms ease-out;
}
.sidebar.collapsed .sidebar-footer-user { padding: var(--s2); }
.sidebar-footer-user .user-info { transition: opacity 200ms ease-out; }
.sidebar.collapsed .user-info { opacity: 0; pointer-events: none; }
.user-name { font-size: 13px; font-weight: var(--w-medium); color: var(--branco); }
.user-role { font-size: 11px; color: rgba(255,255,255,0.55); }

/* App main */
.app-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.app-topbar {
  height: var(--header-h);
  background: var(--branco);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--s6);
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: 0 1px 0 var(--surface-soft);
}
.app-content {
  flex: 1;
  padding: var(--s7) var(--s8);
  background: var(--branco);
}

/* ═══════════════ MOBILE BOTTOM NAV ═══════════════ */
.mobile-footer {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: var(--footer-h);
  background: var(--branco);
  display: flex;
  align-items: center;
  justify-content: space-around;
  padding: 0 var(--s4);
  box-shadow: 0 -2px 18px rgba(0,0,0,0.06);
  z-index: 100;
}
.mobile-footer-item {
  width: 44px; height: 44px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--cinza);
  opacity: 0.45;
  cursor: pointer;
  transition: all 260ms var(--ease-spring);
  position: relative;
}
.mobile-footer-item:hover { opacity: 0.85; }
.mobile-footer-item.active {
  opacity: 1;
  background: var(--roxo);
  color: var(--branco);
  transform: scale(1.08);
}
.mobile-footer-item svg { width: 20px; height: 20px; stroke-width: 1.75; }
.mobile-footer-brand {
  font-size: 8px;
  font-weight: var(--w-medium);
  color: var(--cinza);
  opacity: 0.35;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ═══════════════ FOOTER "Powered by Beews" ═══════════════ */
.beews-footer {
  text-align: center;
  font-size: 9px;
  font-weight: var(--w-medium);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cinza);
  opacity: 0.35;
  padding: var(--s5) 0 var(--s4);
}
.beews-footer strong { font-weight: var(--w-semi); color: var(--roxo); opacity: 0.8; }
.beews-footer.on-dark { color: rgba(255,255,255,0.45); }
.beews-footer.on-dark strong { color: var(--amarelo); opacity: 1; }

/* ═══════════════ ICON BUTTON ═══════════════ */
.icon-btn {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent;
  color: var(--cinza);
  cursor: pointer;
  transition: background 200ms ease-out, transform 200ms ease-out;
}
.icon-btn:hover { background: var(--surface-soft); }
.icon-btn:active { transform: scale(0.92); }
.icon-btn.on-roxo { color: var(--branco); }
.icon-btn.on-roxo:hover { background: rgba(255,255,255,0.14); }

/* ═══════════════ STAT TILE (refinada — SEM trend pill) ═══════════════ */
.stat {
  background: var(--branco);
  padding: var(--s6);
  border-radius: var(--r-lg);
  box-shadow: var(--el-1);
  transition: transform 280ms var(--ease-spring), box-shadow 280ms ease-out;
}
.stat:hover { transform: translateY(-3px); box-shadow: var(--el-2); }
.stat-label {
  font-size: 11px;
  font-weight: var(--w-medium);
  letter-spacing: 0.06em;
  color: var(--cinza);
  opacity: 0.45;
  text-transform: uppercase;
  margin-bottom: var(--s4);
}
.stat-value {
  font-size: 40px;
  font-weight: var(--w-light);
  color: var(--cinza);
  letter-spacing: -0.03em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.stat-sub {
  font-size: 12px;
  color: var(--cinza);
  opacity: 0.5;
  margin-top: var(--s3);
  font-weight: var(--w-regular);
}
.stat-accent {
  width: 28px; height: 2px;
  background: var(--roxo);
  border-radius: 2px;
  margin-top: var(--s4);
  transition: width 600ms var(--ease-out);
}
.stat:hover .stat-accent { width: 56px; }
.stat-accent.amarelo { background: var(--amarelo); }
.stat-accent.vermelho { background: var(--vermelho); }
.stat-accent.azul { background: var(--azul); }

/* radio / option row (used in surveys) */
.option-row {
  display: flex;
  align-items: center;
  gap: var(--s4);
  padding: var(--s4) var(--s5);
  border-radius: var(--r-sm);
  background: var(--surface-soft);
  cursor: pointer;
  transition: all 240ms var(--ease-out);
  user-select: none;
}
.option-row:hover { background: var(--surface-line); }
.option-row .opt-radio {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--branco);
  position: relative;
  flex-shrink: 0;
  transition: all 240ms var(--ease-out);
}
.option-row .opt-radio::after {
  content: '';
  position: absolute;
  inset: 6px;
  border-radius: 50%;
  background: var(--roxo);
  transform: scale(0);
  transition: transform 280ms var(--ease-spring);
}
.option-row.selected {
  background: var(--roxo);
  color: var(--branco);
}
.option-row.selected .opt-radio::after { transform: scale(1); }
.option-row .opt-label { font-size: 15px; font-weight: var(--w-regular); }
.option-row.selected .opt-label { font-weight: var(--w-medium); }
