/* Dashboard (dashboard.html). */

#hero-counter {
  width: 100%;
  align-self: stretch;
  box-sizing: border-box;
}

/* ——— Dashboard modo TV (preview=tv) ——— */

.dashboard-tv-preview > main {
  visibility: hidden;
  pointer-events: none;
}

.dashboard-tv-preview > header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 2147483647;
  visibility: visible;
  pointer-events: none;
  background: transparent;
  border: none;
  box-shadow: none;
}

.dashboard-tv-preview > header .container-fluid {
  justify-content: flex-end;
  padding: clamp(0.75rem, 2vw, 1.25rem) clamp(1rem, 3vw, 1.75rem);
  pointer-events: none;
}

.dashboard-tv-preview > header .header-logo,
.dashboard-tv-preview > header .vr,
.dashboard-tv-preview > header h1,
.dashboard-tv-preview > header #clock-text {
  display: none !important;
}

.dashboard-tv-preview > header .header-nav {
  pointer-events: auto;
}

.dashboard-tv-preview > header .header-nav__menu {
  z-index: 2147483647;
}

.dashboard-tv-preview #record-fx-flash {
  z-index: 2147483646;
}

.dashboard-tv-preview .record-confetti-layer {
  z-index: 2147483646;
}

.tv-preview-overlay--record-burst .tv-preview-overlay__counter {
  animation: record-counter-mega 2.35s cubic-bezier(0.33, 1, 0.32, 1) both;
}

.tv-preview-overlay--record-burst .tv-preview-overlay__glow {
  animation: tv-preview-glow-burst 4.2s ease-in-out 2;
}

@keyframes tv-preview-glow-burst {
  0%,
  100% {
    opacity: 0.85;
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(1.08);
  }
}

.tv-preview-overlay {
  position: fixed;
  inset: 0;
  z-index: 2147483646;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(1rem, 4vw, 3rem);
  box-sizing: border-box;
  background:
    radial-gradient(ellipse 80% 55% at 50% 38%, hsl(37 100% 59% / 0.14), transparent 62%),
    radial-gradient(ellipse 100% 80% at 50% 100%, hsl(268 45% 22% / 0.9), transparent 55%),
    hsl(268 32% 8% / 0.98);
  overflow: hidden;
}

.tv-preview-overlay[hidden] {
  display: none !important;
}

.tv-preview-overlay__glow {
  position: absolute;
  inset: -20%;
  background: radial-gradient(circle at 50% 42%, hsl(37 100% 59% / 0.22), transparent 48%);
  pointer-events: none;
  animation: tv-preview-glow-pulse 4s ease-in-out infinite;
}

.tv-preview-overlay--achieved .tv-preview-overlay__glow {
  background: radial-gradient(circle at 50% 42%, hsl(142 70% 45% / 0.28), transparent 50%);
}

@keyframes tv-preview-glow-pulse {
  0%,
  100% {
    opacity: 0.75;
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(1.04);
  }
}

.tv-preview-overlay__content {
  position: relative;
  z-index: 1;
  width: min(100%, 72rem);
  text-align: center;
}

.tv-preview-overlay__label {
  margin: 0 0 clamp(0.75rem, 2vw, 1.5rem);
  font-size: clamp(0.875rem, 2.2vw, 1.35rem);
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--table-muted);
}

.tv-preview-overlay--achieved .tv-preview-overlay__label {
  color: var(--success, hsl(142 65% 52%));
}

.tv-preview-overlay__counter {
  margin: 0;
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-size: clamp(6rem, 24vw, 16rem);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.04em;
  color: var(--primary);
  text-shadow:
    0 0 40px hsl(37 100% 59% / 0.45),
    0 0 120px hsl(37 100% 59% / 0.2);
  transform-origin: center center;
}

.tv-preview-overlay--achieved .tv-preview-overlay__counter {
  color: hsl(142 70% 55%);
  text-shadow:
    0 0 48px hsl(142 70% 45% / 0.5),
    0 0 140px hsl(142 70% 45% / 0.25);
}

