/* ============================================================
   BlaXx · Design System
   Conteúdo claro · Cabeçalho + menu escuros · Verde Limão
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&family=Space+Grotesk:wght@500;600;700&display=swap');

:root {
  /* ---- core palette ---- */
  --ink: #0E0F0B;          /* near-black, warm */
  --ink-soft: #1B1D14;     /* dark card base */
  --carbon: #16180F;       /* dark elevated */
  --lime: #C6FF00;         /* primary signal — marca oficial */
  --lime-bright: #D7FF5C;  /* highlight / reward */
  --lime-deep: #5AB800;    /* pressed */
  --paper: #ECEFE3;        /* page ground */
  --paper-2: #F4F6EE;      /* lighter ground */
  --white: #FFFFFF;        /* card */
  --cream: #FBFCF7;        /* warm white */

  /* ---- text ---- */
  --fg: #0E0F0B;
  --fg-muted: #686C5B;
  --fg-subtle: #9CA08C;
  --fg-on-dark: #F4F6EE;
  --fg-on-dark-muted: #9DA68A;

  /* ---- lines ---- */
  --line: rgba(14,15,11,0.10);
  --line-strong: rgba(14,15,11,0.18);
  --line-dark: rgba(244,246,238,0.12);

  /* ---- chrome (dark header/menu) ---- */
  --chrome: #0C0D09;
  --chrome-2: #121309;
  --chrome-line: rgba(244,246,238,0.10);
  --chrome-line-strong: rgba(244,246,238,0.18);
  --chrome-fg: #F4F6EE;
  --chrome-fg-muted: #9DA68A;
  --chrome-surface: rgba(244,246,238,0.05);

  /* ---- lime tints ---- */
  --lime-06: rgba(198,255,0,0.06);
  --lime-12: rgba(198,255,0,0.12);
  --lime-20: rgba(198,255,0,0.20);
  --lime-40: rgba(198,255,0,0.40);

  /* ---- signals ---- */
  --pos: #5FB733;     /* gain */
  --neg: #E2533B;     /* spend / minus */
  --warn: #E8A933;    /* expiring */
  --info: #4C8DF6;

  /* ---- type ---- */
  --font-display: 'Space Grotesk', 'Hanken Grotesk', system-ui, sans-serif;
  --font-body: 'Hanken Grotesk', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  /* ---- radii ---- */
  --r-xs: 8px;
  --r-sm: 12px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 28px;
  --r-pill: 999px;

  /* ---- spacing ---- */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px; --sp-8: 64px;

  /* ---- shadows ---- */
  --sh-1: 0 1px 2px rgba(14,15,11,0.05), 0 1px 0 rgba(14,15,11,0.02);
  --sh-2: 0 4px 16px rgba(14,15,11,0.06), 0 1px 3px rgba(14,15,11,0.05);
  --sh-3: 0 18px 48px rgba(14,15,11,0.14), 0 4px 12px rgba(14,15,11,0.08);
  --glow-lime: 0 0 0 1px var(--lime-20), 0 18px 48px rgba(14,15,11,0.14);

  /* ---- motion ---- */
  --ease: cubic-bezier(0.2, 0, 0, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --dur: 240ms;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--fg);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
img { max-width: 100%; display: block; }

::selection { background: var(--lime); color: var(--ink); }

/* gentle reveal */
@keyframes rise {
  from { transform: translateY(10px); }
  to   { transform: translateY(0); }
}
@keyframes pop {
  0%   { transform: scale(0.9); opacity: 0; }
  60%  { transform: scale(1.04); }
  100% { transform: scale(1); opacity: 1; }
}
@keyframes shimmer {
  0% { background-position: -120% 0; }
  100% { background-position: 220% 0; }
}
@keyframes spinSlow { to { transform: rotate(360deg); } }
@keyframes pulseDot {
  0%,100% { opacity: 1; transform: scale(1); }
  50%     { opacity: 0.35; transform: scale(0.7); }
}

/* =========================================================
   APP SHELL — cabeçalho + menu ESCUROS
   ========================================================= */
.topbar {
  position: sticky; top: 0; z-index: 60;
  display: flex; align-items: center; gap: var(--sp-5);
  height: 74px; padding: 0 28px;
  background: var(--chrome);
  border-bottom: 1px solid var(--chrome-line);
}

