/* ====================================================================
   Startfinp — sistema de diseño (marca: indigo #6352F6 → mint #11D49A)
   ==================================================================== */
:root{
  --brand:#11d49a; --brand2:#6352f6; --brand-grad:linear-gradient(135deg,#6352f6,#11d49a);
  --bg:#0a0e1a; --bg2:#0f1424; --card:#141a2c; --card2:#1a2238; --line:#26304a;
  --txt:#e9eef8; --mut:#94a3b8; --mut2:#64748b;
  --good:#34d399; --good-bg:#0d2a22; --warn:#fbbf24; --warn-bg:#2a2410; --bad:#f87171; --bad-bg:#2a1414;
  --r:16px; --shadow:0 10px 30px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:radial-gradient(1000px 500px at 90% -10%,#16223e 0%,transparent 55%),var(--bg);
  color:var(--txt);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;line-height:1.5;min-height:100vh}
a{color:var(--brand);text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#27314c;border-radius:8px}

/* boot */
.boot{min-height:100vh;display:grid;place-content:center;justify-items:center;gap:16px;color:var(--mut)}
.boot-logo{width:64px;height:64px;border-radius:18px;background:var(--brand-grad);box-shadow:var(--shadow);animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.08);opacity:1}}

/* ---------- AUTH ---------- */
.auth{min-height:100vh;display:grid;place-items:center;padding:24px}
.auth-card{width:100%;max-width:420px;background:var(--card);border:1px solid var(--line);border-radius:22px;
  padding:30px 26px;box-shadow:var(--shadow)}
.brandmark{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.brandmark .logo{width:46px;height:46px;border-radius:13px;background:var(--brand-grad);position:relative;flex:0 0 auto}
.brandmark .logo::after{content:"";position:absolute;inset:0;background:url('/icons/icon-512.png') center/cover;border-radius:13px}
.brandmark h1{font-size:22px;margin:0;letter-spacing:-.5px}
.brandmark .tag{font-size:12px;color:var(--mut)}
.auth h2{font-size:18px;margin:18px 0 4px}
.auth p.sub{color:var(--mut);font-size:13.5px;margin:0 0 16px}
.field{margin:12px 0}
.field label{display:block;font-size:12.5px;color:var(--mut);font-weight:600;margin-bottom:6px}
.input{width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--txt);border-radius:11px;
  padding:12px 13px;font-size:15px;outline:none;transition:border .15s}
.input:focus{border-color:var(--brand)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:11px;
  padding:12px 16px;font-size:15px;font-weight:700;background:var(--card2);color:var(--txt);border:1px solid var(--line)}
