﻿/* ═══════════════════════════════════════════════════════════
   TOTEM KIOSK — style.css
   Estrategia de breakpoints:
     Base          → 600px+ (tablet portrait, notebook, monitor)
     max-width:599 → móvil angosto
     min-height:1400px → SOLO totem 1080×1920 portrait
     max-height:580px  → pantalla landscape muy corta
═══════════════════════════════════════════════════════════ */

/* ── Variables ── */
:root {
    --blue:       #00205B;
    --blue-mid:   #002d7a;
    --blue-light: #003494;
    --cyan:       #41B6E6;
    --cyan-dark:  #1e9fd4;
    --cyan-glow:  rgba(65,182,230,0.35);
    --white:      #ffffff;
    --off-white:  #f0f6fb;
    --slate-100:  #e8f0f8;
    --slate-200:  #c8d8ea;
    --slate-400:  #7a96b2;
    --slate-700:  #1e3a5f;
    --green:      #0ea05a;
    --green-bg:   #edfbf3;
    --green-bdr:  #6ee8b4;
    --red:        #e02020;
    --red-bg:     #fff3f3;
    --red-bdr:    #f5a5a5;
    --shadow-sm:  0 2px 8px rgba(0,32,91,0.10);
    --shadow-md:  0 8px 28px rgba(0,32,91,0.18);
    --shadow-lg:  0 20px 56px rgba(0,32,91,0.30);
}

/* ── Reset ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html, body { height:100%; overflow:hidden; }
body { font-family:'Golos Text', system-ui, sans-serif; background:var(--blue); }

/* ── Fondo decorativo ── */
body::before {
    content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
    background:
        radial-gradient(ellipse 90% 55% at 50% 0%,   rgba(65,182,230,.22) 0%, transparent 65%),
        radial-gradient(ellipse 60% 50% at 100% 85%, rgba(65,182,230,.12) 0%, transparent 60%),
        radial-gradient(ellipse 40% 40% at 0%   60%, rgba(0,45,122,.6)    0%, transparent 60%);
}

/* ═══════════════════════════════════════
   PANTALLA BÚSQUEDA — base para ≥600px
═══════════════════════════════════════ */
#paginaBusqueda {
    position:relative; z-index:1;
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    height:100vh; overflow:hidden;
    padding:28px 24px; gap:26px;
}

.hero-wrap { flex-shrink:0; text-align:center; }

.hero-logo {
    display:block; height:84px; max-width:340px;
    width:auto; margin:0 auto; object-fit:contain;
}

.search-card {
    flex-shrink:0; display:flex; flex-direction:column;
    width:100%; max-width:min(88vw, 580px);
    background:rgba(255,255,255,.055);
    border:1px solid rgba(255,255,255,.10);
    border-radius:24px; padding:30px 28px 34px;
    backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
    box-shadow:0 32px 80px rgba(0,0,0,.25);
    overflow:hidden; position:relative;
}

#consultaForm { display:flex; flex-direction:column; gap:18px; }

.field-lbl {
    flex-shrink:0; display:flex; align-items:center; gap:8px;
    font-size:13px; font-weight:700; text-transform:uppercase;
    letter-spacing:1.5px; color:var(--cyan);
}
.field-lbl::before {
    content:''; width:3px; height:14px;
    background:var(--cyan); border-radius:2px;
}

.dni-input {
    flex-shrink:0; display:block; width:100%;
    padding:16px 22px;
    background:rgba(255,255,255,.07);
    border:1.5px solid rgba(255,255,255,.12);
    border-radius:14px;
    color:var(--white); font-size:36px; font-family:inherit;
    font-weight:700; letter-spacing:5px; text-align:center; outline:none;
    transition:border-color .22s, background .22s, box-shadow .22s;
}
.dni-input::placeholder {
    color:rgba(255,255,255,.2); font-weight:300;
    letter-spacing:5px; font-size:36px;
}
.dni-input:focus {
    border-color:var(--cyan);
    background:rgba(65,182,230,.09);
    box-shadow:0 0 0 4px rgba(65,182,230,.15);
}

