
:root{
  --p:#2563eb;--pd:#1d4ed8;--pl:rgba(37,99,235,0.1);
  --r:#dc2626;--rl:rgba(220,38,38,0.1);
  --g:#16a34a;--gl:rgba(22,163,74,0.1);--gl2:rgba(0,0,0,0.04);
  --w:#d97706;--wl:rgba(217,119,6,0.1);
  --gray:#64748b;--txt:#1e293b;
  --sh:0 1px 3px rgba(0,0,0,0.07),0 4px 16px rgba(0,0,0,0.07);--rad:14px;
  --glass:#ffffff;--gb:rgba(0,0,0,0.06);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;min-height:100vh;color:var(--txt);background:#f1f5f9;}
/* LOGIN */
#login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#0a1628,#1e3a8a,#1e40af);padding:20px}
.lcard{background:rgba(255,255,255,0.09);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,0.18);border-radius:24px;padding:40px 28px;width:100%;max-width:360px;box-shadow:0 24px 60px rgba(0,0,0,0.5)}
.logo-a{text-align:center;margin-bottom:28px}
.logo-sh{width:64px;height:64px;background:linear-gradient(135deg,#3b82f6,#60a5fa);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px;box-shadow:0 8px 24px rgba(96,165,250,0.4)}
.logo-sh svg{fill:#fff;width:36px;height:36px}
.logo-a h1{color:#fff;font-size:20px;font-weight:700;line-height:1.2}
.logo-a p{color:rgba(255,255,255,0.55);font-size:12px;margin-top:3px}
/* FORMS */
.fg{margin-bottom:14px}
.fg label{display:block;font-size:13px;font-weight:600;margin-bottom:5px;color:#374151}
.lcard .fg label{color:rgba(255,255,255,0.8)}
.fc{width:100%;padding:11px 14px;border:1.5px solid rgba(0,0,0,0.15);border-radius:10px;font-size:14px;outline:none;transition:border-color .2s,background .2s;background:#ffffff;color:#1e293b}
.fc:focus{border-color:var(--p);background:#f8faff}
.fc::placeholder{color:#94a3b8}
.fc:-webkit-autofill{-webkit-box-shadow:0 0 0 30px #fff inset!important;-webkit-text-fill-color:#1e293b!important;border-color:rgba(0,0,0,0.2)!important}
select.fc{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231e293b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
select.fc option{background:#fff;color:#1e293b}
textarea.fc{resize:vertical;min-height:80px}
.lcard .fc{background:rgba(255,255,255,0.08);color:#fff;border-color:rgba(255,255,255,0.18)}
.lcard .fc:focus{border-color:#60a5fa;background:rgba(255,255,255,0.12)}
.lcard .fc::placeholder{color:rgba(255,255,255,0.35)}
.lcard .fc:-webkit-autofill{-webkit-box-shadow:0 0 0 30px rgba(30,58,138,0.85) inset!important;-webkit-text-fill-color:#fff!important;border-color:rgba(255,255,255,0.2)!important}
.lcard select.fc{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}
.lcard select.fc option{background:#1e3a8a;color:#fff}
/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 18px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.btn-p{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;box-shadow:0 4px 16px rgba(37,99,235,0.35)}
.btn-p:hover{background:linear-gradient(135deg,#1d4ed8,#2563eb);box-shadow:0 6px 22px rgba(37,99,235,0.45);transform:translateY(-1px)}
.btn-out{background:transparent;color:var(--p);border:1.5px solid var(--p)}
.btn-out:hover{background:var(--pl)}
.btn-gray{background:rgba(0,0,0,0.06);color:var(--txt);border:1px solid rgba(0,0,0,0.12)}
.btn-gray:hover{background:rgba(0,0,0,0.1)}
.btn-sm{padding:6px 12px;font-size:12px;border-radius:8px}
.btn-blk{width:100%}
.btn-blk:active,.btn:active{transform:scale(0.98)}
.err{background:rgba(220,38,38,0.08);color:var(--r);padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px;display:none;border:1px solid rgba(220,38,38,0.2)}
/* APP LAYOUT */
#app{display:none;min-height:100vh;flex-direction:column}
header{background:#1e3a8a;color:#fff;padding:0 14px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(255,255,255,0.1);box-shadow:0 2px 12px rgba(30,58,138,0.3)}
header h2{font-size:16px;font-weight:700;flex:1;text-align:center;color:#fff}
.hbtn{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;font-size:20px;transition:background .2s}
.hbtn:hover{background:rgba(255,255,255,0.15)}
.hbtn svg{width:20px;height:20px;fill:#fff}
.content{flex:1;padding:14px;max-width:680px;margin:0 auto;width:100%}
.bnav{background:#ffffff;display:flex;border-top:1px solid rgba(0,0,0,0.1);position:sticky;bottom:0;z-index:100;box-shadow:0 -2px 12px rgba(0,0,0,0.08)}
.ni{flex:1;display:flex;flex-direction:column;align-items:center;padding:7px 4px;cursor:pointer;border:none;background:none;color:#94a3b8;font-size:10px;font-weight:500;gap:2px;transition:color .2s}
.ni.active{color:var(--p)}.ni svg{width:22px;height:22px}
/* CARDS */
@keyframes cardIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.card{background:#ffffff;border:1px solid rgba(0,0,0,0.08);border-radius:var(--rad);padding:16px;box-shadow:var(--sh);margin-bottom:12px;transition:transform .22s ease,box-shadow .22s ease,background .22s ease;animation:cardIn .3s ease both}
.card:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.1)}
.ctit{font-size:12px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}
.sg{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.sc{background:#ffffff;border:1px solid rgba(0,0,0,0.08);border-radius:var(--rad);padding:14px;box-shadow:var(--sh);transition:transform .22s,box-shadow .22s;animation:cardIn .3s ease both}
.sc:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,0.1)}
.sv{font-size:26px;font-weight:800;color:var(--p);line-height:1}
.sl{font-size:12px;color:var(--gray);margin-top:3px}
.sc.r .sv{color:var(--r)}.sc.g .sv{color:var(--g)}
/* SEARCH */
.sbox{position:relative;margin-bottom:12px}
.sbox input{width:100%;padding:12px 14px 12px 44px;border:1.5px solid rgba(0,0,0,0.12);border-radius:12px;font-size:15px;outline:none;background:#ffffff;color:#1e293b;transition:border-color .2s,background .2s}
.sbox input:focus{border-color:var(--p);background:#f8faff}
.sbox input::placeholder{color:#94a3b8}
.sico{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}
/* AFILIADO ITEMS */
.ai{background:#ffffff;border:1px solid rgba(0,0,0,0.08);border-radius:var(--rad);padding:13px 14px;box-shadow:var(--sh);margin-bottom:8px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:transform .22s ease,background .22s ease,box-shadow .22s ease;animation:cardIn .3s ease both}
.ai:hover{transform:translateX(4px) scale(1.004);background:#f8fafc;box-shadow:0 6px 20px rgba(0,0,0,0.1)}
.ai:active{transform:scale(0.99)}
.av{width:44px;height:44px;border-radius:50%;background:rgba(37,99,235,0.1);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:var(--p);flex-shrink:0;border:2px solid rgba(37,99,235,0.2)}
.ain{flex:1;min-width:0}
.anm{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#1e293b}
.acd{font-size:12px;color:var(--gray)}
/* BADGES */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700}
.bg{background:rgba(22,163,74,0.1);color:var(--g);border:1px solid rgba(22,163,74,0.2)}
.br{background:rgba(220,38,38,0.1);color:var(--r);border:1px solid rgba(220,38,38,0.2)}
.bgr{background:rgba(0,0,0,0.06);color:#64748b;border:1px solid rgba(0,0,0,0.1)}
.bw2{background:rgba(217,119,6,0.1);color:var(--w);border:1px solid rgba(217,119,6,0.2)}
/* DETAIL HEADER */
.dh{background:linear-gradient(135deg,rgba(37,99,235,0.08),rgba(59,130,246,0.04));border:1px solid rgba(37,99,235,0.18);color:#1e293b;border-radius:var(--rad);padding:18px;margin-bottom:12px;box-shadow:0 4px 16px rgba(37,99,235,0.08)}
.dn{font-size:19px;font-weight:800}.dcc{font-size:13px;color:var(--gray);margin-top:2px}
.dbs{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.dbw{background:rgba(37,99,235,0.1);color:#2563eb;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid rgba(37,99,235,0.18)}
/* INFO ROWS */
.ir{display:flex;justify-content:space-between;align-items:flex-start;padding:9px 0;border-bottom:1px solid rgba(0,0,0,0.07);gap:8px}
.ir:last-child{border-bottom:none}
.il{font-size:13px;color:#94a3b8;flex-shrink:0}.iv{font-size:13px;font-weight:600;text-align:right;color:#1e293b}
/* MORA BANNERS */
.mb{border-radius:12px;padding:14px;margin-bottom:12px;display:flex;align-items:center;gap:12px;border:1px solid transparent}
.mb.ok{background:rgba(22,163,74,0.08);border-color:rgba(22,163,74,0.2)}
.mb.nok{background:rgba(220,38,38,0.08);border-color:rgba(220,38,38,0.2)}
.mb.par{background:rgba(217,119,6,0.08);border-color:rgba(217,119,6,0.18)}
.mi{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mb.ok .mi{background:rgba(22,163,74,0.2)}.mb.nok .mi{background:rgba(220,38,38,0.2)}.mb.par .mi{background:rgba(217,119,6,0.2)}
.mt{font-size:15px;font-weight:800}
.mb.ok .mt{color:var(--g)}.mb.nok .mt{color:var(--r)}.mb.par .mt{color:var(--w)}
.ms{font-size:12px;color:var(--gray);margin-top:2px}
/* MES GROUPS */
.mes-group{border:1px solid rgba(0,0,0,0.08);border-radius:10px;margin-bottom:8px;overflow:hidden;background:#f8fafc}
.mes-hdr{background:rgba(0,0,0,0.04);padding:8px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(0,0,0,0.07)}
.mes-hdr-n{font-size:13px;font-weight:700;color:#1e293b}.mes-hdr-s{font-size:12px;font-weight:700}
/* FORM GRIDS */
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.fi{display:flex;align-items:center;gap:8px;padding:10px;background:#f8fafc;border-radius:8px;margin-bottom:6px;border:1px solid rgba(0,0,0,0.07)}
.fi-info{flex:1}.fi-n{font-size:14px;font-weight:600;color:#1e293b}.fi-r{font-size:12px;color:var(--gray)}
/* PROGRESS BARS */
.pb-w{background:rgba(0,0,0,0.08);border-radius:8px;height:8px;overflow:hidden;margin-top:8px}
.pb{height:100%;background:linear-gradient(90deg,var(--pd),var(--p));border-radius:8px;transition:width .4s ease}.pb.r{background:linear-gradient(90deg,var(--r),#fb923c)}.pb.w2{background:linear-gradient(90deg,var(--w),#fb923c)}
/* OVERLAYS */
.ov{position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;display:none;align-items:flex-end;justify-content:center}
.ov.on{display:flex}
.mod{background:#ffffff;border:1px solid rgba(0,0,0,0.1);border-radius:20px 20px 0 0;padding:22px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:0 -4px 32px rgba(0,0,0,0.12)}
.mtit{font-size:17px;font-weight:800;margin-bottom:14px;color:#1e293b}
/* FAB */
.fab{position:fixed;bottom:76px;right:16px;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border:none;box-shadow:0 4px 20px rgba(37,99,235,0.45),0 8px 24px rgba(0,0,0,0.1);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:26px;z-index:99;transition:transform .2s,box-shadow .2s}
.fab:hover{transform:scale(1.09) translateY(-2px);box-shadow:0 8px 28px rgba(37,99,235,0.55)}
.fab:active{transform:scale(0.94)}
.stit{font-size:17px;font-weight:800;margin-bottom:12px;color:#1e293b}
/* USER ITEMS */
.uitm{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid rgba(0,0,0,0.07)}
.uitm:last-child{border-bottom:none}
.uav{width:40px;height:40px;border-radius:50%;background:rgba(37,99,235,0.1);border:2px solid rgba(37,99,235,0.2);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--p);flex-shrink:0}
/* LOADING */
#loading{position:fixed;inset:0;background:rgba(241,245,249,0.96);backdrop-filter:blur(12px);z-index:999;display:none;flex-direction:column;align-items:center;justify-content:center;gap:14px}
#loading.on{display:flex}
.spinner{width:44px;height:44px;border:3px solid rgba(37,99,235,0.2);border-top-color:var(--p);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#loading p{color:var(--p);font-weight:600;font-size:15px}
/* SYNC BAR */
.sync-bar{display:flex;align-items:center;gap:6px;font-size:11px;padding:6px 10px;border-radius:8px;margin-bottom:10px}
.sync-bar.cloud{background:rgba(22,163,74,0.08);color:#16a34a;border:1px solid rgba(22,163,74,0.18)}
.sync-bar.local{background:rgba(217,119,6,0.08);color:#d97706;border:1px solid rgba(217,119,6,0.18)}
/* PAYMENT ROWS */
.pago-row{padding:10px 12px;border-bottom:1px solid rgba(0,0,0,0.07);display:flex;justify-content:space-between;align-items:center;gap:8px}
.pago-row:last-child{border-bottom:none}
.bt-on{background:rgba(37,99,235,0.1)!important;border-radius:8px}
@media(max-width:420px){.fr2,.fr3{grid-template-columns:1fr}}
/* DASHBOARD CARDS */
.dcards{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(min-width:768px){.dcards{grid-template-columns:repeat(4,1fr)}}
.drow{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:768px){.drow{grid-template-columns:1.8fr 1fr}}
.dcard{background:#ffffff;border:1px solid rgba(0,0,0,0.08);border-radius:14px;padding:18px 16px;position:relative;overflow:hidden;transition:transform .22s ease,box-shadow .22s ease,background .22s ease;animation:cardIn .3s ease both}
.dcard:hover{background:#f8fafc;transform:translateY(-4px) scale(1.01);box-shadow:0 12px 28px rgba(0,0,0,0.1)}
.dcard:active{transform:scale(0.98)}
.dcard::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,0.6) 0%,transparent 100%);pointer-events:none}
.dcard-bar{position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0}
.dsec{background:#ffffff;border:1px solid rgba(0,0,0,0.08);border-radius:14px;padding:16px;box-shadow:var(--sh)}
.dsec-lbl{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.app-body{display:flex;flex:1;overflow:hidden;min-height:0}
/* SIDEBAR */
#sidebar{display:none;width:210px;background:#1e3a8a;flex-direction:column;flex-shrink:0;border-right:1px solid rgba(0,0,0,0.1);position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto}
.sb-logo{padding:18px 16px 14px;border-bottom:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;gap:10px}
.sb-logo-ic{width:34px;height:34px;background:linear-gradient(135deg,#3b82f6,#60a5fa);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px rgba(96,165,250,0.4)}
.sb-logo-ic svg{fill:#fff;width:20px;height:20px}
.sb-logo-txt{font-size:14px;font-weight:800;color:#e8eaf0;line-height:1.2}
.sb-logo-sub{font-size:10px;color:rgba(255,255,255,0.5);margin-top:1px}
.sb-sect{padding:14px 16px 4px;font-size:9px;font-weight:700;color:rgba(255,255,255,0.45);text-transform:uppercase;letter-spacing:.8px}
.sbi{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;color:rgba(255,255,255,0.6);font-size:13px;font-weight:500;border:none;background:none;width:100%;text-align:left;transition:all .15s;border-left:3px solid transparent;border-radius:0 8px 8px 0;margin:1px 0}
.sbi:hover{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.95)}
.sbi.active{background:rgba(255,255,255,0.18);color:#fff;border-left-color:#60a5fa}
.sbi svg{width:18px;height:18px;fill:currentColor;flex-shrink:0}
@media(min-width:768px){
  #sidebar{display:flex}
  .bnav{display:none!important}
  .content{overflow-y:auto;height:calc(100vh - 56px)}
}
