/* ZYPHRA · app.css — identidad de marca (tema oscuro, azul Zyphra) */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700&family=Manrope:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  --bg:#070a11; --bg-2:#0b0f19; --surface:#10151f; --surface-2:#161d2a;
  --ink:#e9eef6; --ink-soft:#828ea6; --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.05);
  --accent:#3aa8ee; --accent-2:#1f6fd6; --cargo:#fb7185; --favor:#18cdb0; --gold:#fbbf24;
  --radius:16px; --shadow:0 10px 40px -12px rgba(0,0,0,.6);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);font-family:'Manrope',system-ui,sans-serif;line-height:1.55;
  min-height:100vh;padding:0 0 90px;position:relative;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(55vw 55vw at 6% -12%, rgba(58,168,238,.16), transparent 60%),
    radial-gradient(50vw 45vw at 102% -5%, rgba(31,111,214,.15), transparent 55%),
    radial-gradient(45vw 45vw at 95% 105%, rgba(24,205,176,.08), transparent 60%);
}
a{color:var(--accent);text-decoration:none}
.num{font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums;letter-spacing:-.02em}

/* Header / nav */
header.top{padding:22px max(22px,5vw);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  border-bottom:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.025),transparent)}
.brand{display:flex;align-items:center;gap:18px}
.logo{height:clamp(42px,5vw,58px);width:auto;filter:drop-shadow(0 6px 22px rgba(58,168,238,.28))}
nav.main{display:flex;gap:6px;flex-wrap:wrap}
nav.main a{font-family:'Sora',sans-serif;font-weight:500;font-size:.88rem;color:var(--ink-soft);padding:8px 14px;border-radius:10px;transition:.15s}
nav.main a:hover{color:var(--ink);background:rgba(255,255,255,.04)}
nav.main a.active{color:var(--accent);background:rgba(58,168,238,.12)}
.userbox{display:flex;align-items:center;gap:14px;font-size:.85rem;color:var(--ink-soft)}
.userbox b{color:var(--ink);font-weight:600}

main{padding:0 max(22px,5vw);max-width:1200px;margin:0 auto}
.pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin:30px 0 6px}
.pagehead h1{font-family:'Sora',sans-serif;font-weight:700;font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.03em}
.pagehead .sub{font-size:.85rem;color:var(--ink-soft);margin-top:4px}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;
  border:1px solid rgba(251,191,36,.35);color:var(--gold);padding:7px 14px;border-radius:100px;background:rgba(251,191,36,.07);white-space:nowrap}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(251,191,36,.5);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(251,191,36,.5)}70%{box-shadow:0 0 0 7px rgba(251,191,36,0)}100%{box-shadow:0 0 0 0 rgba(251,191,36,0)}}

/* KPIs */
.summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(205px,1fr));gap:16px;margin:24px 0 12px}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.kpi{background:linear-gradient(155deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;position:relative;overflow:hidden;box-shadow:var(--shadow);animation:rise .6s cubic-bezier(.2,.7,.2,1) backwards}
.kpi:nth-child(2){animation-delay:.08s}.kpi:nth-child(3){animation-delay:.16s}.kpi:nth-child(4){animation-delay:.24s}
.kpi::after{content:"";position:absolute;width:140px;height:140px;border-radius:50%;top:-60px;right:-40px;background:var(--accent);opacity:.16;filter:blur(40px)}
.kpi.cargo::after{background:var(--cargo)}.kpi.favor::after{background:var(--favor)}
.kpi .lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft);font-weight:700;position:relative}
.kpi .val{font-family:'JetBrains Mono',monospace;font-size:1.7rem;font-weight:600;margin-top:10px;letter-spacing:-.03em;position:relative}
.kpi .val.cargo{color:var(--cargo)}.kpi .val.favor{color:var(--favor)}
.kpi .sub{font-size:.74rem;color:var(--ink-soft);margin-top:5px;position:relative}