/* ---- BLAXX brand (PNG logo) ---- */
.brand { display: flex; align-items: center; }
.brand__img { height: 42px; width: auto; display: block; }

.topnav { display: flex; align-items: center; gap: 4px; margin: 0 auto; }
.topnav a {
  position: relative;
  font-size: 14px; font-weight: 600; color: var(--chrome-fg-muted);
  padding: 9px 15px; border-radius: var(--r-pill);
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
  white-space: nowrap;
}
.topnav a:hover { color: var(--chrome-fg); background: rgba(244,246,238,0.06); }
.topnav a.is-active { color: var(--lime); }
.topnav a.is-active::after {
  content: ''; position: absolute; left: 15px; right: 15px; bottom: 3px;
  height: 2px; border-radius: 2px; background: var(--lime);
  box-shadow: 0 0 8px rgba(198,255,0,0.6);
}

.topbar__right { display: flex; align-items: center; gap: 12px; }
.icon-btn {
  position: relative;
  width: 42px; height: 42px; border-radius: var(--r-pill);
  border: 1px solid var(--chrome-line-strong); background: var(--chrome-surface);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--chrome-fg); transition: all var(--dur) var(--ease);
}
.icon-btn:hover { background: rgba(244,246,238,0.12); transform: translateY(-1px); }
.icon-btn .dot {
  position: absolute; top: 9px; right: 10px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--lime); border: 2px solid var(--chrome);
  box-shadow: 0 0 7px rgba(198,255,0,0.8);
}
.user-pill {
  display: flex; align-items: center; gap: 10px;
  background: var(--chrome-surface); border: 1px solid var(--chrome-line-strong);
  border-radius: var(--r-pill); padding: 6px 16px 6px 8px;
  color: var(--chrome-fg); font-weight: 700; font-size: 14px;
  transition: all var(--dur) var(--ease);
}
.user-pill:hover { border-color: var(--lime-40); }
.user-pill .av {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--lime); color: var(--ink);
  display: grid; place-items: center; font-weight: 800; font-size: 13px;
}

.shell {
  display: grid;
  grid-template-columns: 268px minmax(0, 1400px);
  align-items: stretch;
}

/* ---- sidebar (escuro) ---- */
.sidebar {
  background: var(--chrome);
  border-right: 1px solid var(--chrome-line);
  align-self: stretch;
}
.sidebar__sticky {
  position: sticky; top: 74px;
  max-height: calc(100vh - 74px);
  overflow-y: auto;
  padding: 22px 16px 32px 20px;
  display: flex; flex-direction: column; gap: 5px;
}
.sidebar__sticky::-webkit-scrollbar { width: 6px; }
.sidebar__sticky::-webkit-scrollbar-thumb { background: var(--chrome-line-strong); border-radius: 99px; }

.profile-card {
  display: flex; align-items: center; gap: 12px;
  background: var(--chrome-surface); border: 1px solid var(--chrome-line);
  border-radius: var(--r-md); padding: 14px; margin-bottom: 14px;
}
.profile-card .av {
  width: 40px; height: 40px; border-radius: 12px;
  background: var(--lime); color: var(--ink);
  display: grid; place-items: center; font-weight: 800; font-size: 16px;
  flex-shrink: 0;
}
.profile-card__name { font-weight: 800; font-size: 14px; line-height: 1.2; color: var(--chrome-fg); }
.profile-card__meta { font-family: var(--font-mono); font-size: 11px; color: var(--chrome-fg-muted); margin-top: 3px; }
.profile-card__meta b { color: var(--lime); }

.nav-section { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em;
  color: var(--chrome-fg-muted); text-transform: uppercase; padding: 14px 14px 6px; }

.nav-item {
  display: flex; align-items: center; gap: 13px;
  padding: 11px 14px; border-radius: var(--r-sm);
  font-weight: 600; font-size: 14.5px; color: var(--chrome-fg-muted);
  transition: all 180ms var(--ease);
  position: relative;
}
.nav-item .ico {
  width: 26px; height: 26px; border-radius: 8px;
  display: grid; place-items: center; flex-shrink: 0;
  background: transparent; color: var(--chrome-fg-muted);
  transition: all 180ms var(--ease);
}
.nav-item .ico svg { width: 17px; height: 17px; }
.nav-item:hover { background: rgba(244,246,238,0.06); color: var(--chrome-fg); }
.nav-item:hover .ico { color: var(--chrome-fg); }
.nav-item.is-active { background: var(--lime-12); color: var(--lime); }
.nav-item.is-active .ico { background: var(--lime); color: var(--ink); }
.nav-item .badge {
  margin-left: auto; font-family: var(--font-mono); font-size: 10px;
  background: var(--lime); color: var(--ink); font-weight: 700;
  padding: 2px 7px; border-radius: var(--r-pill);
}
.nav-divider { height: 1px; background: var(--chrome-line); margin: 14px 14px; }

