*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0d0d10;--bg2:#131318;--bg3:#1a1a22;--bg4:#22222c;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.11);
  --text:#eeeef2;--text2:#8888a0;--text3:#55556a;
  --accent:#7c6af7;--accent2:#9d8fff;--accent-bg:rgba(124,106,247,0.13);
  --green:#3ecf8e;--green-bg:rgba(62,207,142,0.1);
  --red:#f26c6c;--red-bg:rgba(242,108,108,0.1);
  --amber:#f0a830;--amber-bg:rgba(240,168,48,0.1);
  --blue:#5ba3f5;--blue-bg:rgba(91,163,245,0.1);
  --r:10px;--rl:14px;--sw:224px;
  --font:'DM Sans',sans-serif;--mono:'DM Mono',monospace;
}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}
.shell{display:flex;min-height:100vh}
.sidebar{width:var(--sw);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:10}
.brand{display:flex;align-items:center;gap:12px;padding:22px 18px 18px;border-bottom:1px solid var(--border)}
.brand-ico{width:36px;height:36px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:#fff;flex-shrink:0}
.brand-name{font-size:15px;font-weight:600;letter-spacing:-.3px}
.brand-sub{font-size:12px;color:#9090a8;margin-top:2px;font-weight:500}
.nav{padding:14px 10px;display:flex;flex-direction:column;gap:3px;flex:1}
.nav-btn,.nav a.nav-btn{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r);border:none;background:none;color:var(--text2);font-size:13.5px;font-family:var(--font);cursor:pointer;text-align:left;width:100%;transition:all .15s;text-decoration:none}
.nav-btn:hover,.nav a.nav-btn:hover{background:var(--bg3);color:var(--text)}
.nav-btn svg{flex-shrink:0;opacity:.7}
.sidebar-foot{padding:14px 10px;border-top:1px solid var(--border)}
.btn-export{display:block;width:100%;padding:9px 12px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);color:var(--text2);font-size:13px;font-family:var(--font);cursor:pointer;transition:all .15s;text-decoration:none;text-align:center}
.btn-export:hover{background:var(--bg4);color:var(--text)}
.main{margin-left:var(--sw);flex:1;padding:32px;max-width:calc(100vw - var(--sw));overflow-x:hidden}
.pg-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.pg-header h1{font-size:22px;font-weight:600;letter-spacing:-.5px;display:flex;align-items:center;gap:10px}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:24px}
.stat{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:18px 20px}
.stat-lbl{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}
.stat-val{font-size:22px;font-weight:600;letter-spacing:-.5px;font-family:var(--mono)}
.stat-val.g{color:var(--green)}.stat-val.r{color:var(--red)}.stat-val.a{color:var(--accent2)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;margin-bottom:20px}
.panel-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border)}
.panel-hd h3{font-size:14px;font-weight:500}
.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl th{text-align:left;color:#c8c8e0;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;padding:9px 16px;border-bottom:1px solid var(--border);background:var(--bg3);white-space:nowrap}
.tbl td{padding:10px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:rgba(255,255,255,.015)}
.empty-td{text-align:center;padding:32px!important;color:#9090a8!important}
.sub{font-size:11px;color:var(--text3);margin-top:1px}
.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:500}
.badge.green{background:var(--green-bg);color:var(--green)}
.badge.red{background:var(--red-bg);color:var(--red)}
.badge.amber{background:var(--amber-bg);color:var(--amber)}
.badge.blue{background:var(--blue-bg);color:var(--blue)}
.badge.accent{background:var(--accent-bg);color:var(--accent2)}
.mn{font-family:var(--mono);font-size:12.5px}
.mn.g{color:var(--green);font-weight:500}.mn.r{color:var(--red);font-weight:500}.mn.d{color:var(--text2)}
.btn-primary{padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all .15s;text-decoration:none;display:inline-block}
.btn-primary:hover{background:var(--accent2)}
.btn-primary.full{width:100%;text-align:center}
.btn-ghost{padding:9px 18px;background:transparent;color:var(--text2);border:1px solid var(--border2);border-radius:var(--r);font-size:13px;font-family:var(--font);cursor:pointer;transition:all .15s}
.btn-ghost:hover{background:var(--bg3);color:var(--text)}
.btn-sm{padding:4px 10px;font-size:11px;background:transparent;border:1px solid var(--border2);border-radius:6px;color:var(--text2);cursor:pointer;font-family:var(--font);transition:all .15s;text-decoration:none;display:inline-block}
.btn-sm:hover{background:var(--bg3);color:var(--text)}
.btn-sm.danger:hover{border-color:var(--red);color:var(--red);background:var(--red-bg)}
.btn-sm.edit:hover{border-color:var(--accent);color:var(--accent2);background:var(--accent-bg)}
.search-inline{background:var(--bg3);border:1px solid var(--border2);color:var(--text);border-radius:var(--r);padding:6px 12px;font-size:12px;font-family:var(--font);width:200px}
.search-inline:focus{outline:none;border-color:var(--accent)}
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:100;align-items:center;justify-content:center;padding:16px}
.overlay.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--rl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}
.modal-wide{max-width:660px}
.modal-hd{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 0}
.modal-hd h2{font-size:16px;font-weight:600;letter-spacing:-.3px}
.close-btn{background:none;border:none;color:var(--text3);font-size:22px;cursor:pointer;padding:2px 8px;border-radius:6px;line-height:1}
.close-btn:hover{background:var(--bg3);color:var(--text)}
.modal-body{padding:20px;display:flex;flex-direction:column;gap:14px}
.modal-ft{display:flex;gap:10px;justify-content:flex-end;padding:0 20px 20px}
.fg{display:flex;flex-direction:column;gap:5px}
.fg label{font-size:11px;color:#c8c8e0;font-weight:500;text-transform:uppercase;letter-spacing:.5px}
.fg input,.fg select{background:var(--bg3);border:1px solid var(--border2);color:var(--text);border-radius:var(--r);padding:9px 12px;font-size:13px;font-family:var(--font);transition:border-color .15s;width:100%}
.fg input:focus,.fg select:focus{outline:none;border-color:var(--accent)}
.fg select option{background:var(--bg3)}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-stack{padding:20px;display:flex;flex-direction:column;gap:14px}
.calc-strip{display:flex;gap:1px;border-radius:var(--r);overflow:hidden;border:1px solid var(--border)}
.cs-item{flex:1;background:var(--bg3);padding:10px 14px;display:flex;flex-direction:column;gap:2px}
.cs-item.accent{background:var(--accent-bg)}
.cs-item span{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.4px}
.cs-item strong{font-size:15px;font-family:var(--mono);font-weight:500;color:var(--text)}
.cs-item.accent strong{color:var(--accent2)}
.pagos-section{border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.pagos-hd{padding:10px 14px;background:var(--bg3);font-size:12px;font-weight:500;border-bottom:1px solid var(--border)}
.hint{font-size:11px;color:var(--text3);font-weight:400;margin-left:6px}
.pago-row-hd{display:grid;grid-template-columns:48px 140px 1fr 60px 140px 32px;gap:8px;padding:7px 14px;background:var(--bg3);font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-weight:500;border-bottom:1px solid var(--border)}
.cuota-row{display:grid;grid-template-columns:48px 140px 1fr 60px 140px 32px;gap:8px;padding:8px 14px;border-bottom:1px solid var(--border);align-items:center}
.cuota-row:last-child{border-bottom:none}
.cuota-row input[type="number"],.cuota-row input[type="date"]{background:var(--bg3);border:1px solid var(--border2);color:var(--text);border-radius:6px;padding:5px 8px;font-size:12px;font-family:var(--font);width:100%}
.cuota-row input:focus{outline:none;border-color:var(--accent)}
.cuota-num{font-size:12px;font-weight:600;color:var(--text3);font-family:var(--mono)}
.cuota-pagado{display:flex;align-items:center;justify-content:center}
.cuota-pagado input[type="checkbox"]{width:16px;height:16px;cursor:pointer;accent-color:var(--green)}
.mini-tbl{width:100%;font-size:13px;border-collapse:collapse}
.mini-tbl td{padding:9px 20px;border-bottom:1px solid var(--border)}
.mini-tbl tr:last-child td{border-bottom:none}
.mini-tbl td:first-child{color:var(--text2)}
.mini-tbl td:last-child{text-align:right;font-family:var(--mono);font-weight:500}
.venc-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;padding:3px 8px;border-radius:20px;font-weight:500}
.venc-chip.vencido{background:var(--red-bg);color:var(--red)}
.venc-chip.hoy{background:var(--amber-bg);color:var(--amber)}
.venc-chip.proximo{background:var(--blue-bg);color:var(--blue)}
.venc-chip.futuro{background:var(--bg3);color:var(--text2)}
.venc-chip.pagado{background:var(--green-bg);color:var(--green)}
.periodo-pills{display:flex;gap:6px;flex-wrap:wrap}
.pill{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;border:1px solid var(--border2);color:var(--text2);text-decoration:none;transition:all .15s}
.pill:hover{background:var(--bg3);color:var(--text)}
.pill.active{background:var(--accent-bg);color:var(--accent2);border-color:var(--accent)}
.alert{padding:12px 16px;border-radius:var(--r);font-size:13px;margin-bottom:16px;border:1px solid}
.alert.success{background:var(--green-bg);color:var(--green);border-color:rgba(62,207,142,.3)}
.alert.danger{background:var(--red-bg);color:var(--red);border-color:rgba(242,108,108,.3)}
/* LOGIN */
body.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:16px}
.login-wrap{width:100%;max-width:400px}
.login-card{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--rl);padding:32px}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.login-title{font-size:18px;font-weight:600;margin-bottom:20px;letter-spacing:-.3px}
@media(max-width:900px){
  .sidebar{width:58px}
  .brand-name,.brand-sub,.nav-btn span{display:none}
  .nav-btn{justify-content:center;padding:10px}
  .main{margin-left:58px;padding:16px}
  .two-col,.fg-row{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .pago-row-hd,.cuota-row{grid-template-columns:40px 1fr 1fr 40px 1fr 28px}
}

/* MOBILE MENU */
.menu-toggle{display:none;position:fixed;top:12px;left:12px;z-index:200;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r);color:var(--text);font-size:18px;width:40px;height:40px;cursor:pointer;align-items:center;justify-content:center}
.overlay-menu{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:15;backdrop-filter:blur(2px)}
.overlay-menu.open{display:block}
.app-footer{margin-left:var(--sw);padding:14px 32px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.app-footer span{font-size:12px;color:#9090a0}

@media(max-width:768px){
  .menu-toggle{display:flex}
  .sidebar{transform:translateX(-100%);transition:transform .25s ease;width:240px;z-index:20}
  .sidebar.open{transform:translateX(0)}
  .brand-name,.brand-sub,.nav-btn span,.btn-export span{display:block}
  .nav-btn{justify-content:flex-start;padding:10px 12px}
  .main{margin-left:0;padding:60px 16px 16px}
  .app-footer{margin-left:0;padding:12px 16px}
  .two-col{grid-template-columns:1fr}
  .fg-row{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .pago-row-hd,.cuota-row{grid-template-columns:40px 1fr 1fr 40px 1fr 28px}
  .pg-header{flex-direction:column;align-items:flex-start}
  .pg-header h1{font-size:18px}
  .periodo-pills{gap:4px}
  .pill{padding:5px 10px;font-size:11px}
  .tbl th,.tbl td{padding:8px 10px;font-size:11px}
  .stat-val{font-size:18px}
  .modal{max-width:100%;margin:0 8px}
  .modal-wide{max-width:100%}
  .panel-hd{flex-wrap:wrap;gap:8px}
}