/* Secciones / tablas */
section{margin-top:34px}
.sec-head{display:flex;align-items:center;gap:13px;margin-bottom:16px}
.sec-head h2{font-family:'Sora',sans-serif;font-weight:600;font-size:1.2rem;letter-spacing:-.02em;display:flex;align-items:center;gap:11px}
.sec-head h2::before{content:"";width:10px;height:10px;border-radius:3px;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 0 12px rgba(58,168,238,.5)}
.sec-head .hint{font-size:.8rem;color:var(--ink-soft)}
.sec-head .n{margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:.76rem;color:var(--accent);background:rgba(58,168,238,.1);padding:4px 11px;border-radius:100px}
.scroll{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(155deg,rgba(255,255,255,.02),transparent)}
table{width:100%;border-collapse:collapse;font-size:.85rem}
th{text-align:left;font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);padding:13px 12px;border-bottom:1px solid var(--line);white-space:nowrap;background:rgba(255,255,255,.015)}
th.r,td.r{text-align:right}th.c,td.c{text-align:center}
td{padding:9px 12px;border-bottom:1px solid var(--line-2)}
tbody tr{transition:background .15s}tbody tr:hover{background:rgba(58,168,238,.05)}
tbody tr:last-child td{border-bottom:none}
.month-row td:first-child{font-weight:700;font-family:'Sora',sans-serif}
.totrow td{border-top:1.5px solid var(--accent);font-weight:700;background:rgba(58,168,238,.07)}
.pos{color:var(--cargo);font-weight:600}.neg{color:var(--favor);font-weight:600}
.chip{font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:100px}
.chip.pm{background:rgba(58,168,238,.14);color:var(--accent)}.chip.pf{background:rgba(251,191,36,.14);color:var(--gold)}
.chip.emit{background:rgba(24,205,176,.14);color:var(--favor)}.chip.recib{background:rgba(251,113,133,.14);color:var(--cargo)}
.chip.no{background:rgba(255,255,255,.06);color:var(--ink-soft)}

/* Form */
.card{background:linear-gradient(155deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
label{font-size:.74rem;color:var(--ink-soft);font-weight:700;display:block;margin-bottom:6px}
input,select{font-family:inherit;font-size:.88rem;color:var(--ink);background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:9px 11px;width:100%;transition:.15s}
input.num{font-family:'JetBrains Mono',monospace;text-align:right}
select{cursor:pointer}option{background:var(--surface)}
input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(58,168,238,.16);background:var(--surface)}
input[type=checkbox]{width:auto;accent-color:var(--accent);transform:scale(1.25);cursor:pointer}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}
button,.btn{font-family:'Sora',sans-serif;cursor:pointer;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-size:.86rem;font-weight:600;padding:10px 16px;transition:.18s;display:inline-block}
button:hover,.btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
button.primary,.btn.primary{border:none;background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#04121f;font-weight:800;box-shadow:0 8px 24px -6px rgba(58,168,238,.45)}
button.primary:hover,.btn.primary:hover{filter:brightness(1.08);color:#04121f;transform:translateY(-2px)}
button.del{padding:4px 10px;color:var(--cargo);border-color:transparent;background:transparent;font-size:1.1rem;line-height:1}
button.del:hover{background:rgba(251,113,133,.12);border-color:rgba(251,113,133,.3);color:var(--cargo);transform:none}
.note{font-size:.82rem;color:#c4cee0;background:rgba(58,168,238,.07);border:1px solid rgba(58,168,238,.18);border-left:3px solid var(--accent);padding:12px 15px;border-radius:0 10px 10px 0;margin:14px 0;line-height:1.6}
.note b{color:#fff}
.legend{font-size:.76rem;color:var(--ink-soft);margin-top:14px;display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.legend b{color:var(--ink);font-weight:600}
.flash{padding:12px 16px;border-radius:12px;margin:16px 0;font-size:.88rem}
.flash.ok{background:rgba(24,205,176,.12);border:1px solid rgba(24,205,176,.3);color:#7ff0d8}
.flash.err{background:rgba(251,113,133,.12);border:1px solid rgba(251,113,133,.3);color:#ffb3c0}
footer{max-width:1200px;margin:48px auto 0;padding:22px max(22px,5vw);border-top:1px solid var(--line);font-size:.77rem;color:var(--ink-soft);line-height:1.65}
footer b{color:#c4cee0}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:100%;max-width:400px}
.login-card .logo{height:64px;margin:0 auto 8px;display:block}
.login-card .lema{text-align:center;color:var(--ink-soft);font-size:.85rem;margin-bottom:26px;font-family:'Sora',sans-serif}
.login-card .field{margin-bottom:16px}
.login-card button{width:100%;margin-top:6px}
@media(max-width:640px){td,th{padding:8px 7px}header.top{justify-content:center}}