/* ---- main (CLARO) ---- */
main {
  padding: 36px 40px 80px;
  min-height: calc(100vh - 74px);
  background: var(--paper);
  opacity: 1;
  animation: rise 420ms var(--ease-out) both;
}
.page-w { max-width: 980px; }

/* =========================================================
   PRIMITIVES (conteúdo claro)
   ========================================================= */
.eyebrow {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink);
  background: var(--lime-20); border: 1px solid var(--lime-40);
  padding: 5px 12px; border-radius: var(--r-pill);
}
.h-display {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(34px, 4.4vw, 52px); line-height: 0.98;
  letter-spacing: -0.03em; margin: 14px 0 8px;
  font-variant-numeric: tabular-nums;
}
.h-section {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(26px, 3vw, 38px); letter-spacing: -0.025em;
  line-height: 1.05; margin: 0;
}
.lead { font-size: 17px; color: var(--fg-muted); margin: 0; max-width: 56ch; }
.lead b { color: var(--fg); font-weight: 700; }
.mono { font-family: var(--font-mono); }

.card {
  background: var(--white); border: 1px solid var(--line);
  border-radius: var(--r-lg); box-shadow: var(--sh-1);
}
.card--dark {
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(198,255,0,0.14), transparent 55%),
    radial-gradient(90% 70% at 0% 100%, rgba(198,255,0,0.06), transparent 60%),
    var(--ink);
  color: var(--fg-on-dark); border-color: rgba(244,246,238,0.08);
}
.card--lime {
  background:
    radial-gradient(120% 120% at 100% 0%, rgba(198,255,0,0.30), transparent 60%),
    var(--paper-2);
  border-color: var(--lime-40);
}

/* buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-body); font-weight: 700; font-size: 14.5px;
  padding: 13px 22px; border-radius: var(--r-pill); border: 1px solid transparent;
  transition: all 180ms var(--ease); white-space: nowrap;
}
.btn--primary { background: var(--lime); color: var(--ink); }
.btn--primary:hover { background: var(--lime-bright); transform: translateY(-1px); box-shadow: 0 8px 22px rgba(198,255,0,0.35); }
.btn--primary:active { background: var(--lime-deep); transform: translateY(0); }
.btn--dark { background: var(--ink); color: var(--lime); }
.btn--dark:hover { background: #000; transform: translateY(-1px); }
.btn--ghost-dark { background: rgba(244,246,238,0.06); color: var(--fg-on-dark); border-color: rgba(244,246,238,0.18); }
.btn--ghost-dark:hover { background: rgba(244,246,238,0.12); }
.btn--white { background: var(--white); color: var(--ink); border-color: var(--line); }
.btn--white:hover { box-shadow: var(--sh-2); transform: translateY(-1px); }
.btn--outline { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn--outline:hover { background: rgba(14,15,11,0.04); }
.btn--sm { padding: 9px 16px; font-size: 13px; }
.btn--block { width: 100%; }

/* chips */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.04em; text-transform: uppercase;
  padding: 5px 11px; border-radius: var(--r-pill);
  background: var(--lime); color: var(--ink);
}
.chip--ghost { background: rgba(244,246,238,0.10); color: var(--fg-on-dark); border: 1px solid rgba(244,246,238,0.16); }
.chip--ink { background: var(--ink); color: var(--lime); }
.chip--live { background: var(--lime); color: var(--ink); }
.chip--live .pd { width: 6px; height: 6px; border-radius: 50%; background: var(--ink); animation: pulseDot 1.4s infinite; }

/* progress */
.bar { height: 10px; border-radius: 99px; background: rgba(14,15,11,0.08); overflow: hidden; }
.bar__fill { height: 100%; border-radius: 99px;
  background: linear-gradient(90deg, var(--lime-deep), var(--lime), var(--lime-bright));
  position: relative; transition: width 1.1s var(--ease-out); }
.bar--dark { background: rgba(244,246,238,0.12); }