.tv-preview-overlay__counter--tick {
  animation: tv-preview-counter-tick 0.85s cubic-bezier(0.33, 1, 0.32, 1) both;
}

@keyframes tv-preview-counter-tick {
  0% {
    transform: scale(1);
  }
  35% {
    transform: scale(1.06);
  }
  100% {
    transform: scale(1);
  }
}

.tv-preview-overlay__progress-wrap {
  position: relative;
  max-width: 40rem;
  margin: clamp(1.25rem, 4vw, 2.5rem) auto 0;
}

.tv-preview-overlay__progress {
  height: clamp(0.75rem, 2vw, 1.25rem);
  border-radius: 999px;
  background: hsl(268 20% 18% / 0.9);
}

.tv-preview-overlay__pct {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: clamp(0.75rem, 1.8vw, 1rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg);
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.65);
  pointer-events: none;
}

.tv-preview-overlay__meta {
  margin: clamp(0.75rem, 2.5vw, 1.25rem) 0 0;
  font-size: clamp(0.875rem, 2vw, 1.125rem);
  color: var(--table-muted);
}

.tv-preview-overlay__meta strong {
  color: var(--fg);
  font-weight: 700;
}

.tv-preview-overlay__message {
  margin: clamp(0.75rem, 2.5vw, 1.5rem) 0 0;
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-size: clamp(1rem, 2.8vw, 1.75rem);
  font-weight: 700;
  line-height: 1.35;
  color: var(--primary);
}

.tv-preview-overlay__message--success {
  color: hsl(142 70% 55%);
}

.tv-preview-overlay__message--pulse {
  animation: tv-preview-message-pulse 2s ease-in-out infinite;
}

@keyframes tv-preview-message-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.72;
  }
}

.counter-text {
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-size: clamp(5rem, 14vw, 10rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--primary);
  display: block;
  width: 100%;
  min-height: 1em;
  transform-origin: center center;
}

@media (min-width: 768px) {
  .counter-text {
    font-size: clamp(7rem, 12vw, 10rem);
  }
}
.mesa-flag {
  display: block;
  width: 2rem;
  height: auto;
  max-height: 1.375rem;
  margin: 0 auto 0.25rem;
  object-fit: contain;
}

.mesa-flag-placeholder {
  display: block;
  margin-bottom: 0.25rem;
  line-height: 1.375rem;
}
.mesa-cell {
  border-radius: 0.5rem;
  padding: 0.5rem;
  text-align: center;
  border: 1px solid color-mix(in srgb, var(--border) 45%, transparent);
  background: color-mix(in srgb, var(--secondary-bg) 40%, transparent);
}

a.mesa-cell {
  display: block;
  text-decoration: none;
  color: inherit;
  transition:
    border-color 0.2s ease,
    background-color 0.2s ease;
}

a.mesa-cell:hover {
  border-color: color-mix(in srgb, var(--primary) 50%, var(--border));
  background: color-mix(in srgb, var(--primary) 10%, var(--secondary-bg));
}

a.mesa-cell:focus-visible {
  outline: 2px solid hsl(37 100% 59% / 0.45);
  outline-offset: 2px;
}

.feed-row {
  background: color-mix(in srgb, var(--secondary-bg) 50%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 30%, transparent);
}

.feed-row--trade {
  background: color-mix(in srgb, var(--secondary-bg) 30%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 20%, transparent);
}

.trade-feed-row {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
}

.trade-feed-row__icon {
  flex-shrink: 0;
  margin-top: 0.1rem;
}

.trade-feed-row__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 0.75rem;
}

.trade-feed-row__main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  min-width: 0;
  flex: 1 1 10rem;
}

.trade-feed-row__name {
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--fg);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.trade-feed-row__name--mobile {
  display: none;
}

.trade-feed-row__badge {
  flex-shrink: 0;
  font-size: 0.7rem;
  background: hsl(37 100% 59% / 0.15) !important;
  color: var(--primary) !important;
}

