/* ============================================================
   Design system Shop Antenas — TEMA ESCURO FUTURISTA
   Marca: azul #004aad · branco #ffffff · vermelho #c41616 · preto #000000
   ============================================================ */
:root{
  /* superfícies */
  --bg:#070b15;          /* canvas (quase preto azulado) */
  --paper:#111a2e;       /* base dos cards */
  --paper-2:#16223c;     /* card mais elevado */
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(90,140,255,.28);

  /* texto */
  --ink:#eef3fb;
  --ink-soft:#8a99b5;

  /* marca / acentos */
  --brand:#2f6bff;       /* azul realçado p/ fundo escuro */
  --brand-deep:#004aad;  /* azul padrão da marca */
  --brand-glow:rgba(47,107,255,.45);
  --teal:#2f6bff;        /* compat. tokens do protótipo */
  --navy:#004aad;

  /* entrada = azul · saída = vermelho */
  --green:#2f6bff;       --green-bg:rgba(47,107,255,.12);
  --red:#ff4d4d;         --red-deep:#c41616;  --red-bg:rgba(255,77,77,.12);
  --amber:#ffb020;       --amber-bg:rgba(255,176,32,.12);
  --purple:#a36bff;      --purple-bg:rgba(163,107,255,.12);

  --shadow:0 2px 10px rgba(0,0,0,.45),0 20px 55px -22px rgba(0,0,0,.75);
  --glow:0 0 0 1px var(--line-strong),0 12px 40px -10px var(--brand-glow);
}
*{box-sizing:border-box;margin:0;padding:0}
::selection{background:rgba(47,107,255,.35);color:#fff}

body{
  color:var(--ink);min-height:100vh;
  font-family:'Hanken Grotesk',sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;
  background:
    radial-gradient(1200px 620px at 82% -12%, rgba(47,107,255,.20), transparent 60%),
    radial-gradient(900px 520px at -12% 112%, rgba(196,22,22,.12), transparent 55%),
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px),
    var(--bg);
  background-size:auto,auto,46px 46px,46px 46px;
  background-attachment:fixed;
}
h1,h2,h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;letter-spacing:-.02em;color:#fff}
.num{font-variant-numeric:tabular-nums}
.eyebrow{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--brand)}
.sub{color:var(--ink-soft);font-size:14px}

/* Marca */
.brand{display:flex;align-items:center;gap:10px;font-family:'Bricolage Grotesque';font-weight:800;font-size:18px;color:#fff}
.brand .dot{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--brand),var(--brand-deep));color:#fff;display:grid;place-items:center;box-shadow:0 0 20px var(--brand-glow)}
.brand.big{font-size:22px}.brand.big .dot{width:40px;height:40px;font-size:18px}

