/* Indiko — design system dos mockups */
:root{
  /* Paleta da marca Indiko — slate #1E293B · roxo #4010D0 · verde #00A070 */
  --bg:#1E293B; --surface:#273549; --surface2:#31405a; --line:#3c4c67;
  --text:#eef2f8; --muted:#a1b1c8; --muted2:#6f8099;
  --brand:#4010D0; --brand2:#9b86ff; --brand-soft:#4010d038;
  --green:#00A070; --green2:#19c692; --green-soft:#00a07033;
  --amber:#fbbf24; --amber-soft:#fbbf2422;
  --red:#f87171; --red-soft:#f8717122; --blue:#60a5fa; --blue-soft:#60a5fa22;
  --radius:14px; --shadow:0 12px 34px #00000066;
}
/* wordmark da marca usado no lugar do texto "Indiko" */
.brandimg{height:30px;width:auto;display:block}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--text); font-size:14px; line-height:1.5;
}
a{color:var(--brand2);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0;font-weight:650;letter-spacing:-.01em}
.muted{color:var(--muted)}
.small{font-size:12px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}

/* layout app: sidebar + main */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.side{background:var(--surface);border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:6px}
.brand{display:flex;align-items:center;gap:9px;padding:6px 8px 16px}
.brand .logo{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--brand),#22d3ee);display:grid;place-items:center;font-weight:800;color:#fff}
.brand b{font-size:18px;letter-spacing:-.02em}
.brand .k{color:var(--brand2)}
.nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.nav a{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;color:var(--muted);font-weight:500;cursor:pointer}
.nav a:hover{background:var(--surface2);text-decoration:none;color:var(--text)}
.nav a.active{background:var(--brand-soft);color:var(--brand2)}
.nav .sep{height:1px;background:var(--line);margin:10px 4px}
.side .who{margin-top:auto;padding:10px;border-radius:10px;background:var(--surface2);font-size:12px;color:var(--muted)}

.main{padding:26px 30px;max-width:1200px;width:100%}
.head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:16px}
.head .sub{color:var(--muted);font-size:13px;margin-top:3px}

/* cards / grid */
.grid{display:grid;gap:16px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.kpi .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.kpi .val{font-size:28px;font-weight:700;margin-top:6px;letter-spacing:-.02em}
.kpi .delta{font-size:12px;margin-top:4px}
.kpi .delta.up{color:var(--green)} .kpi .delta.down{color:var(--red)}

/* table */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.panel .ph{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--line)}
.panel .ph h3{font-size:15px}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:12px 18px;border-bottom:1px solid var(--line);font-size:13px}
th{color:var(--muted);font-weight:550;font-size:11px;text-transform:uppercase;letter-spacing:.04em}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--surface2)}

/* badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:550}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.b-new{color:var(--blue);background:var(--blue-soft)}
.b-review{color:var(--amber);background:var(--amber-soft)}
.b-ok{color:var(--green2);background:var(--green-soft)}
.b-rej{color:var(--red);background:var(--red-soft)}
.b-paid{color:var(--brand2);background:var(--brand-soft)}

/* buttons / inputs */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:10px;border:1px solid var(--line);background:var(--surface2);color:var(--text);font-weight:550;cursor:pointer;font-size:13px}
.btn:hover{border-color:var(--brand);text-decoration:none}
.btn.primary{background:linear-gradient(135deg,var(--brand),#6a2ef0);border-color:transparent;color:#fff}
.btn.ghost{background:transparent}
.btn.sm{padding:6px 11px;font-size:12px}
.input,select,textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:var(--surface2);color:var(--text);font-size:14px;font-family:inherit}
.input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand)}
label.fld{display:block;margin-bottom:14px}
label.fld .lbl{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.copybox{display:flex;gap:8px;align-items:center;background:var(--surface2);border:1px dashed var(--line);border-radius:10px;padding:9px 12px}
.copybox code{flex:1;font-size:12.5px;color:var(--brand2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* nav groups (submenu) */
.nav .grouplbl{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted2);padding:14px 11px 4px;font-weight:600}
.nav a.sub{padding-left:30px;font-size:13px}

/* product cards (visual intuitivo) */
.prodgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.prod{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:12px}
.prod .top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.prod .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:20px;background:var(--brand-soft)}
.prod h3{font-size:16px}
.prod .desc{color:var(--muted);font-size:13px;min-height:34px}
.prod .comm{display:flex;align-items:baseline;gap:6px}
.prod .comm b{font-size:22px;color:var(--green)}
.prod .lk{margin-top:2px}
.prod .lk .lbl{font-size:11px;color:var(--muted);margin-bottom:5px;display:flex;justify-content:space-between}

/* product list (um abaixo do outro) */
.prodlist{display:flex;flex-direction:column;gap:12px}
.prow{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center}
.prow .pinfo{display:flex;gap:14px;align-items:flex-start;min-width:0}
.prow .ic{width:46px;height:46px;flex:none;border-radius:12px;display:grid;place-items:center;font-size:22px;background:var(--brand-soft)}
.prow h3{font-size:16px;display:flex;align-items:center;gap:8px}
.prow .desc{color:var(--muted);font-size:13px;margin:3px 0 6px}
.prow .comm b{color:var(--green);font-size:18px}
.prow .pact{width:340px;max-width:42vw}
.prow .pact .row2{display:flex;gap:8px}
.prow .genout{display:none;margin-top:8px}
@media(max-width:760px){.prow{grid-template-columns:1fr}.prow .pact{width:auto;max-width:none}}

/* date filter (preset + personalizado) */
.datef{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}
.datef select{width:auto}
.datef .custom{display:none;align-items:center;gap:8px}
.datef .custom.on{display:inline-flex}
.datef input[type=date]{width:auto;padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:var(--surface2);color:var(--text);font-size:14px;font-family:inherit}
.datef input[type=date]:focus{outline:none;border-color:var(--brand)}
.datef .to{color:var(--muted)}

/* upload de imagem quadrada (logo do produto) */
.imgup{width:96px;height:96px;border:1px dashed var(--line);border-radius:12px;background:var(--surface2);display:grid;place-items:center;text-align:center;color:var(--muted);font-size:12px;cursor:pointer;overflow:hidden}
.imgup:hover{border-color:var(--brand)}
.imgup span{padding:6px}

/* balance / finance hero */
.balance{background:linear-gradient(135deg,#2e1d6b,#243149);border:1px solid #4a39a0;border-radius:16px;padding:22px 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.balance .b1 .lbl{color:var(--brand2);font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.balance .b1 .v{font-size:36px;font-weight:750;letter-spacing:-.02em;margin-top:4px}
.balance .meta{display:flex;gap:26px}
.balance .meta .lbl{color:var(--muted);font-size:12px}
.balance .meta .v{font-size:18px;font-weight:600;margin-top:2px}

/* modal-ish card */
.note{background:var(--surface2);border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:12.5px;color:var(--muted)}

.tabhide{display:none}
.pill{font-size:11px;color:var(--muted);background:var(--surface2);border:1px solid var(--line);padding:2px 8px;border-radius:999px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:820px){.app{grid-template-columns:1fr}.side{display:none}.split{grid-template-columns:1fr}}
