/* ============================================================
   Painel de Vendas — tema "graphite & gold"
   ============================================================ */
:root {
  --bg:        #0e0f13;
  --bg-tint:   #14161c;
  --panel:     #171a21;
  --panel-2:   #1d212a;
  --line:      #272c37;
  --line-soft: #20242e;
  --txt:       #e8eaf0;
  --txt-dim:   #99a1b3;
  --txt-faint: #6a7180;
  --gold:      #e7b15b;
  --gold-soft: #f0c987;
  --teal:      #5fd0c5;
  --teal-soft: #8fe0d8;
  --red:       #ef6f6f;
  --green:     #74d68a;
  --radius:    16px;
  --shadow:    0 10px 40px -12px rgba(0,0,0,.6);
  --font-disp: "Fraunces", Georgia, serif;
  --font-body: "Manrope", system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background:
    radial-gradient(1200px 600px at 85% -10%, rgba(231,177,91,.08), transparent 60%),
    radial-gradient(900px 500px at 0% 0%, rgba(95,208,197,.06), transparent 55%),
    var(--bg);
  color: var(--txt);
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

.wrap { max-width: 1240px; margin: 0 auto; padding: 28px 24px 64px; }

/* ---------- Cabecalho ---------- */
header.top {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 18px; margin-bottom: 26px;
  padding-bottom: 22px; border-bottom: 1px solid var(--line-soft);
}
.brand h1 {
  font-family: var(--font-disp);
  font-weight: 600; font-size: 32px; letter-spacing: -.5px;
  line-height: 1.05;
}
.brand h1 .accent { color: var(--gold); font-style: italic; }
.brand p { color: var(--txt-faint); font-size: 13.5px; margin-top: 4px; }

.badge {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 12px; font-weight: 600; letter-spacing: .3px;
  padding: 6px 11px; border-radius: 999px;
  border: 1px solid var(--line);
}
.badge .dot { width: 7px; height: 7px; border-radius: 50%; }
.badge.demo  { color: var(--gold); background: rgba(231,177,91,.08); border-color: rgba(231,177,91,.25); }
.badge.demo .dot { background: var(--gold); box-shadow: 0 0 10px var(--gold); }
.badge.live  { color: var(--teal); background: rgba(95,208,197,.08); border-color: rgba(95,208,197,.25); }
.badge.live .dot { background: var(--teal); box-shadow: 0 0 10px var(--teal); }
.badge.err   { color: var(--red);  background: rgba(239,111,111,.08); border-color: rgba(239,111,111,.3); }
.badge.err .dot { background: var(--red); }

/* ---------- Barra de filtros ---------- */
.filters {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  background: var(--panel); border: 1px solid var(--line-soft);
  border-radius: var(--radius); padding: 14px 16px; margin-bottom: 24px;
}
.presets { display: flex; gap: 6px; flex-wrap: wrap; }
.preset {
  font: inherit; font-size: 13px; font-weight: 600; cursor: pointer;
  color: var(--txt-dim); background: transparent;
  border: 1px solid var(--line); border-radius: 9px; padding: 7px 12px;
  transition: .15s;
}
.preset:hover { color: var(--txt); border-color: var(--gold); }
.preset.active { color: var(--bg); background: var(--gold); border-color: var(--gold); }
.date-group { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.date-group label { font-size: 12px; color: var(--txt-faint); }
input[type="date"] {
  font: inherit; font-size: 13.5px; color: var(--txt);
  background: var(--panel-2); border: 1px solid var(--line);
  border-radius: 9px; padding: 7px 10px; color-scheme: dark;
}
input[type="date"]:focus { outline: none; border-color: var(--gold); }

/* ---------- KPIs ---------- */
.kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
.kpi {
  position: relative; overflow: hidden;
  background: linear-gradient(160deg, var(--panel), var(--bg-tint));
  border: 1px solid var(--line-soft); border-radius: var(--radius);
  padding: 20px 20px 18px; box-shadow: var(--shadow);
}
.kpi::after {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 3px;
  background: linear-gradient(90deg, var(--gold), transparent 70%);
  opacity: .5;
}
.kpi .label { font-size: 12px; color: var(--txt-faint); letter-spacing: .4px; text-transform: uppercase; font-weight: 600; }
.kpi .value {
  font-family: var(--font-disp); font-weight: 600; font-size: 34px;
  letter-spacing: -1px; margin-top: 10px; font-variant-numeric: tabular-nums;
}
.kpi .sub { font-size: 12.5px; color: var(--txt-dim); margin-top: 6px; }
.kpi.gold  .value { color: var(--gold-soft); }
.kpi.teal  .value { color: var(--teal-soft); }
.kpi.teal::after  { background: linear-gradient(90deg, var(--teal), transparent 70%); }

/* ---------- Paineis ---------- */
.panel {
  background: var(--panel); border: 1px solid var(--line-soft);
  border-radius: var(--radius); padding: 20px 22px; box-shadow: var(--shadow);
}
.panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; gap: 12px; flex-wrap: wrap; }
.panel-head h2 { font-family: var(--font-disp); font-weight: 600; font-size: 19px; letter-spacing: -.3px; }
.panel-head .hint { font-size: 12px; color: var(--txt-faint); }
.head-right { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.head-right .hint b { color: var(--gold-soft); font-weight: 700; }

.grid-2 { display: grid; grid-template-columns: 1fr; gap: 20px; margin-top: 22px; }
@media (min-width: 980px) { .grid-2 { grid-template-columns: 1.05fr .95fr; } }

.chart-box { position: relative; height: 300px; }
.chart-tall { height: 360px; }

/* toggle receita/qtde */
.toggle { display: inline-flex; background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px; padding: 3px; }
.toggle button {
  font: inherit; font-size: 12.5px; font-weight: 600; cursor: pointer;
  color: var(--txt-dim); background: transparent; border: 0;
  border-radius: 7px; padding: 6px 12px; transition: .15s;
}
.toggle button.active { color: var(--bg); background: var(--gold); }

/* tabela top */
table.top { width: 100%; border-collapse: collapse; margin-top: 16px; font-size: 13.5px; }
table.top th, table.top td { text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--line-soft); }
table.top th { font-size: 11px; text-transform: uppercase; letter-spacing: .4px; color: var(--txt-faint); font-weight: 700; }
table.top td.num { text-align: right; font-variant-numeric: tabular-nums; }
table.top tr:last-child td { border-bottom: 0; }
table.top .rank { color: var(--gold); font-weight: 700; width: 28px; }
table.top .pname { color: var(--txt); font-weight: 600; }
table.top .pcode { color: var(--txt-faint); font-size: 11.5px; }

/* estados */
.loading, .empty { color: var(--txt-faint); font-size: 13.5px; padding: 28px 0; text-align: center; }
.spin { display:inline-block; width:14px; height:14px; border:2px solid var(--line); border-top-color: var(--gold); border-radius:50%; animation: sp .7s linear infinite; vertical-align:-2px; margin-right:8px; }
@keyframes sp { to { transform: rotate(360deg); } }

footer.foot { margin-top: 34px; color: var(--txt-faint); font-size: 12px; text-align: center; }
footer.foot code { color: var(--txt-dim); background: var(--panel-2); padding: 1px 6px; border-radius: 5px; }

@media (max-width: 720px) {
  .kpis { grid-template-columns: 1fr 1fr; }
  .brand h1 { font-size: 26px; }
}

/* reveal */
.reveal { opacity: 0; transform: translateY(8px); animation: rv .5s ease forwards; }
.reveal:nth-child(2){animation-delay:.05s} .reveal:nth-child(3){animation-delay:.1s} .reveal:nth-child(4){animation-delay:.15s}
@keyframes rv { to { opacity:1; transform:none; } }