/* icon tile */
.tile {
  width: 44px; height: 44px; border-radius: var(--r-sm);
  background: var(--lime); color: var(--ink);
  display: grid; place-items: center; flex-shrink: 0;
}
.tile svg { width: 22px; height: 22px; }
.tile--ink { background: var(--ink); color: var(--lime); }
.tile--soft { background: var(--lime-12); color: var(--ink); }

/* stat */
.stat__label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--fg-subtle); }
.stat__val { font-family: var(--font-mono); font-weight: 700; font-size: 22px; letter-spacing: -0.02em; }

/* divider rule */
.sec-head .h-section { white-space: nowrap; }
.rule { height: 1px; background: var(--line); border: 0; margin: 0; }
.rule--dark { background: rgba(244,246,238,0.12); }

/* mobile nav helpers (hidden on desktop) */
.menu-btn { display: none; }
.drawer, .drawer-scrim { display: none; }

/* =========================================================
   SITE FOOTER (escuro)
   ========================================================= */
.site-footer {
  background: var(--chrome);
  border-top: 1px solid var(--chrome-line);
  color: var(--chrome-fg-muted);
}
.footer-inner { max-width: 1400px; margin: 0 auto; padding: 66px 40px 40px; }
.footer-top {
  display: grid;
  grid-template-columns: 1.7fr 1fr 1fr 1.2fr;
  gap: 40px;
}
.footer-logo {
  font-family: var(--font-display); font-weight: 700;
  font-size: 30px; letter-spacing: -0.02em; color: #F4F6EE;
  display: flex; align-items: baseline; gap: 14px;
}
.footer-logo .x { color: var(--lime); }
.footer-logo__img { height: 40px; width: auto; display: block; }
.footer-logo em {
  font-style: normal; font-weight: 500; font-size: 17px;
  color: var(--chrome-fg-muted); letter-spacing: 0.02em;
}
.footer-desc {
  margin: 22px 0 0; font-size: 14.5px; line-height: 1.6;
  color: var(--chrome-fg-muted); max-width: 34ch;
}
.footer-col h4 {
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase; color: #F4F6EE; margin: 0 0 14px;
}
.footer-col { display: flex; flex-direction: column; }
.footer-col a {
  font-size: 14.5px; color: var(--chrome-fg-muted);
  padding: 8px 0; width: max-content;
  transition: color 0.16s var(--ease);
}
.footer-col a:hover { color: var(--lime); }
.footer-rule { height: 1px; background: var(--chrome-line); border: 0; margin: 46px 0 26px; }
.footer-bottom {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 32px;
}
.footer-copy { font-size: 13px; color: var(--chrome-fg-muted); }
.footer-disclaimer {
  font-size: 12.5px; color: var(--fg-subtle); line-height: 1.55;
  max-width: 470px; text-align: right;
}

@media (max-width: 900px) {
  .footer-inner { padding: 48px 18px 36px; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 36px 24px; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-bottom { flex-direction: column; gap: 16px; }
  .footer-disclaimer { text-align: left; max-width: none; }
}
@media (max-width: 540px) {
  .footer-top { grid-template-columns: 1fr; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1080px) {
  .topnav { display: none; }
}
@media (max-width: 900px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  main { padding: 24px 18px 60px; }
  .menu-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 42px; height: 42px; border-radius: var(--r-pill);
    border: 1px solid var(--chrome-line-strong); background: var(--chrome-surface); color: var(--chrome-fg);
  }
  .topbar { padding: 0 16px; gap: 12px; height: 64px; }
  .brand__img { height: 34px; }
  .topbar__right .user-pill span.t { display: none; }
  .user-pill { padding: 6px; }

  /* drawer */
  .drawer-scrim {
    display: block;
    position: fixed; inset: 0; z-index: 80; background: rgba(0,0,0,0.55);
    opacity: 0; pointer-events: none; transition: opacity var(--dur) var(--ease);
  }
  .drawer-scrim.open { opacity: 1; pointer-events: auto; }
  .drawer {
    display: block;
    position: fixed; top: 0; left: 0; bottom: 0; z-index: 81; width: 280px;
    background: var(--chrome); border-right: 1px solid var(--chrome-line);
    padding: 20px; overflow-y: auto;
    transform: translateX(-100%); transition: transform var(--dur) var(--ease-out);
  }
  .drawer.open { transform: translateX(0); }
}
