/* ============ Créditos · Mhervin — estilos ============ */
:root{
  --navy:#16284a; --navy-2:#1f3864; --navy-soft:#2c4a7c;
  --gold:#bf9000; --gold-2:#d9af2e; --gold-bg:#f4ead0;
  --terra:#b5532e;
  --paper:#f6f2ea; --paper-2:#fffdf8; --card:#fffdf8;
  --ink:#1a1d24; --ink-soft:#54504a; --muted:#7a746c;
  --good:#2f6e4f; --good-bg:#e4f0e8;
  --line:#e3d9c6; --line-2:#efe7d6;
  --shadow:0 1px 2px rgba(22,40,74,.06), 0 8px 26px rgba(22,40,74,.08);
  --radius:14px; --maxw:1180px;
  --fs-base:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:var(--fs-base);-webkit-text-size-adjust:100%}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--paper);color:var(--ink);line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,4vw,28px)}
a{color:var(--navy-2);text-underline-offset:2px}
h1,h2,h3{line-height:1.15;letter-spacing:-.01em;color:var(--navy)}
.mono{font-variant-numeric:tabular-nums}

/* accesibilidad */
.skip{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip:focus{left:0}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px}
.muted{color:var(--muted)}

/* ---------- topbar ---------- */
.topbar{background:linear-gradient(120deg,var(--navy),var(--navy-2));color:#f6f1e6;position:sticky;top:0;z-index:50;box-shadow:0 2px 12px rgba(0,0,0,.12)}
.topbar-inner{display:flex;align-items:center;gap:16px;min-height:62px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-weight:800;font-size:1.05rem}
.brand-mark{width:30px;height:30px;border-radius:8px;background:var(--gold);color:var(--navy);display:grid;place-items:center;font-weight:800;flex:none}
.navmenu{margin-left:auto;display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.navmenu a{color:#e7ecf6;text-decoration:none;padding:8px 13px;border-radius:9px;font-weight:600;font-size:.94rem}
.navmenu a:hover{background:rgba(255,255,255,.12)}
.navmenu a[aria-current=page]{background:var(--gold);color:var(--navy)}
.nav-user{color:#cdd6e8;font-size:.8rem;padding:0 8px;border-left:1px solid rgba(255,255,255,.22);margin-left:6px}
.nav-logout{background:rgba(255,255,255,.1)}
.nav-toggle{display:none;margin-left:auto;background:rgba(255,255,255,.12);border:0;width:44px;height:40px;border-radius:9px;cursor:pointer;flex-direction:column;gap:4px;align-items:center;justify-content:center}
.nav-toggle span{width:20px;height:2px;background:#fff;border-radius:2px;transition:.2s}

/* ---------- page header ---------- */
.page-head{padding:30px 0 6px}
.page-head .eyebrow{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700}
.page-head h1{font-size:clamp(1.5rem,4vw,2.1rem);font-weight:800;margin-top:6px}
.page-head p{color:var(--ink-soft);max-width:70ch;margin-top:6px}
section.block{padding:22px 0}

/* ---------- cards / KPIs ---------- */
.grid{display:grid;gap:16px}
.kpis{grid-template-columns:repeat(4,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.kpi .lbl{font-size:.8rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-soft)}
.kpi .val{font-size:1.7rem;font-weight:800;color:var(--navy);margin-top:6px;letter-spacing:-.02em}
.kpi .sub{font-size:.82rem;color:var(--muted);margin-top:4px}
.kpi.accent{background:linear-gradient(160deg,var(--navy),var(--navy-2));border-color:var(--navy-2);color:#fff}
.kpi.accent .lbl{color:var(--gold-2)} .kpi.accent .val{color:#fff} .kpi.accent .sub{color:#cdd6e8}
.kpi.gold{background:linear-gradient(160deg,#caa01e,#bf9000);border-color:#a87f00;color:#fff}
.kpi.gold .lbl,.kpi.gold .sub{color:#fff6dd} .kpi.gold .val{color:#fff}

/* credit summary card */
.credit-card h3{display:flex;justify-content:space-between;align-items:center;font-size:1.15rem;font-weight:800}
.credit-card .pill{font-size:.72rem;font-weight:700;background:var(--gold-bg);color:#7a5c00;padding:3px 9px;border-radius:7px}
.kv{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px dashed var(--line);font-size:.92rem}
.kv:last-of-type{border-bottom:0}
.kv .k{color:var(--ink-soft)} .kv .v{font-weight:700}
.prog{height:9px;background:var(--gold-bg);border-radius:6px;overflow:hidden;margin:12px 0 5px}
.prog>span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-2))}
.prog-lbl{display:flex;justify-content:space-between;font-size:.8rem;color:var(--muted)}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}

/* highlight Javier vs Mhervin */
.who-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.who{border-radius:12px;padding:16px;border:1px solid var(--line)}
.who.j{background:linear-gradient(165deg,#fbf4e4,#f4ead0)}
.who.m{background:linear-gradient(165deg,#eef2f8,#e3eaf5)}
.who .nm{font-weight:800;font-size:.95rem;display:flex;align-items:center;gap:8px}
.who .dot{width:10px;height:10px;border-radius:50%}
.who.j .dot{background:var(--gold)} .who.m .dot{background:var(--navy-2)}
.who .amt{font-size:1.5rem;font-weight:800;color:var(--navy);margin:7px 0 2px}
.who .note{font-size:.8rem;color:var(--ink-soft)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;font:inherit;font-weight:700;font-size:.9rem;
  border-radius:10px;padding:9px 15px;cursor:pointer;text-decoration:none;border:1px solid transparent;transition:.15s}
.btn.primary{background:var(--navy-2);color:#fff}.btn.primary:hover{background:var(--navy)}
.btn.gold{background:var(--gold);color:var(--navy)}.btn.gold:hover{background:var(--gold-2)}
.btn.ghost{background:var(--paper-2);color:var(--navy);border-color:var(--line)}.btn.ghost:hover{border-color:var(--navy-soft)}
.btn.sm{padding:6px 11px;font-size:.82rem}

/* ---------- tables ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:var(--card);-webkit-overflow-scrolling:touch}
table.data{border-collapse:collapse;width:100%;min-width:640px;font-size:.88rem}
table.data caption{text-align:left;padding:12px 14px;font-weight:800;color:var(--navy);background:var(--paper-2);border-bottom:1px solid var(--line)}
table.data th,table.data td{padding:9px 12px;text-align:right;white-space:nowrap}
table.data th:first-child,table.data td:first-child,
table.data th.l,table.data td.l{text-align:left}
table.data thead th{background:var(--navy-2);color:#fff;position:sticky;top:0;font-weight:700;font-size:.8rem}
table.data tbody tr:nth-child(even){background:#fbf6ec}
table.data tbody tr:hover{background:var(--gold-bg)}
table.data tfoot td{background:var(--navy);color:#fff;font-weight:800;border-top:2px solid var(--gold)}
.estado{font-weight:700;font-size:.78rem;padding:2px 8px;border-radius:6px}
.estado.pag{background:var(--good-bg);color:var(--good)}
.estado.pen{background:#f3e3da;color:var(--terra)}

/* ---------- deposits ---------- */
.dep-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.dep-list{margin-top:18px;display:grid;gap:10px}
.dep-row{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 16px;box-shadow:var(--shadow);flex-wrap:wrap}
.dep-row.done{border-color:#bcdcc8;background:linear-gradient(90deg,#f0f8f2,var(--card))}
.dep-row.venc{border-left:4px solid var(--terra)}
.dep-row .when{min-width:120px}
.dep-row .when .m{font-weight:800;color:var(--navy)}
.dep-row .when .d{font-size:.78rem;color:var(--muted)}
.dep-row .amt{font-size:1.15rem;font-weight:800;color:var(--navy);margin-left:auto}
.dep-row .amt small{display:block;font-size:.72rem;color:var(--muted);font-weight:600}
.dep-state{min-width:120px;text-align:right}
.badge{display:inline-block;font-size:.72rem;font-weight:800;padding:3px 9px;border-radius:7px}
.badge.venc{background:var(--terra);color:#fff}
.badge.ok{background:var(--good);color:#fff}
.chk{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-weight:700;font-size:.85rem}
.chk input{width:22px;height:22px;accent-color:var(--good);cursor:pointer}

/* ---------- forms / filters ---------- */
.filters{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;box-shadow:var(--shadow)}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:.8rem;font-weight:700;color:var(--ink-soft)}
.field input,.field select{font:inherit;font-size:.95rem;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink);min-height:42px}
.field input:focus,.field select:focus{border-color:var(--navy-soft)}

/* ---------- alerts ---------- */
.alert{border-radius:12px;padding:14px 18px;font-size:.92rem;margin:14px 0}
.alert.warn{background:#fbeee7;border:1px solid #e3b9a4;border-left:4px solid var(--terra);color:#7a3318}
.alert.info{background:var(--gold-bg);border:1px solid #e6d18f;border-left:4px solid var(--gold);color:#5e4a12}
.alert.ok{background:var(--good-bg);border:1px solid #bcdcc8;border-left:4px solid var(--good);color:#235c3f}

/* ---------- login ---------- */
.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(900px 500px at 20% -10%,rgba(191,144,0,.18),transparent 60%),linear-gradient(160deg,var(--navy),var(--navy-2))}
.login-card{background:var(--paper-2);border-radius:18px;box-shadow:0 30px 70px rgba(0,0,0,.4);max-width:420px;width:100%;overflow:hidden}
.login-card .lc-top{background:linear-gradient(120deg,var(--navy),var(--navy-2));color:#fff;padding:26px 28px}
.login-card .lc-top .badge-lock{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);font-weight:700}
.login-card .lc-top h1{color:#fff;font-size:1.5rem;font-weight:800;margin-top:6px}
.login-card .lc-top p{color:#cdd6e8;font-size:.86rem;margin-top:4px}
.login-card form{padding:24px 28px 28px;display:grid;gap:14px}
.login-card .field input{min-height:46px}
.login-card .btn{justify-content:center;width:100%;padding:13px;font-size:1rem}

/* sheet (planilla) selector */
.sheet-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 16px}
.sheet-tabs a{padding:8px 14px;border-radius:9px;border:1px solid var(--line);background:var(--card);text-decoration:none;color:var(--navy);font-weight:700;font-size:.88rem}
.sheet-tabs a[aria-current=page]{background:var(--navy-2);color:#fff;border-color:var(--navy-2)}

.section-title{display:flex;align-items:baseline;gap:12px;margin:26px 0 14px}
.section-title h2{font-size:1.3rem;font-weight:800}
.section-title .rule{flex:1;height:1px;background:var(--line)}

.site-foot{background:var(--navy);color:#c8d2e6;padding:24px 0;margin-top:36px;font-size:.84rem;text-align:center}
.site-foot a{color:var(--gold-2)}
.site-foot .muted{color:#9aa6bd}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:1fr}
  .dep-summary{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav-toggle{display:flex}
  .navmenu{display:none;position:absolute;left:0;right:0;top:62px;background:var(--navy);flex-direction:column;align-items:stretch;gap:2px;padding:10px 16px 16px;box-shadow:0 16px 30px rgba(0,0,0,.3)}
  .navmenu.open{display:flex}
  .navmenu a{padding:12px 14px}
  .nav-user{border-left:0;padding:8px 14px 4px}
  .g2,.who-grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  .kpis{grid-template-columns:1fr}
  .dep-row .amt{margin-left:0;width:100%}
  .dep-state{text-align:left;min-width:0}
}
@media print{
  .topbar,.site-foot,.btn,.filters,.nav-toggle,.skip{display:none!important}
  body{background:#fff}
  .table-wrap{border:0;overflow:visible}
  table.data{min-width:0;font-size:11px}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