.btn-consultar {
    display:flex; align-items:center; justify-content:center;
    gap:10px; width:100%; padding:19px;
    background:linear-gradient(135deg, var(--cyan) 0%, var(--cyan-dark) 100%);
    border:none; border-radius:15px;
    color:var(--blue); font-size:20px; font-family:inherit;
    font-weight:800; letter-spacing:.4px; cursor:pointer;
    transition:transform .18s, box-shadow .18s, filter .18s;
    box-shadow:0 8px 28px var(--cyan-glow);
}
.btn-consultar:hover:not(:disabled) {
    transform:translateY(-3px); box-shadow:0 16px 40px var(--cyan-glow); filter:brightness(1.05);
}
.btn-consultar:active:not(:disabled) { transform:translateY(0); }
.btn-consultar:disabled { opacity:.45; cursor:not-allowed; }
.btn-consultar .btn-icon { font-size:24px; line-height:1; }

/* ── Numpad ── */
.numpad { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; width:100%; }

.nk {
    position:relative; padding:0; width:100%; aspect-ratio:1/1;
    background:rgba(255,255,255,.07);
    border:1.5px solid rgba(255,255,255,.12);
    border-radius:14px;
    color:var(--white); font-size:32px; font-weight:700; font-family:inherit;
    cursor:pointer; overflow:hidden;
    transition:background .12s, transform .1s;
    -webkit-tap-highlight-color:transparent; user-select:none;
}
.nk:hover  { background:rgba(255,255,255,.14); }
.nk:active { transform:scale(.93); background:rgba(255,255,255,.20); }

.nk-del { background:rgba(220,50,50,.15); border-color:rgba(220,50,50,.25); }
.nk-del:hover  { background:rgba(220,50,50,.28); }
.nk-del:active { background:rgba(220,50,50,.40); }

.nk-ok {
    background:linear-gradient(135deg, var(--cyan) 0%, var(--cyan-dark) 100%);
    border-color:var(--cyan-dark); color:var(--blue);
    box-shadow:0 6px 20px var(--cyan-glow);
}
.nk-ok:hover   { filter:brightness(1.08); box-shadow:0 10px 28px var(--cyan-glow); }
.nk-ok:active  { transform:scale(.93); filter:brightness(.95); }
.nk-ok:disabled { opacity:.45; cursor:not-allowed; transform:none; }

/* ═══════════════════════════════════════
   OVERLAY / MODALES AUXILIARES
═══════════════════════════════════════ */
#overlayLoading {
    position:fixed; inset:0; z-index:800;
    background:rgba(0,10,30,.82); backdrop-filter:blur(6px);
    display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:28px;
    opacity:0; pointer-events:none;
    transition:opacity .25s ease;
}
#overlayLoading.visible { opacity:1; pointer-events:auto; }
.ol-ring { position:relative; width:96px; height:96px; }
.ol-ring::before, .ol-ring::after { content:''; position:absolute; inset:0; border-radius:50%; }
.ol-ring::before { border:4px solid rgba(65,182,230,.15); }
.ol-ring::after  {
    border:4px solid transparent;
    border-top-color:var(--cyan);
    border-right-color:rgba(65,182,230,.4);
    animation:spin .8s linear infinite;
}
.ol-text { color:rgba(255,255,255,.85); font-size:17px; font-weight:700; letter-spacing:.3px; }
.ol-sub  { color:rgba(255,255,255,.35); font-size:13px; margin:-16px 0 0; }

#modalError {
    position:fixed; inset:0; z-index:850;
    background:rgba(0,6,22,.78); backdrop-filter:blur(6px);
    display:flex; align-items:center; justify-content:center;
    padding:24px; opacity:0; pointer-events:none;
    transition:opacity .22s ease;
}
#modalError.visible { opacity:1; pointer-events:auto; }
.merr-card {
    background:#fff; border-radius:24px; padding:36px 32px 28px;
    max-width:420px; width:100%; text-align:center;
    box-shadow:0 32px 80px rgba(0,0,0,.55);
    transform:scale(.9) translateY(20px);
    transition:transform .28s cubic-bezier(.22,.68,0,1.2);
}
#modalError.visible .merr-card { transform:scale(1) translateY(0); }
.merr-icon  { font-size:52px; line-height:1; margin-bottom:14px; }
.merr-titulo { font-size:20px; font-weight:900; color:var(--blue); margin:0 0 8px; }
.merr-msg   { font-size:14px; color:#64748b; line-height:1.6; margin:0 0 24px; }
.btn-reintentar {
    display:block; width:100%;
    background:linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%);
    color:#fff; border:none; border-radius:12px;
    padding:13px 20px; font-size:15px; font-weight:700;
    cursor:pointer; font-family:inherit;
    transition:opacity .15s, transform .1s;
}
.btn-reintentar:hover  { opacity:.88; }
.btn-reintentar:active { transform:scale(.97); }

