*{box-sizing:border-box;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
body{background:#f4f7fb;color:#123}
a{color:#0b3a66;text-decoration:none}
a:hover{text-decoration:underline}
.top{background:#0b3a66;color:#fff;padding:10px 12px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between}
.top h1{font-size:18px;margin-bottom:4px}
.top nav a{color:#fff;margin-right:10px;font-size:14px;padding:4px 8px;border-radius:8px}
.top nav a.active,.top nav a:hover{background:#fff;color:#0b3a66;text-decoration:none}
section{padding:10px 12px}
.card{background:#fff;border-radius:14px;padding:12px 14px;margin:10px 0;box-shadow:0 1px 4px rgba(0,0,0,.08)}
h2{font-size:16px;margin-bottom:8px}
h3{font-size:14px;margin:8px 0}
label{display:block;font-size:13px;margin:6px 0}
input,select,textarea,button{width:100%;padding:7px 8px;margin-top:3px;border-radius:10px;border:1px solid #c5d0e6;font-size:13px}
textarea{min-height:70px;resize:vertical}
button{background:#0b3a66;color:#fff;border:none;font-weight:600;cursor:pointer}
button:hover{filter:brightness(.97)}
.ok{background:#e2ffef;color:#13512b;margin:8px 12px;padding:8px 10px;border-radius:10px;font-size:13px}
.error{background:#ffe8e6;color:#7a1414;margin:8px 0;padding:8px 10px;border-radius:10px;font-size:13px}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;font-size:12px;margin:8px 0;background:#fff;border-radius:12px;}
th,td{padding:6px 8px;border-bottom:1px solid #e1e7f2;text-align:left;white-space:nowrap}
th{background:#eef3fb;font-weight:600}
tr:nth-child(even){background:#fafbff}
tr.row-debe{background:#ffecec}
.badge{display:inline-block;padding:2px 6px;border-radius:999px;font-size:11px;border:1px solid #d0d7ea}
.badge-elem{background:#0b3a66;color:#fff;padding:2px 8px;border-radius:999px;font-size:11px}
.st{padding:2px 6px;border-radius:999px;font-size:11px;font-weight:600}
.st.aldia{background:#daf5e3;color:#145c32}
.st.debe{background:#ffe0e0;color:#923131}
.st.pend{background:#fff4cf;color:#8b5a07}
.kpi{background:#fff;border-radius:14px;padding:10px 12px;display:inline-block;margin:8px 0;box-shadow:0 1px 4px rgba(0,0,0,.06);font-size:13px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.row{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.row label{flex:1}
.btn{display:inline-block;padding:4px 8px;border-radius:8px;border:1px solid #c5d0e6;font-size:12px;margin-right:4px;background:#fff}
.btn:hover{background:#eef3fb;text-decoration:none}
.btn.danger{border-color:#d53b3b;color:#d53b3b}
.btn.danger:hover{background:#ffe4e4}
.btn.warn{border-color:#e6a500;color:#a56b00}
.login-body{display:flex;align-items:center;justify-content:center;height:100vh;background:radial-gradient(circle at top,#e4efff,#f5f7fb)}
.login-card{background:#fff;border-radius:18px;box-shadow:0 10px 30px rgba(0,0,0,.12);padding:24px 22px;width:100%;max-width:340px}
.login-card h1{text-align:center;margin-bottom:10px;color:#0b3a66}
.login-card button{margin-top:10px}
@media(max-width:768px){
 .grid2{grid-template-columns:1fr}
 .top{flex-direction:column;align-items:flex-start}
 .top nav{margin-top:6px}
}
/* --- TABLAS GENERALES --- */
.table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.table-wrap table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
    margin: 8px 0;
    background: #fff;
    border-radius: 12px;
}

.table-wrap table th,
.table-wrap table td {
    padding: 6px 8px;
    border-bottom: 1px solid #e1e7f2;
    text-align: left;
    white-space: nowrap;
}

/* Alternado */
.table-wrap table tbody tr:nth-child(even) { background: #fafbff; }
.table-wrap table tbody tr.row-debe { background: #ffecec; }

/* Hover escritorio */
.table-wrap table tbody tr:hover { background-color: #f0f8ff; }
.table-wrap table tbody tr.row-debe:hover { background-color: #ffe5e5; }

/* Fila activa */
.table-wrap table tbody tr.fila-activa {
    background-color: #fff3cd;
    box-shadow: inset 0 0 0 2px #ffca2c;
}
.table-wrap table tbody tr.row-debe.fila-activa {
    background-color: #ffd4d4;
    box-shadow: inset 0 0 0 2px #ff6b6b;
}

/* --- COLUMNA CLIENTE FIJA (solo móvil) --- */
@media (max-width: 768px) {

    .table-wrap table {
        width: max-content;
        min-width: 100%;
        border-collapse: separate;
        border-spacing: 0;
    }

    .table-wrap table th:first-child,
    .table-wrap table td:first-child {
        position: sticky;
        left: 0;
        background: #fff;
        z-index: 20;
        min-width: 120px;
        max-width: 220px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
}
.kpi {
  padding: 12px 16px;
  border-radius: 6px;
  background: #f4f6f8;
  min-width: 160px;
  text-align: center;
  font-size: 14px;
}

.kpi-red {
  background: #fdecea;
  color: #b00000;
}

.kpi-yellow {
  background: #fff6d6;
  color: #8a6d00;
}

.kpi-green {
  background: #e6f4ea;
  color: #256029;
}
.kpi-click {
  cursor: pointer;
  transition: transform .1s ease, box-shadow .1s ease;
}

.kpi-click:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0,0,0,.12);
}

