:root{
    --bg:#07111f;
    --panel:rgba(15,23,42,.84);
    --panel-strong:rgba(15,23,42,.92);
    --soft:#1f2937;
    --text:#e5e7eb;
    --muted:#94a3b8;
    --green:#14532d;
    --yellow:#854d0e;
    --red:#7f1d1d;
    --blue:#1d4ed8;
    --border:#334155;
    --glass:rgba(148,163,184,.22);
}
*{box-sizing:border-box}
body{margin:0;background:
    linear-gradient(135deg,#07111f 0%,#0f172a 45%,#111827 100%),
    repeating-linear-gradient(135deg,rgba(255,255,255,.035) 0 1px,transparent 1px 18px);
    color:var(--text);font-family:Arial,Helvetica,sans-serif;min-height:100vh}
.container{max-width:1600px;margin:0 auto;padding:24px}
.topbar{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:22px;padding:22px 24px;border:1px solid rgba(148,163,184,.22);border-radius:18px;background:linear-gradient(145deg,rgba(15,23,42,.88),rgba(15,23,42,.72));box-shadow:0 24px 70px rgba(0,0,0,.28);backdrop-filter:blur(14px)}
.topbar h1{margin:0 0 6px 0;font-size:30px;line-height:1}
.muted{color:var(--muted);margin:0}
.nav{display:flex;gap:10px;flex-wrap:wrap}
.nav a{background:linear-gradient(145deg,rgba(15,23,42,.95),rgba(30,41,59,.82));color:var(--text);text-decoration:none;padding:11px 14px;border-radius:12px;border:1px solid rgba(148,163,184,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 10px 25px rgba(0,0,0,.18);transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.nav a:hover{transform:translateY(-1px);border-color:rgba(34,197,94,.45);box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 14px 28px rgba(0,0,0,.24)}
.card{background:var(--panel);border:1px solid rgba(148,163,184,.22);border-radius:18px;padding:20px;margin-bottom:18px;box-shadow:0 20px 60px rgba(0,0,0,.22);backdrop-filter:blur(12px)}
.card h2,.card h3{margin:0 0 10px 0;color:#f8fafc}
.page-intro{display:grid;gap:14px;background:linear-gradient(145deg,rgba(15,23,42,.95),rgba(8,47,73,.34))}
.scan-search-card{border-color:rgba(34,197,94,.22)}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(min(100%,420px),1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr))}
label{display:block;margin-bottom:6px;font-weight:bold}
input,select,textarea,button{width:100%;padding:11px 13px;border-radius:12px;border:1px solid var(--border);background:#020617;color:var(--text)}
input:focus,select:focus,textarea:focus{outline:2px solid rgba(34,197,94,.32);border-color:#22c55e}
button,.btn{background:linear-gradient(135deg,#16a34a,#0284c7);cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;width:auto;min-height:42px;border-radius:12px;border:1px solid rgba(255,255,255,.06);color:#fff;font-weight:bold;letter-spacing:.01em;box-shadow:0 14px 30px rgba(2,132,199,.18),inset 0 1px 0 rgba(255,255,255,.12);transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}
button:hover,.btn:hover{transform:translateY(-1px);filter:saturate(1.05);box-shadow:0 18px 34px rgba(2,132,199,.24),inset 0 1px 0 rgba(255,255,255,.14)}
.btn-secondary{background:linear-gradient(145deg,rgba(15,23,42,.95),rgba(51,65,85,.9))}
.btn-green{background:linear-gradient(135deg,#166534,#15803d)}
.btn-yellow{background:linear-gradient(135deg,#b45309,#d97706)}
.btn-red{background:linear-gradient(135deg,#991b1b,#dc2626)}
table{width:100%;border-collapse:collapse}
th,td{padding:12px 10px;border-bottom:1px solid rgba(148,163,184,.14);text-align:left;font-size:14px;vertical-align:top}
th{color:#dbeafe;background:rgba(2,6,23,.42);font-size:12px;text-transform:uppercase;letter-spacing:.05em}
td{overflow-wrap:break-word;word-break:normal}
.table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-scroll table{min-width:1100px}
.table-card{background:linear-gradient(145deg,rgba(15,23,42,.94),rgba(15,23,42,.82))}
.table-card .table-scroll{margin-top:10px}
.data-table th,.data-table td{max-width:none;white-space:normal}
.data-table tbody tr:nth-child(even) td{background:rgba(2,6,23,.14)}
.data-table tbody tr:hover td{background:rgba(14,165,233,.08)}
.users-table input,.users-table select{min-width:140px}
.users-table td:last-child{min-width:220px}
.wide-card{grid-column:1/-1}
.icon-btn{width:38px;height:38px;padding:0}
.icon-btn svg{width:20px;height:20px;fill:currentColor}
.badge{padding:5px 10px;border-radius:999px;font-size:12px;font-weight:bold;display:inline-block}
.badge.CARGADO{background:#1e3a8a}
.badge.ENVIADO_INTENDENCIA{background:#4338ca}
.badge.AUTORIZADO{background:#065f46}
.badge.RECHAZADO{background:#7c2d12}
.badge.EN_TRANSFERENCIAS{background:#92400e}
.badge.PAGO_PARCIAL{background:#a16207}
.badge.PAGADO,.badge.CERRADO{background:#14532d}
.badge.ANULADO{background:#7f1d1d}
.badge.PENDIENTE{background:#1e40af}
.badge.VERIFICADO{background:#166534}
.badge.RECHAZADO{background:#991b1b}
.badge.ACTIVO{background:#0f766e}
.badge.UTILIZADO{background:#475569}
.badge.VENCIDO{background:#9a3412}
.badge.ANULADO{background:#7f1d1d}
.flash{padding:14px;border-radius:8px;margin-bottom:16px}
.flash.success{background:#052e16}
.flash.error{background:#450a0a}
.flash.warning{background:#451a03}
input[type="file"]{padding:9px 12px;background:#020617}
.copy-box{display:grid;gap:6px;margin-top:14px}
.copy-box input{font-size:13px}
.scan-ok{background:#052e16;border:1px solid #166534}
.scan-warn{background:#3f2a04;border:1px solid #a16207}
.scan-bad{background:#3f1111;border:1px solid #991b1b}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));gap:12px}
.result-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));gap:12px;margin:12px 0 16px}
.stat-card{padding:14px;border:1px solid rgba(148,163,184,.18);border-radius:14px;background:linear-gradient(145deg,rgba(2,6,23,.48),rgba(15,23,42,.76));box-shadow:inset 0 1px 0 rgba(255,255,255,.03)}
.stat-label{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.stat-value{display:block;margin-top:8px;font-size:28px;line-height:1;color:#f8fafc}
.stat-value-sm{font-size:18px}
.accent-total{border-color:rgba(34,197,94,.26)}
.accent-transfer{border-color:rgba(14,165,233,.28)}
.accent-check{border-color:rgba(245,158,11,.28)}
.small{font-size:12px;color:var(--muted)}
.checkbox-line{display:flex;align-items:center;gap:10px;font-weight:bold}
.checkbox-line input{width:auto}
.payment-box{background:#0b1220;border:1px solid var(--border);border-radius:8px;padding:14px}
.paid-fields{margin-top:14px}
.section-header{display:flex;justify-content:space-between;gap:18px;align-items:end;margin-bottom:16px}
.summary-filter{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:12px;align-items:end}
.admin-summary-card{background:linear-gradient(145deg,rgba(15,23,42,.94),rgba(8,47,73,.48))}
.actions form{display:inline-flex}
.inline-payment-form{display:grid;gap:10px;min-width:260px}
.inline-payment-form input,.inline-payment-form select{font-size:13px}
.inline-payment-form button{width:100%}
.page-intro .actions{margin-top:4px}
.table-toolbar{display:flex;justify-content:space-between;gap:14px;align-items:center;margin-bottom:10px}
.table-toolbar .small{margin:0}
.login-page{min-height:100vh;background:
    linear-gradient(135deg,#07111f 0%,#0f172a 45%,#111827 100%),
    repeating-linear-gradient(135deg,rgba(255,255,255,.04) 0 1px,transparent 1px 18px)}
.login-page .container{max-width:1120px;min-height:100vh;display:flex;flex-direction:column;justify-content:center}
.login-page .topbar{display:none}
.login-shell{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(360px,.75fr);gap:28px;align-items:center}
.login-hero{position:relative;overflow:hidden;min-height:520px;border:1px solid rgba(148,163,184,.22);border-radius:8px;padding:48px;background:
    linear-gradient(145deg,rgba(15,23,42,.78),rgba(15,118,110,.20)),
    repeating-linear-gradient(135deg,rgba(255,255,255,.045) 0 1px,transparent 1px 18px);
    box-shadow:0 30px 90px rgba(0,0,0,.35)}
.login-kicker{display:inline-block;margin-bottom:22px;padding:8px 12px;border-radius:999px;background:rgba(34,197,94,.13);color:#bbf7d0;border:1px solid rgba(187,247,208,.24);font-weight:bold;font-size:13px}
.login-hero h2{position:relative;max-width:650px;margin:0;color:#f8fafc;font-size:54px;line-height:.98;letter-spacing:0}
.login-hero p{position:relative;max-width:520px;margin:22px 0 0;color:#cbd5e1;font-size:18px;line-height:1.55}
.login-stats{position:absolute;left:48px;right:48px;bottom:42px;display:flex;gap:12px;flex-wrap:wrap}
.login-stats span{padding:11px 14px;border:1px solid rgba(203,213,225,.24);border-radius:8px;background:rgba(2,6,23,.38);color:#e2e8f0}
.login-card{border:1px solid rgba(148,163,184,.24);border-radius:8px;padding:30px;background:rgba(15,23,42,.84);box-shadow:0 28px 80px rgba(0,0,0,.42);backdrop-filter:blur(14px)}
.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.login-brand span{display:grid;place-items:center;width:52px;height:52px;border-radius:8px;background:linear-gradient(135deg,#22c55e,#0ea5e9);font-weight:900;color:#02111f}
.login-brand strong{display:block;font-size:22px;color:#f8fafc}
.login-brand small{display:block;margin-top:4px;color:var(--muted)}
.login-form{display:grid;gap:16px}
.login-form label{color:#dbeafe}
.login-form input{min-height:48px;background:#020617;border-color:#334155}
.login-form input:focus{outline:2px solid rgba(34,197,94,.32);border-color:#22c55e}
.login-form button{width:100%;min-height:50px;margin-top:4px;border:0;background:linear-gradient(135deg,#16a34a,#0284c7);font-weight:bold;color:white}
.login-note{margin:18px 0 0;color:#94a3b8;font-size:13px;line-height:1.45}
.public-upload-page{min-height:100vh;background:
    linear-gradient(135deg,#0f172a 0%,#1e293b 45%,#0f172a 100%),
    repeating-linear-gradient(135deg,rgba(255,255,255,.04) 0 1px,transparent 1px 18px)}
.public-upload-page .container{max-width:900px;min-height:100vh;display:flex;align-items:center;justify-content:center}
.public-upload-page .topbar{display:none}
.public-upload-shell{width:100%}
.public-upload-card{max-width:760px;margin:0 auto}
.public-upload-form{display:grid;gap:16px}
@media (max-width:860px){
    .login-shell{grid-template-columns:1fr}
    .login-hero{min-height:auto;padding:30px}
    .login-hero h2{font-size:38px}
    .login-stats{position:relative;left:auto;right:auto;bottom:auto;margin-top:28px}
    .container{padding:14px}
    .topbar{display:block}
    .nav{margin-top:14px}
    .section-header{align-items:stretch;flex-direction:column}
    .summary-filter{grid-template-columns:1fr}
    .table-scroll table{min-width:760px}
}