/* ===== App (sidebar + conteúdo) ===== */
.app{display:flex;min-height:100vh}
.sidebar{
  width:252px;flex-shrink:0;padding:22px 18px;display:flex;flex-direction:column;gap:6px;
  position:sticky;top:0;height:100vh;
  background:linear-gradient(180deg,rgba(20,31,56,.72),rgba(10,16,30,.72));
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-right:1px solid var(--line);
}
.nav{display:flex;flex-direction:column;gap:5px;margin-top:28px}
.navlink{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:12px;font-weight:600;font-size:14px;color:var(--ink-soft);text-decoration:none;transition:.16s;border:1px solid transparent}
.navlink .ic{font-size:17px;filter:saturate(1.1)}
.navlink:hover{color:#fff;background:rgba(255,255,255,.04);border-color:var(--line)}
.navlink.on{color:#fff;background:linear-gradient(135deg,rgba(47,107,255,.26),rgba(47,107,255,.06));border-color:var(--line-strong);box-shadow:0 0 26px -6px var(--brand-glow)}
.navlink.disabled{color:#586275;cursor:default}
.navlink.disabled:hover{background:none;border-color:transparent}
.navlink .soon{margin-left:auto;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:rgba(255,255,255,.06);color:var(--ink-soft);padding:2px 7px;border-radius:99px}
.side-foot{margin-top:auto;border-top:1px solid var(--line);padding-top:14px;display:flex;flex-direction:column;gap:8px}
.who strong{display:block;font-size:13.5px;color:#fff}.who span{font-size:11.5px;color:var(--ink-soft)}
.logout{font-size:13px;font-weight:600;color:var(--red);text-decoration:none}
.logout:hover{text-shadow:0 0 12px rgba(255,77,77,.6)}

.content{flex:1;padding:34px 42px;max-width:1100px}
.page h1{font-size:27px;margin:5px 0 2px}
h2{font-size:17px;margin:28px 0 12px}

/* Cards de números */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(184px,1fr));gap:14px;margin:22px 0}
.card{background:linear-gradient(180deg,rgba(22,34,60,.92),rgba(17,26,46,.88));border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.card.hl{background:linear-gradient(135deg,var(--brand-deep),#06204d);border:1px solid var(--line-strong);box-shadow:var(--glow);position:relative;overflow:hidden}
.card.hl::after{content:"";position:absolute;inset:0;background:radial-gradient(420px 120px at 110% -20%,rgba(47,107,255,.5),transparent 60%);pointer-events:none}
.card .l{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.card.hl .l{color:#bcd0ff}
.card .v{font-family:'Bricolage Grotesque';font-weight:800;font-size:24px;margin-top:8px;color:#fff}

/* Estado vazio */
.empty{background:linear-gradient(180deg,rgba(22,34,60,.5),rgba(17,26,46,.35));border:1px dashed var(--line-strong);border-radius:18px;padding:40px;text-align:center;margin:18px 0;box-shadow:inset 0 0 60px -20px var(--brand-glow)}
.empty .ic{font-size:42px;filter:drop-shadow(0 0 14px var(--brand-glow))}
.empty h3{font-size:18px;margin:12px 0 4px}.empty p{color:var(--ink-soft);font-size:13.5px;max-width:460px;margin:0 auto}

/* Passos */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(244px,1fr));gap:12px}
.step{display:flex;gap:12px;background:linear-gradient(180deg,rgba(22,34,60,.7),rgba(17,26,46,.5));border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow);transition:.16s}
.step:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.step .n{flex-shrink:0;width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--brand),var(--brand-deep));color:#fff;font-family:'Bricolage Grotesque';font-weight:800;display:grid;place-items:center;box-shadow:0 0 16px -2px var(--brand-glow)}
.step strong{font-size:14.5px;color:#fff}.step p{font-size:12.5px;color:var(--ink-soft);margin-top:3px}

.note{font-size:12px;color:var(--ink-soft);margin-top:24px;padding-top:16px;border-top:1px solid var(--line)}

/* Banners */
.banner{border-radius:13px;padding:12px 16px;margin:14px 0;font-size:14px;font-weight:600}
.banner.warn{background:var(--red-bg);border:1px solid rgba(255,77,77,.35);color:#ff8a8a}
.banner.ok{background:var(--green-bg);border:1px solid var(--line-strong);color:#9dc0ff}

/* Botão */
.cta{background:linear-gradient(135deg,var(--brand),var(--brand-deep));color:#fff;border:none;font-family:'Hanken Grotesk';font-weight:700;font-size:15px;padding:12px 22px;border-radius:11px;cursor:pointer;box-shadow:0 10px 28px -8px var(--brand-glow);transition:.16s}
.cta:hover{transform:translateY(-2px);box-shadow:0 14px 36px -8px var(--brand-glow)}

/* ===== Login ===== */
.login-page{display:grid;place-items:center;min-height:100vh;padding:24px}
.login-card{position:relative;background:linear-gradient(180deg,rgba(22,34,60,.78),rgba(13,20,36,.78));border:1px solid var(--line-strong);border-radius:20px;box-shadow:var(--glow);padding:34px;width:100%;max-width:392px;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}
.login-sub{color:var(--ink-soft);font-size:13.5px;margin:6px 0 18px}
.login-form{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.login-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--ink-soft)}
.login-form input{font-family:'Hanken Grotesk';font-size:15px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.04);color:var(--ink);transition:.16s}
.login-form input::placeholder{color:#5a6b85}
.login-form input:focus{outline:none;border-color:var(--brand);background:rgba(47,107,255,.06);box-shadow:0 0 0 3px rgba(47,107,255,.22)}
.login-form .cta{margin-top:6px}

/* Scrollbar */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:rgba(120,150,210,.25);border-radius:99px;border:2px solid transparent;background-clip:padding-box}
*::-webkit-scrollbar-thumb:hover{background:rgba(120,150,210,.45);background-clip:padding-box}

/* Botão secundário / mini */
.cta.sec{background:rgba(255,255,255,.05);color:var(--ink);border:1px solid var(--line);box-shadow:none;text-decoration:none;display:inline-block}
.cta.sec:hover{border-color:var(--line-strong);background:rgba(255,255,255,.08)}
.cta.mini{font-size:13px;padding:9px 16px}
a.cta{text-decoration:none;display:inline-block}

/* ===== Módulo Caixa ===== */
/* Drop zone */
.drop{display:block;margin-top:18px;border:2px dashed var(--line-strong);border-radius:18px;padding:42px;text-align:center;cursor:pointer;transition:.18s;background:linear-gradient(180deg,rgba(22,34,60,.4),rgba(17,26,46,.25))}
.drop:hover,.drop.over{border-color:var(--brand);background:rgba(47,107,255,.08);box-shadow:inset 0 0 50px -18px var(--brand-glow)}
.drop .ic{font-size:40px;filter:drop-shadow(0 0 12px var(--brand-glow))}
.drop h3{font-size:19px;margin:10px 0 4px}.drop p{color:var(--ink-soft);font-size:13px}

/* Lista de arquivos */
.files{margin-top:14px;display:flex;flex-direction:column;gap:6px}
.frow{display:flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:9px 14px;font-size:13px}
.frow .new{margin-left:auto;font-weight:700;color:var(--brand)}
.frow .dup{color:var(--ink-soft);font-weight:600;font-size:12px}
.frow .err{margin-left:auto;font-weight:700;color:var(--red)}

/* Barra de progresso */
.progress{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:15px 20px;margin:14px 0;display:flex;align-items:center;gap:18px;flex-wrap:wrap;box-shadow:var(--shadow)}
.pbar{flex:1;min-width:160px;height:9px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}
.pfill{height:100%;background:linear-gradient(90deg,var(--brand-deep),var(--brand));width:0;transition:.4s;border-radius:99px;box-shadow:0 0 12px var(--brand-glow)}
.pstat{font-size:13px;font-weight:600;color:var(--ink-soft)}.pstat b{color:var(--ink)}

/* Filtros (chips) */
.filters{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.fb{font-weight:600;font-size:13px;color:var(--ink-soft);background:var(--paper);border:1px solid var(--line);padding:7px 13px;border-radius:99px;cursor:pointer;text-decoration:none;display:inline-block}
.fb:hover{border-color:var(--line-strong);color:var(--ink)}
.fb.on{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 0 18px -4px var(--brand-glow)}
.fb .c{font-size:11px;opacity:.7;margin-left:3px}

/* Lançamentos (revisão) */
.tx{background:var(--paper);border:1px solid var(--line);border-left-width:4px;border-radius:12px;padding:12px 15px;margin-bottom:8px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;box-shadow:var(--shadow)}
.tx.rec{border-left-color:var(--green)}.tx.desp{border-left-color:var(--red)}
.tx.transf{border-left-color:#5b6b85}.tx.rfv{border-left-color:var(--purple)}
.tx.duv{border-left-color:var(--amber);background:linear-gradient(180deg,rgba(255,176,32,.06),var(--paper))}
.tx .info{flex:1;min-width:220px}.tx .memo{font-weight:600;font-size:13.5px;color:#fff}
.tx .meta{font-size:11.5px;color:var(--ink-soft);margin-top:2px}.tx .conf{font-size:11px;color:var(--ink-soft);margin-top:2px}
.tx .val{font-family:'Bricolage Grotesque';font-weight:800;font-size:16px;white-space:nowrap}
.tx .val.pos{color:var(--green)}.tx .val.neg{color:var(--red)}
.tag{font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:99px;margin-left:8px}
.tag.rec{background:var(--green-bg);color:#9dc0ff}.tag.desp{background:var(--red-bg);color:#ff8a8a}
.tag.transf{background:rgba(255,255,255,.07);color:var(--ink-soft)}.tag.rfv{background:var(--purple-bg);color:#c9aaff}
.tag.duv{background:var(--amber-bg);color:#ffcf7a}
.actions{display:flex;gap:6px;flex-wrap:wrap}
.btn{font-family:'Hanken Grotesk';font-weight:600;font-size:12px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--ink);padding:6px 11px;border-radius:8px;cursor:pointer;transition:.12s}
.btn:hover{border-color:var(--line-strong)}
.btn.rec.sel{background:var(--green);color:#fff;border-color:var(--green)}
.btn.desp.sel{background:var(--red);color:#fff;border-color:var(--red)}
.btn.transf.sel{background:#5b6b85;color:#fff;border-color:#5b6b85}

/* Rodapé fixo da revisão */
.footer{position:sticky;bottom:16px;margin-top:16px;background:linear-gradient(180deg,rgba(22,34,60,.92),rgba(13,20,36,.92));backdrop-filter:blur(14px);border:1px solid var(--line-strong);border-radius:14px;padding:15px 20px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;box-shadow:0 -6px 30px -12px rgba(0,0,0,.6)}
.tot .l{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-weight:600}
.tot .v{font-family:'Bricolage Grotesque';font-weight:800;font-size:18px}
.cta:disabled{background:#2a3550;color:#6b7790;cursor:not-allowed;box-shadow:none;transform:none}

/* Saldo por conta */
.accts{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:6px 20px;box-shadow:var(--shadow);margin-bottom:8px}
.arow{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.arow:last-child{border:none}.arow .nm{font-weight:600;color:#fff}.arow .bl{margin-left:auto;font-weight:700}

/* Breakdowns */
.breakdown{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:6px 20px;box-shadow:var(--shadow)}
.brow{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.brow:last-child{border:none}.brow b{color:#fff}.brow .v{font-weight:700}

/* Tabela visão diária */
.tablecard{background:var(--paper);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.tscroll{max-height:420px;overflow-y:auto}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{position:sticky;top:0;background:var(--brand-deep);color:#fff;font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:11px;padding:10px 14px;text-align:right}
thead th:first-child{text-align:left}
tbody td{padding:8px 14px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap;color:var(--ink)}
tbody td:first-child{text-align:left;font-weight:600}
.ent{color:var(--green)}.sai{color:var(--red)}
td.saldo{font-weight:800;font-family:'Bricolage Grotesque'}
td.pos{color:#fff}td.neg{color:#ff8a8a;background:var(--red-bg)}

/* Alerta RFV */
.alert{background:var(--purple-bg);border:1px solid rgba(163,107,255,.35);border-radius:14px;padding:16px 18px;margin-top:16px}
.alert h3{color:#c9aaff;font-size:15px;margin-bottom:4px}.alert p{font-size:13px;color:#b9a6e0}

/* Responsivo */
@media(max-width:720px){
  .app{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;align-items:center}
  .nav{flex-direction:row;margin-top:0;flex-wrap:wrap}
  .side-foot{margin:0 0 0 auto;border:none;padding:0;flex-direction:row;align-items:center;gap:14px}
  .content{padding:24px 18px}
}
