/* styles.css — lenguaje visual reusado de los mockups (frame_0x_*.html).
   Paleta azul, sidebar oscuro, cards. Adaptado de fijo 1920px a layout fluido.
   Refactor: sistema de tokens (tipografía/espaciado/radios/elevación/foco),
   números tabulares para montos, jerarquía de botones, estados pulidos y un
   layout dedicado para "armar arreglo" (.nuevo-grid + barra de acción sticky). */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;
 font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
 color:#0f172a;background:#eef1f6;-webkit-font-smoothing:antialiased}
:root{
 /* marca / semántica (idéntica identidad azul) */
 --brand:#2563eb;--brand-d:#1e3a8a;--brand-h:#1d4ed8;
 --ok:#16a34a;--okbg:#dcfce7;--red:#dc2626;--redbg:#fee2e2;
 --amber:#d97706;--amberbg:#fef3c7;--muted:#64748b;--bd:#e2e8f0;--card:#fff;
 --ink:#0f172a;--ink-2:#334155;--surface:#f8fafc;
 /* escala tipográfica (ratio ~1.2, base 14) */
 --text-xs:12px;--text-sm:13px;--text-base:14px;--text-md:16px;--text-lg:18px;
 --text-xl:20px;--text-2xl:24px;--text-display:30px;
 --lh-tight:1.15;--lh-snug:1.3;--lh:1.5;
 /* ritmo de espaciado (grilla de 4) */
 --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s8:32px;--s10:40px;
 /* radios */
 --r-sm:8px;--r-md:12px;--r-lg:16px;--r-pill:999px;
 /* elevación */
 --e1:0 1px 2px rgba(15,23,42,.05);
 --e2:0 4px 12px rgba(15,23,42,.07);
 --e3:0 12px 30px rgba(15,23,42,.12);
 --e-brand:0 6px 16px rgba(37,99,235,.22);
 /* foco accesible */
 --ring:0 0 0 3px rgba(37,99,235,.22);
}
svg{stroke:currentColor;fill:none;width:20px;height:20px;flex:none}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
/* números tabulares: clase utilitaria + aplicación directa donde hay montos */
.tnum,td.num,th.num,.val,.tile-v,.city-time,.kv b,.code-input,input.cell[type=number]{
 font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;letter-spacing:0}

