/* ============================================================
   Troove — design system (dark/neon, fiel ao site)
   Paleta oficial (brandbook): navy #000719 · ciano #00FFFF · #F2F2F2
   Fonte: Poppins (titulos, ~Gilroy) + Inter (corpo) · "A energia do futuro"
   ============================================================ */
:root{
  --bg:#000719; --bg-2:#030b20; --panel:#071129; --panel-2:#0b1734;
  --line:rgba(255,255,255,.08); --line-2:rgba(0,255,255,.18);
  --ink:#eaf1fb; --muted:#8b97ad; --muted-2:#5d6b85;
  --cyan:#00ffff; --cyan-2:#19e3ff; --cyan-deep:#00c8e6; --mint:#7df2e6;
  --green:#7ed500; --danger:#ff5d6c; --warn:#fbbf24; --ok:#53f995;
  --grad:linear-gradient(135deg,#00ffff 0,#19e3ff 100%);          /* ciano = herói da marca */
  --grad-cy:linear-gradient(135deg,#00ffff 0,#22d3ee 100%);
  --radius:14px;
  --shadow:0 8px 24px rgba(0,0,0,.35);
  --glow:0 0 18px rgba(0,255,255,.45);
  --font:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  /* Gilroy é a fonte oficial (paga). Coloque os arquivos em /static/fonts/ e
     ela passa a valer automaticamente; sem eles, cai no Poppins (substituto). */
  --font-head:Gilroy,Poppins,Inter,sans-serif;
}
@font-face{font-family:"Gilroy";font-weight:600;font-display:swap;
  src:url("/static/fonts/Gilroy-SemiBold.woff2") format("woff2");}
@font-face{font-family:"Gilroy";font-weight:700;font-display:swap;
  src:url("/static/fonts/Gilroy-Bold.woff2") format("woff2");}
@font-face{font-family:"Gilroy";font-weight:800;font-display:swap;
  src:url("/static/fonts/Gilroy-ExtraBold.woff2") format("woff2");}
*{box-sizing:border-box} html,body{margin:0}
body{font-family:var(--font);
  background:radial-gradient(1200px 600px at 80% -10%,#06122e 0,var(--bg) 55%) fixed,var(--bg);
  color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
h1,h2,h3,.brand,.kpi b{font-family:var(--font-head)}
.layout{display:flex;min-height:100vh}

/* sidebar */
.sidebar{width:236px;background:linear-gradient(180deg,#020817 0,#000510 100%);
  border-right:1px solid var(--line);display:flex;flex-direction:column;
  padding:22px 14px;position:sticky;top:0;height:100vh}
.brand{padding:6px 10px 24px}
.brand-lockup{width:160px;max-width:100%;display:block;filter:drop-shadow(0 0 10px rgba(0,255,255,.25))}
.sidebar nav{display:flex;flex-direction:column;gap:4px}
.sidebar nav a{display:flex;align-items:center;gap:10px;color:#aab4c6;text-decoration:none;
  padding:11px 13px;border-radius:10px;font-weight:500;transition:.15s;border:1px solid transparent}
.sidebar nav a:hover{background:rgba(0,255,255,.08);color:#fff;border-color:var(--line-2)}
.sidebar nav a.on{background:rgba(0,255,255,.14);color:#fff;border-color:var(--line-2);
  box-shadow:inset 3px 0 0 var(--cyan)}
.sidebar nav a.on .nav-ico{color:var(--cyan)}
.nav-ico{width:18px;height:18px;flex:none;color:inherit}
.btn-ico{width:15px;height:15px;flex:none;vertical-align:-2px;margin-right:6px}
/* bolinhas de status (substituem emojis) */
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;vertical-align:1px}
.dot.red{background:var(--danger)} .dot.amber{background:var(--warn)} .dot.green{background:var(--ok)}
.side-foot{margin-top:auto;font-size:11px;color:var(--muted-2);padding:10px}
.btn-refresh{width:100%;background:var(--grad);color:#00121a;border:0;border-radius:999px;
  padding:11px;font-size:12.5px;font-weight:700;cursor:pointer;margin-bottom:8px;transition:.15s}
.btn-refresh:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 0 16px rgba(0,255,255,.45)}
.btn-refresh:disabled{opacity:.6;cursor:default}
.fresh{font-size:10.5px;color:var(--mint);margin-bottom:10px}

/* content */
.content{flex:1;padding:30px 36px;max-width:1200px}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px}
.page-head h1{font-size:25px;margin:0;font-weight:900;letter-spacing:-.01em}
.muted{color:var(--muted)} .page-head p{margin:5px 0 0}
.head-actions select{padding:9px 13px;border:1px solid var(--line-2);border-radius:10px;
  background:var(--panel-2);color:var(--ink);font-size:14px;cursor:pointer;font-family:inherit}

/* kpis */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpis.k6{grid-template-columns:repeat(6,1fr)}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--line-2)}
.kpi span{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.kpi b{display:block;font-size:27px;font-weight:900;margin-top:5px;color:#fff;letter-spacing:-.02em}
.kpi small{font-size:12px;color:var(--muted);font-weight:500}
.kpi em{font-style:normal;font-size:13px;color:var(--muted)}
.kpi.danger::before{background:var(--danger)} .kpi.danger b{color:var(--danger)}
.kpi.warn::before{background:var(--warn)} .kpi.warn b{color:var(--warn)}
.kpi.okk::before{background:var(--green)} .kpi.okk b{color:var(--green)}

/* cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;box-shadow:var(--shadow);margin-bottom:18px}
.card h3{margin:0 0 12px;font-size:15px;font-weight:700;color:#fff}
.cards-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card .row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}
.card .row:last-child{border-bottom:0}

/* alerts */
.alerts{margin-bottom:18px;display:flex;flex-direction:column;gap:8px}
.alert{background:rgba(251,191,36,.10);border:1px solid rgba(251,191,36,.35);color:#fcd34d;
  padding:10px 14px;border-radius:10px;font-size:13px}

/* tables */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);font-size:13.5px}
th{color:var(--muted);font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em}
td.r,th.r{text-align:right;font-variant-numeric:tabular-nums}
td.strong{font-weight:700;color:#fff} tr:hover td{background:rgba(255,255,255,.03)}
.neg{color:var(--danger)}
tr.tot td{border-top:2px solid var(--line-2);border-bottom:0}
a.lnk{color:var(--cyan);text-decoration:none;font-weight:600}
a.lnk:hover{text-decoration:underline;text-shadow:var(--glow)}

.tag{padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}
.t-FALTANDO_NO_EXTRATO{background:rgba(255,93,108,.16);color:#ff8d97}
.t-FATURAMENTO_SUBREPORTADO{background:rgba(251,146,60,.16);color:#fdba74}
.t-DIVERGENCIA_REPASSE{background:rgba(251,191,36,.16);color:#fcd34d}

/* final bar (relatório) */
.final-bar{background:var(--grad);color:#00121a;border-radius:var(--radius);padding:18px 22px;
  display:flex;justify-content:space-between;align-items:center;box-shadow:0 0 28px rgba(0,255,255,.28)}
.final-bar b{font-size:26px;font-weight:800;font-family:var(--font-head)}

/* toggle */
.toggle{display:inline-flex;border:1px solid var(--line-2);border-radius:999px;overflow:hidden}
.toggle button{border:0;background:var(--panel-2);padding:7px 16px;font-size:13px;cursor:pointer;
  color:var(--muted);font-weight:700;font-family:inherit}
.toggle button.on{background:var(--grad);color:#00121a}

/* heatmap */
table.heat{border-collapse:separate;border-spacing:2px;width:100%}
table.heat th{padding:2px;font-size:10px;color:var(--muted);text-transform:none;letter-spacing:0;font-weight:600;text-align:center;border:0}
table.heat td{padding:0;height:18px;border:0;border-radius:3px;background:rgba(255,255,255,.04)}
table.heat tr th:first-child{text-align:right;padding-right:6px;width:34px}
.heat-legend{display:flex;align-items:center;gap:4px;margin-top:10px;font-size:11px;color:var(--muted)}
.heat-legend i{width:18px;height:12px;border-radius:3px;display:inline-block}
.heat-legend .h0{background:rgba(0,255,255,.14)} .heat-legend .h1{background:rgba(0,255,255,.38)}
.heat-legend .h2{background:rgba(0,255,255,.6)} .heat-legend .h3{background:rgba(0,255,255,.8)}
.heat-legend .h4{background:var(--cyan)}

/* barra de progresso (payback) */
.bar{position:relative;background:rgba(255,255,255,.06);border-radius:8px;height:20px;overflow:hidden}
.bar-fill{height:100%;background:var(--grad-cy);border-radius:8px 0 0 8px;min-width:2px}
.bar-fill.done{background:var(--grad)}
.bar-lbl{position:absolute;top:0;right:8px;line-height:20px;font-size:11px;font-weight:700;color:#fff}

/* login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-card{width:100%;max-width:360px;background:var(--panel);border:1px solid var(--line-2);
  border-radius:18px;padding:34px 30px;box-shadow:0 0 40px rgba(0,255,255,.10),var(--shadow)}
.login-lockup{display:block;width:210px;max-width:80%;margin:0 auto 12px;filter:drop-shadow(0 0 18px rgba(0,255,255,.3))}
.login-brand{font-size:32px;justify-content:center;padding:0;margin-bottom:2px}
.login-sub{text-align:center;color:var(--mint);font-size:13px;margin:0 0 22px}
.login-card label{display:block;font-size:12px;color:var(--muted);margin:14px 0 5px;font-weight:600}
.login-card input{width:100%;padding:11px 13px;border:1px solid var(--line-2);border-radius:10px;
  background:var(--bg-2);color:var(--ink);font-size:14px;font-family:inherit}
.login-card input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(0,255,255,.15)}
.btn-login{width:100%;margin-top:22px;background:var(--grad);color:#00121a;border:0;border-radius:999px;
  padding:12px;font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font-head);transition:.15s}
.btn-login:hover{filter:brightness(1.08);box-shadow:0 0 18px rgba(0,255,255,.45)}
.login-erro{background:rgba(255,93,108,.14);border:1px solid rgba(255,93,108,.4);color:#ff8d97;
  padding:9px 12px;border-radius:9px;font-size:13px;margin-bottom:6px;text-align:center}
.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  background:#fff;color:#1f2937;border:0;border-radius:999px;padding:12px;font-size:14px;
  font-weight:700;font-family:var(--font-head);text-decoration:none;cursor:pointer;transition:.15s}
.btn-google:hover{box-shadow:0 0 18px rgba(255,255,255,.25);transform:translateY(-1px)}
.login-hint{text-align:center;color:var(--muted);font-size:12px;margin:10px 0 0}
.login-hint b{color:var(--mint)}
.login-alt{margin-top:18px;border-top:1px solid var(--line);padding-top:10px}
.login-alt summary{color:var(--muted);font-size:12px;cursor:pointer;list-style:none;text-align:center}
.login-alt summary::-webkit-details-marker{display:none}
.login-alt summary:hover{color:var(--cyan)}
.login-foot{text-align:center;color:var(--muted-2);font-size:11px;margin-top:22px}

/* logout / sidebar foot */
.side-logout{display:flex;align-items:center;gap:9px;color:#aab4c6;text-decoration:none;font-size:12.5px;
  font-weight:600;padding:8px 10px;border-radius:8px;margin-bottom:8px}
.side-logout .nav-ico{width:16px;height:16px}
.side-logout:hover{background:rgba(255,93,108,.12);color:#ff8d97}
.btn-refresh{display:flex;align-items:center;justify-content:center}
.side-copy{font-size:11px;color:var(--muted-2);padding:0 10px}

/* empty */
.empty{text-align:center;padding:48px}
.empty-ico{width:44px;height:44px;color:var(--cyan);margin-bottom:10px;
  fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
code{background:rgba(0,255,255,.10);color:var(--mint);padding:1px 6px;border-radius:5px;font-size:12.5px}

@media(max-width:1080px){.kpis.k6{grid-template-columns:repeat(3,1fr)}.cards-2,.cards-3{grid-template-columns:1fr}}
@media(max-width:760px){.kpis,.kpis.k6{grid-template-columns:1fr 1fr}.content{padding:20px}.sidebar{width:200px}}