.trade-feed-row__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.5rem 0.75rem;
  flex-shrink: 0;
}

.trade-feed-row__sticker {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--fg);
}

.trade-feed-row__time {
  font-size: 0.75rem;
  color: var(--table-muted);
  white-space: nowrap;
}

@media (max-width: 575.98px) {
  .trade-feed-row__body {
    flex-direction: column;
    align-items: stretch;
    gap: 0.4rem;
  }

  .trade-feed-row__main {
    flex: 1 1 auto;
    width: 100%;
  }

  .trade-feed-row__meta {
    width: 100%;
    justify-content: space-between;
  }

  .trade-feed-row__name {
    max-width: 100%;
  }

  .trade-feed-row__name--desktop {
    display: none;
  }

  .trade-feed-row__name--mobile {
    display: inline;
  }
}

@keyframes pulse-glow {
  0%,
  100% {
    box-shadow: 0 0 30px hsl(37 100% 59% / 0.15);
  }
  50% {
    box-shadow:
      0 0 60px hsl(37 100% 59% / 0.35),
      0 0 120px hsl(37 100% 59% / 0.1);
  }
}

.animate-pulse-glow {
  animation: pulse-glow 2s ease-in-out infinite;
}

@keyframes slide-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-slide-in {
  animation: slide-in 0.3s ease-out forwards;
}

@keyframes count-pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.02);
  }
  100% {
    transform: scale(1);
  }
}

.animate-count-pulse {
  animation: count-pulse 2s ease-in-out infinite;
}
.progress-counter {
  height: 1.25rem;
  background: var(--secondary-bg);
  border-radius: 9999px;
  overflow: hidden;
}

#tv-preview-progress-bar {
  background: var(--primary) !important;
  transition: width 1s ease;
}

.tv-preview-overlay--achieved #tv-preview-progress-bar {
  background: hsl(142 70% 55%) !important;
  transition: width 1s ease;
}

.progress-counter .progress-bar {
  background: var(--primary);
  transition: width 1s ease;
}

.progress-counter-label {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--primary-fg);
  text-shadow: 0 0 2px rgba(0, 0, 0, 0.4);
  z-index: 1;
  pointer-events: none;
}

@keyframes subtle-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.65;
  }
}

.animate-pulse-custom {
  animation: subtle-pulse 1.5s ease-in-out infinite;
}

.chart-grid line {
  stroke: var(--border);
  stroke-dasharray: 3 3;
}

.chart-axis {
  fill: var(--muted);
  font-family: Inter, system-ui, sans-serif;
}

/* Eixos do gráfico “Evolução do Recorde” — alinhado ao layout base (legível, não micro) */
#evolution-chart .chart-axis--y {
  font-size: 12px;
  font-weight: 500;
}

#evolution-chart .chart-axis--x {
  font-size: 11px;
  font-weight: 500;
}

@media (min-width: 768px) {
  #evolution-chart .chart-axis--x {
    font-size: 12px;
  }
}

#evolution-chart {
  width: 100%;
  min-width: 0;
  overflow: visible;
}

#evolution-chart svg {
  display: block;
  width: 100%;
  max-width: 100%;
  height: 17rem;
}

.chart-wrap {
  position: relative;
  width: 100%;
  min-width: 0;
  overflow: visible;
}

.chart-tooltip {
  position: absolute;
  z-index: 2;
  pointer-events: none;
  min-width: 7rem;
  padding: 0.5rem 0.65rem;
  border-radius: 0.5rem;
  background: hsl(268 25% 16%);
  border: 1px solid hsl(268 15% 28%);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  font-family: Inter, system-ui, sans-serif;
  font-size: 0.8125rem;
  line-height: 1.35;
  color: var(--primary);
  white-space: nowrap;
}

.chart-tooltip.is-hidden {
  opacity: 0;
  visibility: hidden;
}

.chart-tooltip__time {
  font-weight: 600;
  margin-bottom: 0.15rem;
}

.chart-tooltip__value {
  font-weight: 500;
}

