*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',system-ui,Arial,sans-serif;background:#EAF1F8;color:#1B3A5C;line-height:1.5}
a{color:#1B3A5C}
/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-box{background:#fff;padding:36px 32px;border-radius:16px;box-shadow:0 8px 30px rgba(27,58,92,.12);width:100%;max-width:380px}
.login-box h1{font-size:22px;margin-bottom:4px}
.login-box p{color:#6B7280;font-size:14px;margin-bottom:22px}
label{display:block;font-weight:600;font-size:13px;color:#475569;margin:14px 0 5px}
input,select,textarea{width:100%;padding:11px 13px;border:1.5px solid #D6E6F2;border-radius:9px;font-size:15px;color:#1B3A5C;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:#1B3A5C}
textarea{resize:vertical;min-height:64px}
.btn{background:#1B3A5C;color:#fff;border:none;border-radius:10px;padding:12px 18px;font-size:15px;font-weight:700;cursor:pointer}
.btn:hover{background:#2E5F8A}.btn:disabled{background:#9CA3AF;cursor:not-allowed}
.btn-full{width:100%;margin-top:22px}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:7px}
.btn-ghost{background:#EFF6FF;color:#1B3A5C}
.btn-green{background:#16A34A}.btn-green:hover{background:#128C3E}
.msg{margin-top:14px;padding:11px;border-radius:9px;font-weight:600;font-size:14px;display:none}
.msg.err{background:#FEE2E2;color:#991B1B;display:block}
.msg.ok{background:#D1FAE5;color:#065F46;display:block}
/* App */
.app{display:none}
.topbar{background:#1B3A5C;color:#fff;padding:14px 26px;display:flex;align-items:center;gap:14px}
.topbar img{height:34px}
.topbar h1{font-size:18px;font-weight:800}
.topbar .me{margin-left:auto;text-align:right;font-size:13px;line-height:1.3}
.topbar .me b{font-size:14px}
.topbar button{background:rgba(255,255,255,.15);color:#fff;border:none;padding:8px 14px;border-radius:8px;cursor:pointer;font-weight:700;font-size:13px}
.rolechip{display:inline-block;background:rgba(255,255,255,.2);padding:1px 8px;border-radius:20px;font-size:11px;font-weight:700;text-transform:capitalize}
.tabs{display:flex;background:#fff;border-bottom:2px solid #D6E6F2;padding:0 26px}
.tab{padding:13px 22px;font-weight:700;color:#6B7280;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px}
.tab.active{color:#1B3A5C;border-bottom-color:#1B3A5C}
.wrap{max-width:1150px;margin:0 auto;padding:24px 18px 70px}
.bar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.bar h2{font-size:20px}
.filtros{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:end}
.filtros>div{display:flex;flex-direction:column}
.filtros label{margin:0 0 3px}
.filtros input,.filtros select{padding:8px 10px;font-size:13px;min-width:140px}
.card{background:#fff;border-radius:12px;box-shadow:0 2px 14px rgba(27,58,92,.07);overflow:hidden}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 14px rgba(27,58,92,.07)}
thead{background:#1B3A5C;color:#fff}th{padding:11px 12px;text-align:left;font-size:12px;white-space:nowrap}
td{padding:11px 12px;border-bottom:1px solid #f1f5f9;font-size:13.5px;vertical-align:middle}
tbody tr:hover{background:#F8FBFE}
.badge{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;white-space:nowrap}
.b-pendiente{background:#FEF3C7;color:#92400E}
.b-en_proceso{background:#DBEAFE;color:#1E40AF}
.b-pagado{background:#D1FAE5;color:#065F46}
.acts{display:flex;gap:6px;flex-wrap:wrap}
.lnk{color:#1B3A5C;font-weight:600;text-decoration:none}
.lnk:hover{text-decoration:underline}
.muted{color:#9CA3AF}
.vacio{text-align:center;padding:40px;color:#9CA3AF}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.row2{grid-template-columns:1fr}}
/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:100;display:none;align-items:center;justify-content:center;padding:18px}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:16px;padding:26px;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;position:relative}
.modal h2{margin-bottom:14px;font-size:19px}
.x{position:absolute;top:12px;right:14px;background:none;border:none;font-size:24px;cursor:pointer;color:#6B7280}
.file-area{border:2px dashed #D6E6F2;border-radius:10px;padding:16px;text-align:center;cursor:pointer;font-size:13px;color:#6B7280}
.file-area:hover{border-color:#1B3A5C}
.dash-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:14px}
.dash-card{background:#fff;border-radius:12px;padding:15px 18px;box-shadow:0 2px 14px rgba(27,58,92,.07)}
.dash-card .n{font-size:26px;font-weight:800;line-height:1.1}
.dash-card .l{font-size:12.5px;color:#6B7280;margin-top:3px}
.hist{border-left:3px solid #D6E6F2;padding:8px 0 8px 14px;margin-left:6px}
.hist-item{margin-bottom:12px;font-size:13px}
.hist-item b{color:#1B3A5C}
/* ===== Móvil ===== */
@media(max-width:760px){
  .topbar{flex-wrap:wrap;padding:12px 16px;gap:10px}
  .topbar h1{font-size:15px}
  .topbar .me{margin-left:auto;text-align:right}
  .tabs{flex-wrap:wrap;padding:0 6px;gap:2px}
  .tab{padding:8px 9px;font-size:11.5px}
  .wrap{padding:16px 12px 60px}
  .bar h2{font-size:18px}
  .filtros input,.filtros select{min-width:0;width:100%}
  .filtros>div{flex:1 1 45%}
  /* Tablas anchas: scroll horizontal en vez de aplastarse */
  #solLista,#usrLista,#ordLista{overflow-x:auto;-webkit-overflow-scrolling:touch}
  #solLista table{min-width:780px}
  #ordLista table{min-width:720px}
  #usrLista table{min-width:560px}
  .dash-cards{grid-template-columns:repeat(2,1fr)}
  .modal{padding:20px 16px}
}