.btn:hover{filter:brightness(1.1)}
.btn-primary{background:var(--brand-grad);color:#04130d;border:none}
.btn-block{width:100%}
.btn-sm{padding:8px 12px;font-size:13px;border-radius:9px}
.btn-ghost{background:transparent}
.btn-danger{background:var(--bad-bg);color:#fca5a5;border-color:#5b2424}
.btn-good{background:var(--good-bg);color:#86efac;border-color:#1f5b44}
.link{color:var(--brand);font-weight:600;cursor:pointer}
.auth .switch{text-align:center;margin-top:14px;font-size:13.5px;color:var(--mut)}
.note{font-size:12px;color:var(--mut2);margin-top:10px}
.banner{padding:10px 12px;border-radius:10px;font-size:13px;margin:10px 0}
.banner.info{background:#10233a;color:#9cc7ff;border:1px solid #1d3a5b}
.banner.ok{background:var(--good-bg);color:#86efac;border:1px solid #1f5b44}
.banner.bad{background:var(--bad-bg);color:#fca5a5;border:1px solid #5b2424}

/* ---------- APP SHELL ---------- */
.shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:var(--bg2);border-right:1px solid var(--line);padding:18px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:4px}
.sidebar .brandmark{margin-bottom:18px;padding:0 6px}
.sidebar .brandmark h1{font-size:19px}
.navlink{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:11px;color:var(--mut);font-weight:600;font-size:14.5px;cursor:pointer;position:relative}
.navlink .ic{font-size:18px;width:22px;text-align:center}
.navlink:hover{background:var(--card);color:var(--txt)}
.navlink.active{background:var(--card2);color:var(--txt)}
.navlink.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--brand)}
.navlink .badge{margin-left:auto;background:var(--bad);color:#fff;font-size:11px;font-weight:800;padding:1px 7px;border-radius:999px}
.sidebar .spacer{flex:1}
.userchip{display:flex;align-items:center;gap:10px;padding:10px;border-radius:11px;background:var(--card);border:1px solid var(--line);cursor:pointer}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--brand-grad);display:grid;place-items:center;font-weight:800;color:#04130d;flex:0 0 auto}
.userchip .nm{font-size:13px;font-weight:700;line-height:1.1}
.userchip .em{font-size:11px;color:var(--mut)}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:none}
.content{padding:24px;max-width:1100px;width:100%;margin:0 auto}
.bottomnav{display:none}

/* headings */
.viewhead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.viewhead h2{font-size:22px;margin:0;letter-spacing:-.4px}
.viewhead .sub{color:var(--mut);font-size:13.5px;margin-top:2px}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* cards / grid */
.grid{display:grid;gap:14px}
.cols-2{grid-template-columns:1fr 1fr}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px;box-shadow:var(--shadow)}
.card h3{margin:0 0 10px;font-size:15px}
.kpi .lab{font-size:11.5px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.kpi .val{font-size:23px;font-weight:800;margin-top:6px;letter-spacing:-.5px}
.kpi .val.good{color:var(--good)}.kpi .val.bad{color:var(--bad)}
.kpi .note{font-size:11.5px;color:var(--mut2);margin-top:3px}
.kpi{position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:var(--brand-grad)}

/* account card */
.acct{position:relative;overflow:hidden}
.acct .topline{height:4px;border-radius:4px;margin:-16px -16px 12px;background:var(--brand2)}
.acct .nm{font-weight:800;font-size:15.5px}
.acct .inst{color:var(--mut);font-size:12px}
.acct .bal{font-size:20px;font-weight:800;margin-top:8px}
.acct .meta{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px;font-size:12px;color:var(--mut)}
.bar{height:8px;border-radius:6px;background:var(--card2);overflow:hidden;margin-top:6px}
.bar i{display:block;height:100%;border-radius:6px;background:var(--brand);transition:width .8s}
.bar.good i{background:var(--good)}.bar.warn i{background:var(--warn)}.bar.bad i{background:var(--bad)}
.chip{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:700}
.chip.cred{background:#13283f;color:#7dd3fc}.chip.deb{background:#15321f;color:#86efac}
.chip.ahorro{background:#2a2410;color:#fcd34d}.chip.efectivo{background:#22303f;color:#cbd5e1}

/* tables */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r)}
table{border-collapse:collapse;width:100%;font-size:13.5px;min-width:520px}
th{background:var(--card2);color:var(--mut);text-align:left;padding:10px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
td{padding:10px 12px;border-top:1px solid var(--line);vertical-align:middle}
tr:hover td{background:var(--card2)}
td.num,th.num{text-align:right;white-space:nowrap}
.catpill{display:inline-flex;align-items:center;gap:6px;font-size:12px;background:var(--card2);padding:2px 9px;border-radius:999px}
.amt-out{color:#fca5a5;font-weight:700}.amt-in{color:#86efac;font-weight:700}

/* alerts */
.alert{display:flex;gap:12px;align-items:flex-start;border-radius:12px;padding:12px 14px;margin-bottom:10px;border:1px solid var(--line)}
.alert .ic{font-size:20px}
.alert.warn{background:var(--warn-bg);border-color:#5b4a1f}.alert.bad{background:var(--bad-bg);border-color:#5b2424}.alert.ok{background:var(--good-bg);border-color:#1f5b44}
.alert h4{margin:0 0 2px;font-size:14px}.alert p{margin:0;color:var(--mut);font-size:12.5px}

/* forms inline */
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.formgrid .full{grid-column:1/-1}
.seg{display:inline-flex;background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:3px;gap:3px;flex-wrap:wrap}
.seg button{border:none;background:transparent;color:var(--mut);padding:8px 12px;border-radius:8px;font-weight:600;font-size:13px}
.seg button.on{background:var(--card2);color:var(--txt)}

/* modal */
#modal-root{position:fixed;inset:0;z-index:100;display:none}
#modal-root.show{display:block}
.modal-bg{position:absolute;inset:0;background:rgba(4,7,14,.7);backdrop-filter:blur(3px)}
.modal{position:relative;max-width:560px;margin:5vh auto;background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);max-height:90vh;overflow:auto}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--card);z-index:2}
.modal-head h3{margin:0;font-size:17px}
.modal-body{padding:18px 20px}
.modal-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end;position:sticky;bottom:0;background:var(--card)}
.x{background:transparent;border:none;color:var(--mut);font-size:22px;line-height:1}

/* toasts */
#toasts{position:fixed;left:0;right:0;bottom:18px;z-index:200;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.toast{background:var(--card2);border:1px solid var(--line);color:var(--txt);padding:11px 16px;border-radius:12px;font-size:13.5px;box-shadow:var(--shadow);max-width:90vw}
.toast.ok{border-color:#1f5b44}.toast.bad{border-color:#5b2424}

/* dropzone */
.drop{border:2px dashed var(--line);border-radius:14px;padding:26px;text-align:center;color:var(--mut);background:var(--bg2);cursor:pointer}
.drop:hover{border-color:var(--brand)}
.drop strong{color:var(--txt)}
.thumb{max-width:100%;max-height:240px;border-radius:12px;border:1px solid var(--line);margin-top:10px}

/* misc */
.muted{color:var(--mut)}.small{font-size:12.5px}.center{text-align:center}
.spin{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;display:inline-block;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.empty{text-align:center;color:var(--mut);padding:30px}
.empty .big{font-size:40px;opacity:.7}
.pill-recur{font-size:10px;background:#1d3a2a;color:#6ee7b7;padding:1px 6px;border-radius:5px;margin-left:4px}
.pill-msi{font-size:10px;background:#22303f;color:#93c5fd;padding:1px 6px;border-radius:5px;margin-left:4px}
.donut-legend{display:flex;flex-direction:column;gap:6px;font-size:13px}
.donut-legend div{display:flex;align-items:center;gap:8px}
.dot{width:11px;height:11px;border-radius:3px;flex:0 0 auto}
.barrow{display:grid;grid-template-columns:120px 1fr 88px;gap:10px;align-items:center;margin:7px 0;font-size:13px}
.barrow .bt{height:13px;border-radius:7px;background:var(--card2);overflow:hidden}
.barrow .bt i{display:block;height:100%;border-radius:7px}

/* responsive: bottom nav on mobile */
@media(max-width:780px){
  .shell{grid-template-columns:1fr}
  .sidebar{display:none}
  .topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;position:sticky;top:0;background:rgba(10,14,26,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);z-index:30}
  .topbar .brandmark .logo{width:34px;height:34px;border-radius:10px}
  .topbar .brandmark h1{font-size:17px}
  .content{padding:16px 14px 90px}
  .bottomnav{display:flex;position:fixed;bottom:0;left:0;right:0;background:rgba(15,20,36,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);z-index:40;padding:6px 4px env(safe-area-inset-bottom)}
  .bottomnav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--mut);font-size:10.5px;font-weight:600;padding:6px 2px;border-radius:10px}
  .bottomnav a .ic{font-size:20px}
  .bottomnav a.active{color:var(--brand)}
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr 1fr}
  .formgrid{grid-template-columns:1fr}
}
@media(max-width:430px){.cols-3,.cols-4{grid-template-columns:1fr 1fr}.kpi .val{font-size:20px}}