.spinner {
    width:48px; height:48px;
    border:3px solid rgba(65,182,230,.15); border-top-color:var(--cyan);
    border-radius:50%; animation:spin .75s linear infinite; margin:0 auto 14px;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ═══════════════════════════════════════
   PANTALLA RESULTADO — base para ≥600px
═══════════════════════════════════════ */
#paginaResultado {
    position:relative; z-index:1; display:none;
    height:100vh; overflow:hidden;
    flex-direction:column; align-items:stretch;
}

.topbar {
    position:absolute; top:16px; left:16px;
    display:flex; align-items:center; gap:14px; z-index:2;
}

.resultado-inner {
    position:absolute; inset:0;
    display:flex; flex-direction:column; align-items:center;
    padding:68px 20px 20px;
    overflow-y:auto; overflow-x:hidden;
}

.btn-volver {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14);
    color:var(--white); padding:9px 18px; border-radius:10px;
    cursor:pointer; font-size:14px; font-family:inherit; font-weight:600;
    transition:background .2s;
}
.btn-volver:hover { background:rgba(255,255,255,.15); }

.topbar-hint { font-size:13px; color:rgba(255,255,255,.35); font-weight:500; }

#resultadoContenido {
    width:100%; max-width:min(92vw, 800px);
    margin:auto;
}

/* ── Card cliente ── */
.client-card {
    background:var(--white); border-radius:18px;
    overflow:hidden; box-shadow:var(--shadow-lg);
    animation:slideUp .38s cubic-bezier(.22,.68,0,1.2);
    display:flex; flex-direction:column; isolation:isolate;
}
@keyframes slideUp {
    from { opacity:0; transform:translateY(30px) scale(.98); }
    to   { opacity:1; transform:translateY(0) scale(1); }
}

.card-head {
    background:linear-gradient(130deg, var(--blue) 0%, var(--blue-mid) 60%, var(--blue-light) 100%);
    padding:22px 28px; display:flex; align-items:center; gap:18px;
    position:relative; overflow:hidden; flex-shrink:0;
}
.card-head::after {
    content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
    background:linear-gradient(90deg, var(--cyan), rgba(65,182,230,.3));
}

.ch-avatar {
    width:64px; height:64px;
    background:linear-gradient(145deg, var(--cyan), var(--cyan-dark));
    border-radius:50%; display:flex; align-items:center; justify-content:center;
    font-size:28px; flex-shrink:0;
    box-shadow:0 8px 24px var(--cyan-glow); position:relative; z-index:1;
}
.ch-info { position:relative; z-index:1; }
.ch-info h2 {
    font-size:26px; font-weight:800; color:var(--white);
    letter-spacing:-.5px; margin-bottom:6px;
}