.chart-crosshair {
  stroke: hsl(45 10% 88%);
  stroke-width: 1;
  opacity: 0.85;
  pointer-events: none;
}

.chart-hover-dot {
  pointer-events: none;
  fill: hsl(45 10% 96%);
  stroke: hsl(37 100% 59%);
  stroke-width: 2;
}

.mesa-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
}

@media (min-width: 576px) {
  .mesa-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (min-width: 667px) {
  .mesa-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (min-width: 992px) {
  .mesa-grid {
    grid-template-columns: repeat(8, minmax(0, 1fr));
  }
}
/* —— Momento da virada (recorde Guinness / 5.000 trocas) — ritmo suave —— */
#page_main.is-screen-shake,
.tv-preview-overlay.is-screen-shake {
  animation: record-screen-shake 1.25s ease-in-out both;
}

@keyframes record-screen-shake {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  25% {
    transform: translate3d(-2px, 1px, 0);
  }
  50% {
    transform: translate3d(2px, -1px, 0);
  }
  75% {
    transform: translate3d(-1px, 0, 0);
  }
}

.record-fx-flash {
  position: fixed;
  inset: 0;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  max-width: 100%;
  z-index: 9996;
  pointer-events: none;
  opacity: 0;
  overflow: hidden;
  clip-path: inset(0);
  background: radial-gradient(
    circle at 50% 38%,
    hsl(45 95% 70% / 0.38) 0%,
    hsl(37 90% 52% / 0.18) 42%,
    transparent 72%
  );
  transition: none;
}

.record-fx-flash.is-active {
  animation: record-gold-flash 2.5s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes record-gold-flash {
  0% {
    opacity: 0;
  }
  22% {
    opacity: 0.45;
  }
  45% {
    opacity: 0.32;
  }
  100% {
    opacity: 0;
  }
}

#hero-counter.hero-record-burst {
  width: 100%;
  animation: record-hero-burst-glow 4.2s ease-in-out 2;
}

@keyframes record-hero-burst-glow {
  0%,
  100% {
    box-shadow:
      0 0 36px hsl(37 100% 59% / 0.28),
      0 0 90px hsl(45 100% 55% / 0.12);
  }
  50% {
    box-shadow:
      0 0 52px hsl(37 100% 59% / 0.38),
      0 0 120px hsl(45 90% 58% / 0.2),
      0 0 160px hsl(37 100% 50% / 0.08);
  }
}

.counter-text.counter-mega-pop,
.tv-preview-overlay__counter.counter-mega-pop {
  animation: record-counter-mega 2.35s cubic-bezier(0.33, 1, 0.32, 1) both;
  color: hsl(45 95% 60%);
  text-shadow:
    0 0 16px hsl(37 100% 50% / 0.35),
    0 0 40px hsl(37 100% 55% / 0.2);
}

@keyframes record-counter-mega {
  0% {
    transform: scale(1);
    opacity: 1;
    filter: none;
  }
  35% {
    transform: scale(1.035);
    opacity: 1;
    filter: drop-shadow(0 0 24px hsl(37 100% 55% / 0.45));
  }
  70% {
    transform: scale(1.01);
  }
  100% {
    transform: scale(1);
    opacity: 1;
    filter: none;
  }
}

.record-confetti-layer {
  position: fixed;
  inset: 0;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  max-width: 100%;
  z-index: 9997;
  pointer-events: none;
  overflow: hidden;
  clip-path: inset(0);
  contain: strict;
}

.record-confetti-layer .confetti-bit {
  position: absolute;
  width: 8px;
  height: 12px;
  border-radius: 2px;
  margin-left: -4px;
  margin-top: -6px;
  opacity: 1;
  animation: confetti-pop 2.15s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

@keyframes confetti-pop {
  0% {
    transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
    opacity: 1;
  }
  70% {
    opacity: 0.85;
  }
  100% {
    transform: translate3d(var(--confetti-tx), var(--confetti-ty), 0) rotate(var(--confetti-rot)) scale(0.45);
    opacity: 0;
  }
}