/* ---- shell: sidebar + main ---- */
.app{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.side{background:#0f172a;color:#cbd5e1;padding:var(--s8) var(--s5);display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:13px;margin-bottom:var(--s8)}
.logo{width:46px;height:46px;border-radius:var(--r-md);background:linear-gradient(135deg,#2563eb,#1e3a8a);
 display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:var(--text-xl)}
.brand b{color:#fff;font-size:var(--text-xl);font-weight:700;letter-spacing:.2px}
.brand small{display:block;color:#64748b;font-size:var(--text-xs);font-weight:500;margin-top:2px}
.nav{display:flex;flex-direction:column;gap:5px;margin-top:6px}
.nav .it{display:flex;align-items:center;gap:13px;padding:13px 15px;border-radius:var(--r-md);
 font-size:var(--text-md);color:#94a3b8;font-weight:500;transition:background .12s,color .12s}
.nav .it:hover{background:#16213a;color:#e2e8f0}
.nav .it.active{background:#1d2942;color:#fff}
.nav .it svg{width:20px;height:20px}
.nav .sec{font-size:var(--text-xs);letter-spacing:1.5px;color:#475569;font-weight:700;margin:var(--s5) 15px 6px;text-transform:uppercase}
.side .foot{margin-top:auto;display:flex;align-items:center;gap:11px;padding:13px 15px;
 border-top:1px solid #1e293b;color:#94a3b8;font-size:var(--text-base)}
.avatar{width:36px;height:36px;border-radius:50%;background:#334155;color:#e2e8f0;
 display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-base)}
.side .foot .logout{margin-left:auto;color:#64748b}
.side .foot .logout:hover{color:#e2e8f0}

.main{display:flex;flex-direction:column;min-width:0}
.top{min-height:80px;background:#fff;border-bottom:1px solid var(--bd);display:flex;align-items:center;
 padding:0 var(--s8);gap:var(--s4);flex-wrap:wrap}
.top h1{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.01em}
.top .sp{flex:1}
.content{flex:1;padding:var(--s8)}

/* ---- pill / generic ---- */
.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 15px;border-radius:var(--r-pill);
 font-size:var(--text-base);font-weight:600;background:#eff6ff;color:#1d4ed8}
.card{background:var(--card);border:1px solid var(--bd);border-radius:var(--r-lg);
 box-shadow:var(--e1)}
.pad{padding:var(--s6) var(--s6)}
.row{display:flex;gap:var(--s6);flex-wrap:wrap}
.h2{font-size:var(--text-xl);font-weight:700;margin-bottom:var(--s1);letter-spacing:-.01em}
.sub{color:var(--muted);font-size:var(--text-base);line-height:var(--lh-snug)}
.label{font-size:var(--text-sm);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:7px}
.val{font-size:var(--text-xl);font-weight:600}
.muted{color:var(--muted)}
.mb{margin-bottom:var(--s6)}

/* ---- form controls ---- */
.field{margin-bottom:var(--s4)}
.input,select.input,textarea.input{width:100%;min-height:52px;border:1.5px solid var(--bd);border-radius:var(--r-md);
 display:flex;align-items:center;padding:0 var(--s4);font-size:var(--text-md);background:#fff;color:var(--ink);gap:10px;outline:none;
 transition:border-color .12s,box-shadow .12s,background .12s}
textarea.input{padding:var(--s3) var(--s4);min-height:88px;resize:vertical;line-height:var(--lh)}
/* <select> nativo: display:flex y la altura de .input cortaban el texto / la flecha.
   Lo volvemos a block, con altura fija, padding propio y una flecha SVG dibujada. */
select.input{display:block;height:52px;min-height:52px;line-height:52px;
 padding:0 44px 0 var(--s4);-webkit-appearance:none;-moz-appearance:none;appearance:none;
 cursor:pointer;text-overflow:ellipsis;
 background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
 background-repeat:no-repeat;background-position:right 14px center}
select.input::-ms-expand{display:none}
.input:hover,select.input:hover,textarea.input:hover{border-color:#cbd5e1}
.input:focus,select.input:focus,textarea.input:focus{border-color:var(--brand);box-shadow:var(--ring)}
.input::placeholder,textarea.input::placeholder{color:#94a3b8}
.input:disabled,select.input:disabled,textarea.input:disabled{background:var(--surface);color:#94a3b8;cursor:not-allowed}
/* grilla / admin: misma familia de input pero compacta. Mismo radio y mismo foco que .input. */
input.cell{height:44px;border:1.5px solid var(--bd);border-radius:var(--r-md);padding:0 var(--s3);font-size:var(--text-md);width:100%;outline:none;
 background:#fff;color:var(--ink);transition:border-color .12s,box-shadow .12s,background .12s}
input.cell:hover{border-color:#cbd5e1}
input.cell:focus{border-color:var(--brand);box-shadow:var(--ring)}
input.cell:disabled{background:var(--surface);color:#94a3b8;cursor:not-allowed}
input.cell.err{border-color:#f87171;background:#fef2f2}
input.cell.err:focus{box-shadow:0 0 0 3px rgba(248,113,113,.22)}

.btn{min-height:52px;border-radius:var(--r-md);background:var(--brand);color:#fff;font-size:var(--text-md);font-weight:600;
 border:none;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 var(--s6);
 transition:background .12s,box-shadow .12s,transform .04s}
.btn:hover{background:var(--brand-h)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
.btn.g{background:#0f172a}.btn.g:hover{background:#1e293b}
.btn.gh{background:#fff;color:var(--ink);border:1.5px solid var(--bd)}.btn.gh:hover{background:var(--surface);border-color:#cbd5e1}
.btn.sm{min-height:40px;font-size:var(--text-sm);padding:0 var(--s4);border-radius:var(--r-sm)}
.btn.danger{background:#fff;color:#b91c1c;border:1.5px solid #fca5a5}.btn.danger:hover{background:#fef2f2}

.badge{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:var(--r-pill);font-size:var(--text-base);font-weight:600}
.b-ok{background:var(--okbg);color:#15803d}.b-red{background:var(--redbg);color:#b91c1c}
.b-amber{background:var(--amberbg);color:#b45309}.b-grey{background:#f1f5f9;color:#475569}
.b-blue{background:#dbeafe;color:#1d4ed8}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:8px;vertical-align:middle}
.dot-ok{background:var(--ok)}.dot-amber{background:var(--amber)}.dot-red{background:var(--red)}

table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:var(--text-sm);color:var(--muted);text-transform:uppercase;letter-spacing:.5px;
 font-weight:700;padding:var(--s3) var(--s4);border-bottom:1px solid var(--bd);background:var(--surface)}
td{padding:var(--s4) var(--s4);font-size:var(--text-md);border-bottom:1px solid #f1f5f9;vertical-align:middle}
tr:last-child td{border-bottom:none}
td.num,th.num{text-align:right}
.num-neg{color:var(--red);font-weight:700}
.clickrow{cursor:pointer;transition:background .1s}.clickrow:hover td{background:var(--surface)}
/* esquinas limpias cuando la tabla vive directo dentro de una .card (no .pad) */
.card>table{border-radius:var(--r-lg);overflow:hidden}

/* ---- alerts ---- */
.alert{border-radius:var(--r-md);padding:var(--s4) var(--s5);font-size:var(--text-md);font-weight:500;display:flex;gap:11px;align-items:flex-start;line-height:var(--lh-snug)}
.alert svg{margin-top:2px;width:20px;height:20px}
.alert.err{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c}
.alert.okm{background:var(--okbg);border:1px solid #86efac;color:#15803d}
.alert.warn{background:var(--amberbg);border:1px solid #fcd34d;color:#b45309}
.alert ul{margin:var(--s1) 0 0 18px;font-weight:600}
.alert ul li{margin-top:2px}

/* ---- login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
 background:radial-gradient(1200px 700px at 70% -10%,#1e3a8a,#0b1220)}
.login-card{background:#fff;border-radius:20px;padding:42px 40px;width:400px;box-shadow:0 30px 70px rgba(15,23,42,.4)}
.login-card .brand{justify-content:center;margin-bottom:var(--s6)}
.login-card h2{font-size:var(--text-2xl);font-weight:700;text-align:center;margin-bottom:6px;letter-spacing:-.01em}
.login-card .sub{text-align:center;margin-bottom:var(--s6)}
/* ---- onda: marca handshake + tagline + fondo con vida ---- */
.logo svg,.logo .mark{width:26px;height:26px;stroke:#fff}
.login-card{position:relative;z-index:1;overflow:hidden}
.login-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;
 background:linear-gradient(90deg,#2563eb,#6366f1,#e20074)}
.login-card .logo{width:56px;height:56px;border-radius:var(--r-lg);box-shadow:0 10px 26px rgba(37,99,235,.42)}
.login-card .logo svg,.login-card .logo .mark{width:31px;height:31px}
.tagline{text-align:center;color:var(--muted);font-size:14.5px;font-weight:500;font-style:italic;margin:-10px 0 18px}
.login-wrap{position:relative;overflow:hidden}
.login-wrap::before,.login-wrap::after{content:"";position:absolute;border-radius:50%;pointer-events:none;filter:blur(12px)}
.login-wrap::before{width:440px;height:440px;top:-150px;right:-120px;
 background:radial-gradient(circle,rgba(59,130,246,.55),transparent 68%)}
.login-wrap::after{width:380px;height:380px;bottom:-160px;left:-130px;
 background:radial-gradient(circle,rgba(99,102,241,.5),transparent 68%)}

/* ---- login · OTP (input de código grande + reenvío con cooldown) ---- */
.code-input{font-size:var(--text-display);font-weight:700;letter-spacing:14px;text-align:center;
 padding:0 8px;font-family:'SF Mono',Menlo,Consolas,monospace;color:var(--ink)}
.code-input::placeholder{letter-spacing:14px;color:#cbd5e1}
.otp-resend-wrap{text-align:center;margin-top:14px}
.otp-resend{font-size:var(--text-base);font-weight:600;color:var(--brand)}
.otp-resend:hover{text-decoration:underline}
.otp-resend.disabled{color:#94a3b8;pointer-events:none;text-decoration:none;cursor:default}
.otp-back{font-size:var(--text-base);font-weight:600;color:var(--muted)}
.otp-back:hover{color:var(--ink)}

/* ---- misc layout ---- */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:var(--s6)}
.kv{display:flex;justify-content:space-between;align-items:center;font-size:var(--text-md);padding:var(--s3) 0;border-bottom:1px solid #f1f5f9;gap:var(--s4)}
.kv:last-child{border-bottom:none}
.kv b{font-weight:700}
/* reglas de marca como REFERENCIA sutil (viewNuevo) — no distraen del calendario */
.rules-ref{background:var(--surface);border:1px solid var(--bd);border-radius:var(--r-md);padding:var(--s3) var(--s4)}
.rules-ref-title{font-size:var(--text-xs);letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:9px}
.rules-ref-items{display:flex;flex-wrap:wrap;gap:7px 14px}
.ref-chip{font-size:12.5px;color:#94a3b8}
.ref-chip b{color:#475569;font-weight:600;font-variant-numeric:tabular-nums}
.preview-dates{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.chip-date{background:#eff6ff;color:#1d4ed8;border-radius:var(--r-sm);padding:8px 13px;font-size:var(--text-base);font-weight:600;display:flex;flex-direction:column;gap:2px}
.chip-date small{color:#64748b;font-weight:500;text-transform:uppercase;letter-spacing:.4px;font-size:var(--text-xs)}
.spinner{display:inline-block;width:18px;height:18px;border:2.5px solid #cbd5e1;border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- estados: empty + skeleton ---- */
.empty{text-align:center;color:var(--muted);padding:var(--s10) var(--s5);font-size:var(--text-md)}
.empty-rich{display:flex;flex-direction:column;align-items:center;gap:var(--s3);padding:var(--s10) var(--s5);text-align:center}
.empty-rich .empty-ic{width:52px;height:52px;border-radius:var(--r-lg);background:#eff6ff;color:var(--brand);
 display:flex;align-items:center;justify-content:center}
.empty-rich .empty-ic svg{width:26px;height:26px}
.empty-rich .empty-t{font-size:var(--text-lg);font-weight:700;color:var(--ink)}
.empty-rich .empty-s{font-size:var(--text-base);color:var(--muted);max-width:360px;line-height:var(--lh-snug)}
.skel{background:linear-gradient(90deg,#eef2f7 25%,#e2e8f0 37%,#eef2f7 63%);background-size:400% 100%;
 animation:shimmer 1.4s ease infinite;border-radius:var(--r-sm)}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}
.skel-line{height:14px;margin:10px 0}
.skel-row{display:flex;gap:var(--s4);padding:var(--s4) var(--s4);border-bottom:1px solid #f1f5f9}
.skel-row .skel{height:16px;flex:1}

.toolbar{display:flex;gap:var(--s3);align-items:center;margin-bottom:var(--s5);flex-wrap:wrap}
.toolbar .sp{flex:1}
/* tablero operativo (viewHoy) */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:var(--s6)}
.tile{background:var(--card);border:1px solid var(--bd);border-radius:var(--r-lg);padding:var(--s5) var(--s6)}
.tile-v{font-size:var(--text-display);font-weight:800;color:var(--ink);line-height:var(--lh-tight)}
.tile-l{margin-top:8px;font-size:var(--text-base);color:var(--muted);font-weight:600;display:flex;align-items:center;gap:8px}
.auto-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--brand);
  background:#eff6ff;border:1px solid #dbeafe;border-radius:var(--r-sm);padding:2px 6px;margin-left:8px}
@media(max-width:900px){.kpis{grid-template-columns:1fr 1fr}}

/* ---- topbar: chip de usuario (nombre SIEMPRE visible) ---- */
.avatar.sm{width:40px;height:40px;font-size:15px;
 background:linear-gradient(135deg,#2563eb,#1e3a8a);color:#fff;box-shadow:0 4px 12px rgba(37,99,235,.28)}
.top-user{display:flex;align-items:center;gap:11px;padding:6px 8px 6px 14px;border-radius:var(--r-pill);
 background:var(--surface);border:1px solid var(--bd)}
.top-user-txt{text-align:right;line-height:1.2}
.top-user-name{font-size:var(--text-base);font-weight:700;color:var(--ink)}
.top-user-role{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:capitalize}

/* ---- Hoy · header widget (fecha + relojes + clima) ---- */
.top:has(.hoy-header){padding-top:14px;padding-bottom:14px;align-items:stretch}
.hoy-header{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.hoy-head-left{display:flex;flex-direction:column;justify-content:center;min-width:200px}
.hoy-eyebrow{font-size:var(--text-xs);font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--brand)}
.hoy-date{font-size:var(--text-xl);font-weight:800;color:var(--ink);text-transform:capitalize;line-height:var(--lh-tight);margin-top:3px}
.city-cards{display:flex;gap:14px;flex-wrap:wrap}
.city-card{min-width:150px;padding:11px 16px;border-radius:14px;
 background:linear-gradient(135deg,#eff6ff,#e0e7ff);border:1px solid #dbeafe}
.city-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.city-name{font-size:var(--text-xs);font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:#1e40af}
.city-weather{font-size:var(--text-base);font-weight:700;color:#1e3a8a;white-space:nowrap}
.city-time{font-size:var(--text-2xl);font-weight:800;color:var(--ink);line-height:var(--lh-tight);margin-top:2px;letter-spacing:.5px}
.city-sub{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:capitalize;margin-top:1px}

/* ---- branding global: acentos sobrios, cards pulidas ---- */
.h2{position:relative}
/* barra de acento de marca en TODOS los h2 de una card.pad (identidad consistente) */
.card.pad>.h2:first-child,.card.pad>.h2{padding-left:13px}
.card.pad>.h2::before,.nuevo-main .card.pad .h2::before{content:"";position:absolute;left:0;top:3px;bottom:3px;width:4px;
 border-radius:3px;background:linear-gradient(180deg,#2563eb,#1e3a8a)}
.nuevo-main .card.pad .h2{padding-left:13px;position:relative}
.tile{transition:box-shadow .14s,transform .14s,border-color .14s}
.tile:hover{box-shadow:0 10px 24px rgba(37,99,235,.12);transform:translateY(-2px);border-color:#dbeafe}
.tile-v{background:linear-gradient(135deg,#2563eb,#1e3a8a);-webkit-background-clip:text;
 background-clip:text;-webkit-text-fill-color:transparent}
.nav .it.active{box-shadow:inset 3px 0 0 var(--brand)}
/* peso/sombra azul reservado SOLO al CTA primario (.btn pelado). Secundarios planos. */
.btn{box-shadow:var(--e-brand)}
.btn.gh,.btn.danger,.btn.sm{box-shadow:none}

/* ============================================================================
   viewNuevo · ARMAR ARREGLO — el calendario es el protagonista.
   Layout de 2 zonas: columna principal ancha (calendario) + lateral angosta
   (datos del acuerdo + reglas + preview). Barra de acción sticky al pie.
   ========================================================================== */
.nuevo-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(300px,.9fr);
 gap:var(--s6);align-items:start;margin-bottom:var(--s8)}
.nuevo-main{display:flex;flex-direction:column;gap:var(--s5);min-width:0}
.nuevo-side{display:flex;flex-direction:column;gap:var(--s5);min-width:0}
/* contexto del contrato (cliente/equipo/saldo) en una tira sobria arriba de todo */
.ctx-strip{display:flex;flex-wrap:wrap;gap:var(--s6);align-items:center}
.ctx-strip .ctx-i{min-width:120px}
.ctx-strip .ctx-l{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.ctx-strip .ctx-v{font-size:var(--text-md);font-weight:700;color:var(--ink);margin-top:2px}
/* la grilla de cuotas con fila de totales */
.cuotas tfoot td{border-top:2px solid var(--bd);border-bottom:none;font-weight:800;background:var(--surface)}
.cuotas td.del-cell{width:48px;text-align:center}
.icon-btn{width:36px;height:36px;border-radius:var(--r-sm);background:#fff;border:1.5px solid var(--bd);
 color:var(--muted);display:inline-flex;align-items:center;justify-content:center;transition:all .12s}
.icon-btn:hover{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}
.icon-btn svg{width:18px;height:18px}
/* cajas sutiles del lateral (mismo nivel visual, sin card-dentro-de-no-card) */
.side-box{background:var(--surface);border:1px solid var(--bd);border-radius:var(--r-md);padding:var(--s4)}
.side-box-title{font-size:var(--text-xs);letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:var(--s3)}
/* barra de acción sticky: resumen vivo + CTA primario, siempre a la vista */
.action-bar{position:sticky;bottom:0;z-index:5;display:flex;align-items:center;gap:var(--s5);flex-wrap:wrap;
 background:#fff;border:1px solid var(--bd);border-radius:var(--r-lg);box-shadow:0 -6px 20px rgba(15,23,42,.08);
 padding:var(--s4) var(--s6);margin-top:var(--s2)}
.action-summary{display:flex;align-items:center;gap:var(--s6);flex-wrap:wrap;flex:1;min-width:240px}
.action-summary .as-i{display:flex;flex-direction:column;line-height:var(--lh-tight)}
.action-summary .as-l{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.action-summary .as-v{font-size:var(--text-lg);font-weight:800;color:var(--ink);margin-top:2px;font-variant-numeric:tabular-nums}
.action-state{display:inline-flex;align-items:center;gap:7px;font-size:var(--text-sm);font-weight:600;padding:6px 12px;border-radius:var(--r-pill)}
.action-state.ok{background:var(--okbg);color:#15803d}
.action-state.bad{background:var(--amberbg);color:#b45309}
.action-cta{display:flex;align-items:center;gap:var(--s4);flex-wrap:wrap;justify-content:flex-end}
.action-hint{font-size:var(--text-sm);color:var(--muted);font-weight:500;max-width:220px;text-align:right}
.action-bar .btn{min-width:200px;font-size:var(--text-lg)}

@media(max-width:1000px){
  .nuevo-grid{grid-template-columns:1fr}
  .nuevo-side{order:2}
  .nuevo-main{order:1}
}

/* ---- responsive general ---- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(max-width:820px){
  .app{grid-template-columns:1fr}
  .side{position:static;height:auto;flex-direction:row;flex-wrap:wrap;gap:10px}
  .side .foot{display:none}
  .nav{flex-direction:row;flex-wrap:wrap}
  .grid2{grid-template-columns:1fr}
  .top-user-txt{display:none}
  .hoy-header{gap:14px}
  .content{padding:var(--s5)}
  .action-bar .btn{min-width:0;flex:1}
  .action-cta{flex:1}
}