.badge {
    display:inline-flex; align-items:center; gap:5px;
    padding:5px 14px; border-radius:24px;
    font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.8px;
}
.badge::before { content:''; width:7px; height:7px; border-radius:50%; }
.badge-activo   { background:rgba(65,182,230,.18); color:var(--cyan); }
.badge-activo::before   { background:var(--cyan); }
.badge-inactivo { background:rgba(220,38,38,.18); color:#ff8080; }
.badge-inactivo::before { background:#ff6060; }
.badge-deudor   { background:rgba(255,180,0,.18); color:#ffc84a; }
.badge-deudor::before   { background:#ffb829; }

.card-body { padding:20px 28px 14px; flex-shrink:0; }

.s-title {
    font-size:11px; font-weight:800; text-transform:uppercase;
    letter-spacing:1.5px; color:var(--slate-400);
    margin-bottom:12px; display:flex; align-items:center; gap:10px;
}
.s-title::after { content:''; flex:1; height:1px; background:var(--slate-100); }

.info-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }

.info-cell {
    background:var(--off-white); border:1px solid var(--slate-100);
    border-radius:11px; padding:12px 16px;
    transition:border-color .2s, box-shadow .2s;
}
.info-cell:hover { border-color:rgba(65,182,230,.4); box-shadow:0 4px 12px rgba(65,182,230,.08); }
.info-cell.full { grid-column:1/-1; }

.ic-lbl {
    font-size:11px; font-weight:700; text-transform:uppercase;
    letter-spacing:1px; color:var(--blue); opacity:.6; margin-bottom:4px;
}
.ic-val { font-size:17px; font-weight:600; color:var(--slate-700); word-break:break-word; line-height:1.4; }
.ic-val.muted { color:var(--slate-400); font-weight:400; font-style:italic; }

.c-divider { height:1px; background:var(--slate-100); margin:0 28px; flex-shrink:0; }

/* ── Deuda ── */
.deuda-wrap {
    flex:1; display:flex; flex-direction:column; justify-content:center;
    padding:18px 28px;
}
.deuda-box {
    border-radius:16px; padding:20px 22px;
    display:flex; align-items:center; gap:20px;
}
.deuda-box.con-deuda { background:var(--red-bg);   border:1.5px solid var(--red-bdr);   }
.deuda-box.sin-deuda { background:var(--green-bg); border:1.5px solid var(--green-bdr); }

.deuda-ico  { font-size:44px; flex-shrink:0; line-height:1; }
.deuda-data { flex:1; min-width:0; }

.deuda-lbl {
    font-size:11px; font-weight:800; text-transform:uppercase;
    letter-spacing:1px; margin-bottom:4px;
}
.con-deuda .deuda-lbl { color:var(--red); }
.sin-deuda .deuda-lbl { color:var(--green); }

.deuda-monto { font-size:46px; font-weight:900; color:var(--red); letter-spacing:-1.5px; line-height:1; }
.sin-deuda-msg { font-size:32px; font-weight:800; color:var(--green); letter-spacing:-.5px; }
.sin-deuda-sub { font-size:14px; color:var(--green); opacity:.7; margin-top:4px; font-weight:500; }

.btn-pagar {
    display:inline-flex; align-items:center; justify-content:center;
    gap:8px; padding:15px 28px;
    background:linear-gradient(135deg, var(--cyan) 0%, var(--cyan-dark) 100%);
    color:var(--blue); text-decoration:none; border:none;
    border-radius:13px; font-weight:800; font-size:17px;
    letter-spacing:.2px; cursor:pointer; font-family:inherit;
    transition:transform .18s, box-shadow .18s, filter .18s;
    flex-shrink:0; box-shadow:0 8px 24px var(--cyan-glow); white-space:nowrap;
}
.btn-pagar:hover { transform:translateY(-3px); box-shadow:0 16px 36px var(--cyan-glow); filter:brightness(1.06); }

.btn-terminar-result {
    display:block; width:100%; margin-top:14px;
    background:linear-gradient(135deg, var(--green) 0%, #0d8a4d 100%);
    color:#fff; border:none; border-radius:12px;
    padding:14px 20px; font-size:15px; font-weight:700;
    cursor:pointer; font-family:inherit;
    transition:opacity .15s, transform .1s;
}
.btn-terminar-result:hover  { opacity:.88; }
.btn-terminar-result:active { transform:scale(.97); }

.error-card {
    background:var(--white); border-radius:24px;
    padding:48px 40px; text-align:center;
    box-shadow:var(--shadow-lg);
    animation:slideUp .38s cubic-bezier(.22,.68,0,1.2);
}
.error-card .e-icon { font-size:60px; margin-bottom:18px; }
.error-card h3 { font-size:22px; font-weight:800; color:var(--blue); margin-bottom:8px; }
.error-card p  { color:var(--slate-400); font-size:14px; line-height:1.5; }

.qr-billetera {
    font-size:12px; color:#64748b; margin-top:12px; line-height:1.6;
    padding:10px 14px; background:#f8fafc;
    border-radius:10px; border:1px solid #e2e8f0;
}

/* ═══════════════════════════════════════
   MODAL QR — base para ≥600px
═══════════════════════════════════════ */
.qr-overlay {
    position:fixed; inset:0; z-index:1000;
    background:rgba(0,10,30,.80);
    display:flex; align-items:center; justify-content:center;
    padding:24px; backdrop-filter:blur(5px);
    animation:fadeInOverlay .22s ease; overflow-y:auto;
}
@keyframes fadeInOverlay { from { opacity:0 } to { opacity:1 } }

.qr-modal {
    background:var(--white); border-radius:22px;
    padding:36px 32px 30px;
    max-width:min(88vw, 560px); width:100%;
    max-height:92vh; overflow-y:auto;
    box-shadow:0 32px 80px rgba(0,0,0,.55);
    text-align:center;
    animation:popIn .32s cubic-bezier(.22,.68,0,1.2);
    margin:auto;
}
@keyframes popIn {
    from { opacity:0; transform:scale(.88) translateY(24px) }
    to   { opacity:1; transform:scale(1) translateY(0) }
}

.qr-empresa { font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--cyan); margin-bottom:6px; }
.qr-monto   { font-size:54px; font-weight:900; color:var(--blue); letter-spacing:-1.5px; margin-bottom:6px; }
.qr-hint    { font-size:16px; color:#94a3b8; margin-bottom:22px; }
.qr-img     { max-width:min(340px, 72vw); width:100%; border-radius:12px; border:1px solid #e2e8f0; display:block; margin:0 auto; }
.qr-aviso   {
    background:#fff7ed; border:1px solid #fed7aa; color:#92400e;
    border-radius:10px; padding:10px 14px; font-size:13px;
    margin:14px 0 12px; line-height:1.55;
}
.btn-terminar {
    display:block; width:100%;
    background:linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%);
    color:#fff; border:none; border-radius:13px;
    padding:18px 20px; font-size:19px; font-weight:700;
    cursor:pointer; letter-spacing:.3px;
    transition:opacity .15s, transform .1s;
}
.btn-terminar:hover  { opacity:.88; }
.btn-terminar:active { transform:scale(.97); }

.qr-loading { text-align:center; padding:28px 0 18px; }
.qr-loading p { color:#94a3b8; margin-top:14px; font-size:14px; }
.qr-poll-estado { font-size:12px; color:#94a3b8; margin-top:14px; letter-spacing:.2px; }

.qr-confirmado { padding:18px 0 12px; animation:popIn .38s cubic-bezier(.22,.68,0,1.2); }
.qrc-ico    { font-size:72px; margin-bottom:14px; }
.qrc-titulo { font-size:36px; font-weight:900; color:var(--green); margin-bottom:6px; }
.qrc-sub    { font-size:16px; color:#64748b; margin-bottom:10px; }
.qrc-monto  { font-size:48px; font-weight:900; color:var(--blue); letter-spacing:-1px; }

/* ── Banner inactividad ── */
#bannerInactividad {
    position:fixed; bottom:0; left:0; right:0; z-index:960;
    background:rgba(0,6,22,.92); border-top:1px solid rgba(65,182,230,.25);
    backdrop-filter:blur(8px);
    display:flex; align-items:center; justify-content:center; gap:18px;
    padding:16px 28px;
    transform:translateY(100%); transition:transform .3s ease; cursor:pointer;
}
#bannerInactividad.visible { transform:translateY(0); }
.bi-text { color:rgba(255,255,255,.75); font-size:14px; font-weight:500; }
.bi-text strong { color:var(--cyan); font-size:16px; }
.bi-tap  { color:rgba(255,255,255,.45); font-size:12px; font-weight:400; white-space:nowrap; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE

   Dispositivos y breakpoints activos:
   ┌──────────────────────────────┬──────────────────────────────┐
   │ Dispositivo                  │ Breakpoint activo            │
   ├──────────────────────────────┼──────────────────────────────┤
   │ Móvil 375×812                │ max-width:599px              │
   │ Tablet 768×1024 portrait     │ BASE (sin breakpoint)        │
   │ Tablet 1024×768 landscape    │ BASE + max-height:580px      │
   │ Notebook 1366×768            │ BASE + max-height:580px      │
   │ Notebook 1280×800            │ BASE (sin breakpoint)        │
   │ Monitor 1920×1080            │ BASE (sin breakpoint)        │
   │ Totem 1080×1920 portrait     │ min-height:1400px            │
   └──────────────────────────────┴──────────────────────────────┘
═══════════════════════════════════════════════════════════ */

/* ── 1. Móvil angosto (≤599px) ── */
@media (max-width: 599px) {
    #paginaBusqueda  { padding:16px 14px; gap:14px; }
    .hero-logo       { height:50px; max-width:220px; }
    .search-card     { max-width:100%; padding:16px 14px 18px; border-radius:18px; }
    #consultaForm    { gap:10px; }
    .field-lbl       { font-size:11px; }
    .dni-input       { font-size:24px; padding:11px 16px; border-radius:11px; }
    .dni-input::placeholder { font-size:24px; }
    .btn-consultar   { font-size:15px; padding:13px; }
    .btn-consultar .btn-icon { font-size:18px; }
    .numpad          { gap:7px; }
    .nk              { font-size:22px; border-radius:11px; }

    .resultado-inner { padding:52px 10px 14px; }
    .topbar          { flex-wrap:wrap; gap:8px; }
    .card-head       { flex-direction:column; text-align:center; padding:14px 12px; }
    .card-body, .deuda-wrap { padding-left:12px; padding-right:12px; }
    .c-divider       { margin:0 12px; }
    .info-grid       { grid-template-columns:1fr; }
    .ch-info h2      { font-size:17px; }
    .deuda-box       { flex-direction:column; text-align:center; gap:10px; }
    .deuda-monto     { font-size:28px; }
    .sin-deuda-msg   { font-size:20px; }
    .btn-pagar       { width:100%; padding:12px 14px; font-size:14px; }

    /* QR modal en móvil */
    .qr-overlay      { padding:10px; align-items:flex-start; padding-top:16px; }
    .qr-modal        { padding:20px 18px 18px; border-radius:16px; max-height:96vh; max-width:100%; }
    .qr-empresa      { font-size:10px; margin-bottom:4px; }
    .qr-monto        { font-size:30px; margin-bottom:4px; }
    .qr-hint         { font-size:12px; margin-bottom:12px; }
    .qr-img          { max-width:min(250px, 62vw); }
    .qr-aviso        { padding:8px 10px; font-size:11px; margin:10px 0 8px; line-height:1.4; }
    .btn-terminar    { padding:14px 20px; font-size:15px; border-radius:12px; }
    .qrc-ico         { font-size:48px; margin-bottom:8px; }
    .qrc-titulo      { font-size:24px; margin-bottom:4px; }
    .qrc-sub         { font-size:12px; margin-bottom:8px; }
    .qrc-monto       { font-size:30px; }
}

/* ── 2. Notebook / altura media (600-860px, ancho ≥600px) ── */
/* ── 2a. Notebook pequeño (alto ≤820px) — 1366×768, etc. ── */
@media (max-height: 820px) and (min-width: 600px) {
    #paginaBusqueda  { gap:12px; padding:12px 24px; }
    .hero-logo       { height:54px; max-width:240px; }
    .search-card     { max-width:min(88vw, 420px); padding:16px 20px 20px; border-radius:18px; }
    #consultaForm    { gap:10px; }
    .field-lbl       { font-size:11px; }
    .dni-input       { font-size:26px; padding:10px 16px; border-radius:11px; }
    .dni-input::placeholder { font-size:26px; }
    .btn-consultar   { font-size:15px; padding:13px; border-radius:12px; }
    .btn-consultar .btn-icon { font-size:19px; }
    .numpad          { gap:7px; }
    /* aspect-ratio:auto + altura fija para que el numpad entre en ~688px de viewport */
    .nk              { font-size:24px; border-radius:11px; aspect-ratio:auto; height:72px; }
}

/* ── 2b. Monitor/MacBook medio (alto 821–960px) — MacBook Pro 1440×900, 1280×800 etc. ── */
@media (max-height: 960px) and (min-height: 821px) and (min-width: 600px) {
    #paginaBusqueda  { gap:20px; padding:20px 28px; }
    .hero-logo       { height:72px; max-width:300px; }
    .search-card     { max-width:min(88vw, 520px); padding:24px 26px 28px; border-radius:22px; }
    #consultaForm    { gap:14px; }
    .field-lbl       { font-size:13px; }
    .dni-input       { font-size:32px; padding:14px 20px; border-radius:13px; }
    .dni-input::placeholder { font-size:32px; }
    .btn-consultar   { font-size:18px; padding:16px; border-radius:14px; }
    .btn-consultar .btn-icon { font-size:22px; }
    .numpad          { gap:10px; }
    /* Teclas con altura fija proporcional — en card 520px quedan ~153px ancho × 108px alto */
    .nk              { font-size:30px; border-radius:13px; aspect-ratio:auto; height:108px; }
}

/* ── 3. TOTEM portrait: SOLO pantallas con altura ≥1400px ── */
/*    Totem 1080×1920 → height 1920px → APLICA                 */
/*    Notebook 1366×768 → height 768px → NO aplica             */
/*    Monitor 1920×1080 → height 1080px → NO aplica            */
@media (min-height: 1400px) {
    #paginaBusqueda  { gap:36px; padding:36px 40px; }
    .hero-logo       { height:100px; max-width:380px; }
    .search-card     { max-width:min(88vw, 560px); border-radius:28px; padding:34px 34px 40px; }
    #consultaForm    { gap:22px; }
    .field-lbl       { font-size:16px; }
    .dni-input       { font-size:48px; padding:20px 24px; border-radius:16px; }
    .dni-input::placeholder { font-size:48px; }
    .btn-consultar   { font-size:24px; padding:24px; border-radius:18px; }
    .btn-consultar .btn-icon { font-size:28px; }
    .numpad          { gap:16px; }
    .nk              { font-size:44px; border-radius:16px; }

    .topbar          { top:24px; left:24px; }
    .btn-volver      { font-size:17px; padding:13px 24px; border-radius:12px; }
    .topbar-hint     { font-size:15px; }
    #resultadoContenido { max-width:min(88vw, 900px); }
    .client-card     { border-radius:26px; }
    .card-head       { padding:26px 32px; gap:20px; }
    .ch-avatar       { width:72px; height:72px; font-size:34px; }
    .ch-info h2      { font-size:34px; margin-bottom:8px; }
    .badge           { font-size:13px; padding:6px 18px; }
    .card-body       { padding:24px 32px 16px; }
    .s-title         { font-size:12px; margin-bottom:14px; }
    .info-grid       { gap:12px; }
    .info-cell       { padding:14px 18px; border-radius:12px; }
    .ic-lbl          { font-size:11px; margin-bottom:5px; }
    .ic-val          { font-size:20px; }
    .c-divider       { margin:0 32px; }
    .deuda-wrap      { padding:22px 32px; }
    .deuda-box       { padding:22px 28px; gap:22px; border-radius:18px; }
    .deuda-ico       { font-size:56px; }
    .deuda-lbl       { font-size:14px; }
    .deuda-monto     { font-size:60px; }
    .sin-deuda-msg   { font-size:38px; }
    .btn-pagar       { font-size:19px; padding:17px 30px; border-radius:14px; }

    .qr-modal        { max-width:min(88vw, 620px); padding:42px 38px 34px; border-radius:28px; }
    .qr-empresa      { font-size:13px; }
    .qr-monto        { font-size:70px; margin-bottom:8px; }
    .qr-hint         { font-size:18px; margin-bottom:30px; }
    .qr-img          { max-width:min(420px, 70vw); border-radius:16px; }
    .qr-aviso        { font-size:15px; padding:14px 18px; margin:22px 0 18px; }
    .btn-terminar    { font-size:23px; padding:23px 20px; border-radius:18px; }
    .qrc-ico         { font-size:92px; margin-bottom:16px; }
    .qrc-titulo      { font-size:48px; margin-bottom:8px; }
    .qrc-sub         { font-size:19px; margin-bottom:12px; }
    .qrc-monto       { font-size:60px; }
}

/* ── 3. Landscape muy corta (≤580px alto) — notebooks con barra, tablet girado ── */
@media (max-height: 580px) {
    .resultado-inner { padding-top:48px; }
    .ch-avatar  { width:38px; height:38px; font-size:17px; }
    .ch-info h2 { font-size:16px; margin-bottom:2px; }
    .badge      { padding:3px 8px; font-size:10px; }
    .card-head  { padding:10px 16px; gap:10px; }
    .card-body  { padding:8px 16px 6px; }
    .s-title    { margin-bottom:5px; font-size:9px; }
    .info-grid  { gap:5px; }
    .ic-val     { font-size:13px; }
    .ic-lbl     { font-size:9px; }
    .deuda-wrap { padding:8px 16px; }
    .deuda-monto { font-size:26px; }
    .deuda-ico  { font-size:26px; }
    .deuda-box  { padding:10px 14px; gap:12px; border-radius:10px; }
    .btn-pagar  { padding:10px 16px; font-size:13px; }
    .sin-deuda-msg { font-size:20px; }

    .qr-modal   { padding:16px 18px; max-height:88vh; }
    .qr-monto   { font-size:32px; margin-bottom:4px; }
    .qr-hint    { font-size:12px; margin-bottom:10px; }
    .qr-img     { max-width:min(200px, 55vw); }
    .qr-aviso   { padding:8px 12px; font-size:11px; margin:8px 0; }
    .btn-terminar { padding:12px 20px; font-size:14px; }
}
