/* ══════════════════════════════════════════════════
   AQUA & VESTIS — Design System
   Primary:  #15234A  (azul marino)
   Accent:   #C3986B  (dorado cobre)
   Neutral:  #606060  (gris)
   Light:    #F0F0EC  (hueso)
══════════════════════════════════════════════════ */
@font-face{
  font-family:'EuropaNuova';
  src:local('EuropaNuovaBold'),local('Europa Nuova Bold');
  font-weight:700;font-style:normal;
}
:root{
  --navy:   #15234A;
  --copper: #C3986B;
  --gray:   #606060;
  --bone:   #F0F0EC;
  --navy2:  #1d2f5e;
  --navy3:  #0d1630;
  --navy4:  #091022;
  --copper2:#d4aa82;
  --copper3:#a07a4e;
  --bone2:  #e2e2dd;
  --bone3:  #d4d4cf;
  --ok:     #3a8f6a;
  --err:    #b94040;
  --warn:   #b07030;
  --bdr:    rgba(195,152,107,.22);
  --bdr2:   rgba(240,240,236,.09);
  --r:      14px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{width:100%;height:100%;overflow:hidden;background:var(--navy4);font-family:Helvetica,Arial,sans-serif;color:var(--bone);user-select:none;touch-action:pan-y;-webkit-font-smoothing:antialiased}
button{font-family:Helvetica,Arial,sans-serif;cursor:pointer;border:none;outline:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}

/* ── APP SHELL portrait 480px ── */
#K{
  position:fixed;top:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:480px;height:100%;
  background:var(--navy);display:flex;flex-direction:column;overflow:hidden;
}

/* ── SCREEN MANAGER ── */
.scr{
  position:absolute;inset:0;display:flex;flex-direction:column;
  background:var(--navy);overflow:hidden;
  opacity:0;transform:translateY(14px);pointer-events:none;
  transition:opacity .3s ease,transform .3s ease;
}
.scr.SHOW{opacity:1;transform:translateY(0);pointer-events:auto}

/* ── HEADER ── */
.H{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px 12px;flex-shrink:0;
  background:rgba(21,35,74,.97);border-bottom:1px solid var(--bdr2);
  backdrop-filter:blur(20px);z-index:10;
}
.H-logo{display:flex;align-items:center;gap:11px}
.H-mark{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:var(--copper3);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.H-mark img{width:100%;height:100%;object-fit:contain;padding:4px}
.H-name{
  font-family:'EuropaNuova',Helvetica,sans-serif;
  font-size:15px;font-weight:700;letter-spacing:.12em;
  color:var(--copper);line-height:1;text-transform:uppercase;
}
.H-sub{font-size:8px;letter-spacing:.18em;color:rgba(240,240,236,.4);text-transform:uppercase;margin-top:2px}
.H-right{display:flex;align-items:center;gap:9px}
.H-clk{font-family:'Courier New',monospace;font-size:12px;color:rgba(240,240,236,.45);letter-spacing:.06em}
.H-dot{width:6px;height:6px;border-radius:50%;background:var(--ok);animation:blink 2.5s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

/* ── SCROLL AREA ── */
.scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.scroll::-webkit-scrollbar{display:none}
.p{padding:16px 18px}

/* ── BOTTOM BAR ── */
.B{
  flex-shrink:0;padding:11px 18px 16px;
  background:rgba(21,35,74,.97);border-top:1px solid var(--bdr2);
  backdrop-filter:blur(16px);
}

/* ── BUTTONS ── */
.btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;min-height:56px;border-radius:12px;
  font-size:14px;font-weight:600;letter-spacing:.04em;
  transition:filter .1s,transform .1s;
}
.btn:active{filter:brightness(1.12);transform:scale(.98)}
.btn:disabled{opacity:.28;pointer-events:none}
.btn-primary{
  background:var(--copper);color:var(--navy4);
  box-shadow:0 4px 20px rgba(195,152,107,.3);
  font-family:'EuropaNuova',Helvetica,sans-serif;letter-spacing:.06em;
}
.btn-ghost{
  background:rgba(240,240,236,.07);color:rgba(240,240,236,.6);
  border:1px solid var(--bdr2);
}
.btn-ghost:active{background:rgba(240,240,236,.12)}
.btn-sm{min-height:40px;font-size:12px;padding:0 14px;width:auto;border-radius:9px}
.btn-outline{
  background:transparent;color:var(--copper);
  border:1.5px solid var(--copper3);
}

/* ── CARDS ── */
.card{
  background:rgba(240,240,236,.05);
  border:1px solid var(--bdr2);
  border-radius:var(--r);padding:15px;
}
.card+.card{margin-top:10px}

/* ── SECTION LABEL ── */
.sec{
  font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--copper3);margin-bottom:11px;font-weight:600;
}

/* ── BADGE ── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  border-radius:6px;padding:3px 9px;font-size:10px;font-weight:600;
  letter-spacing:.04em;
}
.b-ok{background:rgba(58,143,106,.15);color:#5dbf91;border:1px solid rgba(58,143,106,.3)}
.b-warn{background:rgba(176,112,48,.14);color:#d4924a;border:1px solid rgba(176,112,48,.28)}
.b-copper{background:rgba(195,152,107,.12);color:var(--copper2);border:1px solid var(--bdr)}
.b-err{background:rgba(185,64,64,.13);color:#e07070;border:1px solid rgba(185,64,64,.28)}

/* ── DIVIDER ── */
.div{height:1px;background:var(--bdr2);margin:13px 0}

/* ── TOAST ── */
#TOAST{
  position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(6px);
  background:var(--navy2);border:1px solid var(--bdr);
  border-radius:10px;padding:10px 18px;font-size:13px;color:var(--bone);
  z-index:999;opacity:0;transition:all .22s;pointer-events:none;
  white-space:nowrap;max-width:90%;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}
#TOAST.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* ════════════════════════════════════
   IDLE SCREEN
════════════════════════════════════ */
#SI{background:var(--navy4)}

.idle-pattern{
  position:absolute;inset:0;z-index:0;
  opacity:.08;background-size:120px auto;background-repeat:repeat;
}
.idle-header{
  position:relative;z-index:2;
  padding:22px 22px 0;display:flex;justify-content:space-between;align-items:flex-start;
}
.idle-logo{width:110px;opacity:.9}
.idle-time{
  font-family:'Courier New',monospace;font-size:11px;
  color:rgba(240,240,236,.3);letter-spacing:.08em;
  text-align:right;
}

.ad-wrap{
  flex:1;position:relative;overflow:hidden;z-index:1;
  display:flex;flex-direction:column;justify-content:center;
}
.ad{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:center;
  padding:28px 26px 20px;
  opacity:0;transition:opacity .7s ease;
}
.ad.SHOW{opacity:1}

.ad-tag{
  font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--copper);margin-bottom:18px;
  display:flex;align-items:center;gap:10px;
}
.ad-tag::before{content:'';width:24px;height:1px;background:var(--copper3)}

.ad-title{
  font-family:'EuropaNuova',Helvetica,sans-serif;
  font-size:clamp(44px,13vw,72px);
  font-weight:700;line-height:.92;letter-spacing:-.02em;
  color:var(--bone);margin-bottom:16px;
}
.ad-title em{color:var(--copper);font-style:normal}

.ad-sub{font-size:13px;color:rgba(240,240,236,.55);line-height:1.65;max-width:300px;margin-bottom:26px}

.price-pill{
  display:inline-flex;align-items:baseline;gap:5px;
  background:rgba(195,152,107,.12);border:1px solid var(--bdr);
  border-radius:50px;padding:9px 20px;
  font-size:11px;color:var(--copper2);letter-spacing:.06em;
}
.price-pill strong{font-size:34px;font-weight:700;color:var(--copper);font-family:'EuropaNuova',Helvetica,sans-serif}

.feat-g{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}
.feat-c{
  background:rgba(240,240,236,.05);border:1px solid var(--bdr2);
  border-radius:11px;padding:13px;
}
.fc-ico{font-size:20px;margin-bottom:7px}
.fc-t{font-size:13px;font-weight:600;color:var(--bone);margin-bottom:3px}
.fc-d{font-size:11px;color:rgba(240,240,236,.45);line-height:1.5}

.pay-g{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.pay-c{
  background:rgba(240,240,236,.06);border:1px solid var(--bdr2);
  border-left:2px solid var(--copper3);
  border-radius:10px;padding:11px 10px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.pc-ico{font-size:22px}
.pc-n{font-size:10px;color:rgba(240,240,236,.55);text-align:center;line-height:1.4;letter-spacing:.02em}

.suc-g{display:flex;flex-wrap:wrap;gap:5px}
.suc-n{
  font-size:9px;padding:4px 9px;border-radius:20px;
  background:rgba(240,240,236,.07);color:rgba(240,240,236,.35);
  border:1px solid var(--bdr2);transition:all .3s;
}
.suc-n.lit{background:rgba(195,152,107,.15);color:var(--copper2);border-color:var(--bdr)}

/* Idle footer */
.idle-f{
  position:relative;z-index:2;
  padding:14px 22px 18px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  border-top:1px solid var(--bdr2);
  background:rgba(21,35,74,.7);backdrop-filter:blur(10px);
}
.sd{display:flex;gap:7px;margin-bottom:2px}
.sd-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(240,240,236,.2);transition:background .3s;
}
.sd-dot.a{background:var(--copper)}

.idle-tap{
  font-family:'EuropaNuova',Helvetica,sans-serif;
  font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--navy4);background:var(--copper);
  padding:14px 44px;border-radius:50px;border:none;cursor:pointer;
  box-shadow:0 6px 28px rgba(195,152,107,.35);
  animation:float 3s ease-in-out infinite;
  transition:transform .1s,filter .1s;
}
.idle-tap:active{transform:scale(.96);filter:brightness(1.1)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

.idle-note{font-size:9px;letter-spacing:.14em;color:rgba(240,240,236,.25);text-transform:uppercase}

#adm-zone{position:fixed;bottom:0;right:0;width:50px;height:50px;z-index:20}

/* ════════════════════════════════════
   REGISTRO
════════════════════════════════════ */
.reg-input{
  display:flex;align-items:center;gap:12px;
  background:rgba(240,240,236,.05);border:1px solid var(--bdr2);
  border-radius:12px;padding:13px 15px;margin-bottom:10px;cursor:pointer;
  transition:border-color .18s,background .18s;
}
.reg-input:active,.reg-input:hover{border-color:var(--copper3);background:rgba(195,152,107,.06)}
.ri-ico{font-size:20px;flex-shrink:0;width:28px;text-align:center}
.ri-body{flex:1;min-width:0}
.ri-lbl{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--copper3);margin-bottom:3px}
.ri-val{font-size:16px;font-weight:500;color:var(--bone);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ri-val.ph{color:rgba(240,240,236,.22)}

.cf{
  background:rgba(58,143,106,.08);border:1px solid rgba(58,143,106,.22);
  border-radius:12px;padding:14px;margin-bottom:10px;display:none;
}
.cf-name{font-family:'EuropaNuova',Helvetica,sans-serif;font-size:19px;font-weight:700;color:var(--copper);margin-bottom:10px}
.cf-row{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}

.nf{
  background:rgba(195,152,107,.07);border:1px solid var(--bdr);
  border-radius:12px;padding:14px;margin-bottom:10px;display:none;
}
.nf-t{font-size:12px;font-weight:600;color:var(--copper2);margin-bottom:12px;letter-spacing:.02em}

/* Fidelidad dots */
.lp-row{display:flex;gap:5px;margin-top:4px}
.lp-b{
  flex:1;height:5px;border-radius:3px;
  background:rgba(240,240,236,.1);transition:background .3s;
}
.lp-b.fill{background:var(--copper)}

/* ════════════════════════════════════
   SERVICIOS / MÁQUINAS
════════════════════════════════════ */
.mach-card{
  background:rgba(240,240,236,.04);border:1px solid var(--bdr2);
  border-radius:var(--r);overflow:hidden;margin-bottom:12px;
}
.mach-hd{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px 12px;border-bottom:1px solid var(--bdr2);
}
.mach-nm{font-size:15px;font-weight:600;color:var(--bone);margin-bottom:3px}
.mach-meta{font-size:10px;color:rgba(240,240,236,.35);letter-spacing:.04em}

.svc-grid{padding:10px;display:flex;flex-direction:column;gap:7px}
.svc-btn{
  display:flex;align-items:center;gap:13px;
  background:rgba(240,240,236,.04);border:1px solid var(--bdr2);
  border-left:3px solid transparent;
  border-radius:10px;padding:13px 14px;width:100%;
  cursor:pointer;transition:all .18s;text-align:left;
  position:relative;
}
.svc-btn:active,.svc-btn:hover{background:rgba(195,152,107,.08);border-color:var(--copper3)}
.svc-btn.SEL{
  background:rgba(195,152,107,.1);
  border-color:var(--copper3);border-left-color:var(--copper);
}
.sb-chk{
  width:20px;height:20px;border-radius:50%;
  background:rgba(240,240,236,.08);border:1.5px solid var(--bdr2);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;color:transparent;flex-shrink:0;transition:all .18s;
}
.svc-btn.SEL .sb-chk{background:var(--copper);border-color:var(--copper);color:var(--navy4)}
.sb-n{flex:1;font-size:14px;font-weight:500;color:var(--bone)}
.sb-p{font-family:'Courier New',monospace;font-size:16px;font-weight:600;color:var(--copper);flex-shrink:0}
.sb-t{font-size:10px;color:rgba(240,240,236,.35);text-align:right;margin-top:1px}

.busy-bar{
  padding:12px 16px;font-size:12px;
  color:rgba(240,240,236,.4);background:rgba(176,112,48,.07);
  border-top:1px solid rgba(176,112,48,.15);
}

/* Sel bar */
.sel-bar{
  padding:11px 18px;background:rgba(21,35,74,.97);
  border-top:1px solid var(--bdr2);flex-shrink:0;
  display:flex;justify-content:space-between;align-items:center;
}
.sel-lbl{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--copper3);margin-bottom:2px}
.sel-nm{font-size:13px;color:var(--bone2)}
.sel-pr{font-family:'EuropaNuova',Helvetica,sans-serif;font-size:26px;font-weight:700;color:var(--copper)}

/* ════════════════════════════════════
   PAGO
════════════════════════════════════ */
.ord-r{display:flex;justify-content:space-between;font-size:13px;margin-bottom:8px}
.ord-l{color:rgba(240,240,236,.45)}
.ord-v{font-weight:500;color:var(--bone)}
.ord-tot{
  display:flex;justify-content:space-between;align-items:baseline;
  border-top:1px solid var(--bdr2);padding-top:11px;margin-top:8px;
}
.ot-l{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--copper3)}
.ot-v{font-family:'EuropaNuova',Helvetica,sans-serif;font-size:28px;font-weight:700;color:var(--copper)}

.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.pm{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  background:rgba(240,240,236,.04);border:1px solid var(--bdr2);
  border-radius:12px;padding:13px 8px;cursor:pointer;
  transition:all .18s;text-align:center;position:relative;
}
.pm:active,.pm:hover{background:rgba(195,152,107,.08);border-color:var(--copper3)}
.pm.SEL{background:rgba(195,152,107,.1);border-color:var(--copper)}
.pm.SOON{opacity:.4;cursor:not-allowed}
.pm-soon{
  position:absolute;top:6px;right:6px;font-size:8px;letter-spacing:.06em;
  background:rgba(195,152,107,.15);color:var(--copper3);padding:2px 6px;border-radius:4px;
}
.pm-chk{
  position:absolute;top:7px;right:7px;
  width:16px;height:16px;border-radius:50%;
  background:transparent;border:1.5px solid transparent;
  font-size:9px;display:flex;align-items:center;justify-content:center;
  color:transparent;transition:all .18s;
}
.pm.SEL .pm-chk{background:var(--copper);border-color:var(--copper);color:var(--navy4)}
.pm-i{font-size:24px}
.pm-n{font-size:11px;font-weight:600;color:var(--bone);line-height:1.3}
.pm-d{font-size:9px;color:rgba(240,240,236,.35)}

/* Card credit preview */
.cprev{
  width:100%;height:130px;border-radius:14px;
  background:linear-gradient(135deg,var(--navy2) 0%,var(--navy3) 100%);
  border:1px solid var(--bdr);padding:16px;margin-bottom:10px;
  position:relative;overflow:hidden;
}
.cprev::before{
  content:'';position:absolute;right:-30px;top:-30px;
  width:160px;height:160px;border-radius:50%;
  background:rgba(195,152,107,.07);
}
.c-brand{font-size:11px;color:var(--copper3);letter-spacing:.16em;margin-bottom:8px}
.c-chip{width:24px;height:18px;border-radius:3px;background:var(--copper3);opacity:.6;margin-bottom:10px}
.c-num{font-family:'Courier New',monospace;font-size:14px;letter-spacing:.16em;color:var(--bone2);margin-bottom:9px}
.c-bot{display:flex;justify-content:space-between;align-items:flex-end}
.c-hold{font-size:12px;font-weight:600;color:var(--bone);text-transform:uppercase;letter-spacing:.06em}
.c-exp{font-family:'Courier New',monospace;font-size:12px;color:var(--copper3)}

.pi{
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(240,240,236,.05);border:1px solid var(--bdr2);
  border-radius:10px;padding:12px 14px;margin-bottom:8px;width:100%;
  cursor:pointer;transition:border-color .18s;
}
.pi:hover,.pi:active{border-color:var(--copper3)}
.pi-lbl{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--copper3);white-space:nowrap}
.pi-v{font-family:'Courier New',monospace;font-size:14px;color:var(--bone);text-align:right;flex:1;margin-left:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pi-v.ph{color:rgba(240,240,236,.2)}

/* POS */
.pos{
  background:rgba(240,240,236,.04);border:1px solid var(--bdr2);
  border-radius:14px;padding:16px;text-align:center;margin-bottom:10px;
}
.pos-sl{width:80%;height:3px;background:var(--copper3);border-radius:2px;margin:0 auto 14px;opacity:.4}
.pos-scr{
  font-family:'EuropaNuova',Helvetica,sans-serif;font-size:28px;font-weight:700;
  color:var(--copper);margin-bottom:14px;line-height:1;
}
.pos-kp{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-width:180px;margin:0 auto 10px}
.pos-k{
  background:rgba(240,240,236,.08);border-radius:7px;
  padding:8px;font-size:14px;font-weight:500;
  color:var(--bone2);
}
.pos-tag{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(240,240,236,.25)}

/* NFC */
.nfc-w{
  display:flex;align-items:center;justify-content:center;
  height:120px;position:relative;margin-bottom:12px;
}
.nfc-r{
  position:absolute;border:1.5px solid var(--copper3);border-radius:50%;
  animation:nfc-p 2s ease-out infinite;opacity:0;
}
.nfc-r:nth-child(1){width:60px;height:60px;animation-delay:0s}
.nfc-r:nth-child(2){width:95px;height:95px;animation-delay:.5s}
.nfc-r:nth-child(3){width:130px;height:130px;animation-delay:1s}
@keyframes nfc-p{0%{opacity:.7;transform:scale(.7)}100%{opacity:0;transform:scale(1)}}

/* Biometric */
.bio{
  display:flex;flex-direction:column;align-items:center;
  padding:16px;background:rgba(240,240,236,.04);
  border:1px solid var(--bdr2);border-radius:14px;margin-bottom:10px;
  position:relative;overflow:hidden;
}
.bio-sl{
  position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--copper);animation:bio-s 2s ease-in-out infinite;
  box-shadow:0 0 8px var(--copper);
}
@keyframes bio-s{0%,100%{top:0;opacity:1}50%{top:calc(100% - 2px);opacity:.6}}
.bio-f{font-size:52px;margin:10px 0}
.bio-d{display:flex;gap:5px}
.bd{width:30px;height:3px;border-radius:2px;background:rgba(195,152,107,.35)}

/* Efectivo */
.cash-top{
  background:rgba(195,152,107,.1);border:1px solid var(--bdr);
  border-radius:12px;padding:14px;text-align:center;margin-bottom:10px;
}
.cash-lbl{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--copper3);margin-bottom:4px}
.cash-v{font-family:'EuropaNuova',Helvetica,sans-serif;font-size:36px;font-weight:700;color:var(--copper)}
.bills{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:10px}
.bill{
  background:rgba(240,240,236,.06);border:1px solid var(--bdr2);
  border-radius:9px;padding:10px 5px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  font-size:12px;font-weight:600;color:var(--copper2);cursor:pointer;
  transition:all .15s;
}
.bill:active{background:rgba(195,152,107,.12);border-color:var(--copper3)}
.bill-e{font-size:16px}

/* ════════════════════════════════════
   PROCESANDO
════════════════════════════════════ */
#SPRO{
  align-items:center;justify-content:center;
  background:var(--navy4);
}
.spin-wrap{position:relative;margin-bottom:28px}
.ring{
  width:76px;height:76px;border-radius:50%;
  border:2.5px solid rgba(195,152,107,.15);
  border-top-color:var(--copper);
  animation:spin 1.1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.ring::after{
  content:'';position:absolute;inset:8px;border-radius:50%;
  border:2px solid rgba(195,152,107,.08);
  border-bottom-color:var(--copper3);
  animation:spin 1.8s linear infinite reverse;
}
.pro-title{
  font-family:'EuropaNuova',Helvetica,sans-serif;
  font-size:22px;font-weight:700;letter-spacing:.04em;
  color:var(--bone);margin-bottom:6px;text-align:center;
}
.pro-sub{font-size:12px;color:rgba(240,240,236,.4);margin-bottom:28px;text-align:center}
.step{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;border-radius:10px;margin-bottom:6px;
  font-size:13px;color:rgba(240,240,236,.35);
  background:rgba(240,240,236,.03);border:1px solid transparent;
  transition:all .3s;
}
.step.cur{
  color:var(--bone);background:rgba(195,152,107,.08);
  border-color:var(--bdr);
}
.step.done{color:rgba(240,240,236,.5);background:transparent}
.step.done .step-i::after{content:'✓'}
.step-i{
  width:26px;height:26px;border-radius:50%;
  background:rgba(240,240,236,.07);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;flex-shrink:0;
}
.step.cur .step-i{background:var(--copper);color:var(--navy4)}
.step.done .step-i{background:rgba(58,143,106,.2);color:#5dbf91;font-size:11px}

/* ════════════════════════════════════
   ÉXITO
════════════════════════════════════ */
.chk{
  width:64px;height:64px;border-radius:50%;
  background:rgba(195,152,107,.12);border:2px solid var(--copper3);
  display:flex;align-items:center;justify-content:center;
  font-size:26px;color:var(--copper);margin:0 auto 16px;
}
.mach-live{
  display:flex;align-items:center;gap:14px;
  background:rgba(240,240,236,.05);border:1px solid var(--bdr2);
  border-radius:12px;padding:14px;margin-bottom:16px;text-align:left;
}
.ml-ico{font-size:32px}
.ctdn{
  font-family:'EuropaNuova',Helvetica,sans-serif;
  font-size:22px;font-weight:700;color:var(--copper);
}

/* Receipt */
.rcpt{
  background:rgba(240,240,236,.04);border:1px solid var(--bdr2);
  border-radius:14px;padding:16px;text-align:left;
}
.rh{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.rbrand{
  font-family:'EuropaNuova',Helvetica,sans-serif;
  font-size:15px;font-weight:700;letter-spacing:.1em;
  color:var(--copper);text-transform:uppercase;
}
.rid{font-family:'Courier New',monospace;font-size:10px;color:rgba(240,240,236,.3);margin-top:2px}
.rrow{display:flex;justify-content:space-between;font-size:13px;margin-bottom:7px}
.rlbl{color:rgba(240,240,236,.4)}
.rsep{border:none;border-top:1px dashed var(--bdr2);margin:10px 0}
.rnote{
  font-size:10px;color:rgba(240,240,236,.35);
  background:rgba(240,240,236,.04);border:1px solid var(--bdr2);
  border-radius:7px;padding:8px 10px;margin-top:8px;line-height:1.5;
}

/* ════════════════════════════════════
   ADMIN
════════════════════════════════════ */
.atabs{
  display:flex;gap:4px;padding:10px 14px;
  border-bottom:1px solid var(--bdr2);flex-shrink:0;
  overflow-x:auto;background:rgba(21,35,74,.97);
}
.atabs::-webkit-scrollbar{display:none}
.atab{
  font-size:11px;font-weight:600;letter-spacing:.04em;
  padding:7px 12px;border-radius:8px;white-space:nowrap;
  background:rgba(240,240,236,.05);color:rgba(240,240,236,.5);
  border:1px solid transparent;transition:all .18s;
}
.atab.A{background:rgba(195,152,107,.12);color:var(--copper);border-color:var(--bdr)}
.tpane{display:none}
.tpane.A{display:block}
.kg{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:10px}
.kc{
  background:rgba(240,240,236,.05);border:1px solid var(--bdr2);
  border-radius:11px;padding:11px 12px;
}
.kl{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--copper3);margin-bottom:4px}
.kv{font-family:'EuropaNuova',Helvetica,sans-serif;font-size:22px;font-weight:700;color:var(--copper);line-height:1;margin-bottom:2px}
.kd{font-size:10px;color:rgba(58,143,106,.8)}
.pb{height:3px;background:rgba(240,240,236,.08);border-radius:2px;margin:8px 0 6px}
.pf{height:100%;border-radius:2px;background:var(--copper3)}
.tw{overflow-x:auto}
.tw-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:12px}
.tbl{width:100%;border-collapse:collapse;font-size:11px}
.tbl th{padding:7px 8px;text-align:left;font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--copper3);border-bottom:1px solid var(--bdr2)}
.tbl td{padding:8px 8px;border-bottom:1px solid rgba(240,240,236,.04);color:rgba(240,240,236,.55)}
.tbl tr:hover td{color:var(--bone)}
.tog{
  width:36px;height:20px;background:rgba(240,240,236,.1);
  border-radius:10px;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0;
}
.tog.on{background:var(--copper)}
.tog::after{
  content:'';position:absolute;top:3px;left:3px;
  width:14px;height:14px;border-radius:50%;background:var(--bone);
  transition:left .2s;
}
.tog.on::after{left:19px}
.tg{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--bdr2)}
.tg:last-child{border:none;padding-bottom:0}

/* ════════════════════════════════════
   ON-SCREEN KEYBOARD
════════════════════════════════════ */
#OSK{
  position:fixed;inset:0;z-index:100;
  background:rgba(9,16,34,.75);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;justify-content:flex-end;
  opacity:0;pointer-events:none;transition:opacity .22s;
}
#OSK.SHOW{opacity:1;pointer-events:auto}
.osk-box{
  background:var(--navy2);border-top:1px solid var(--bdr2);
  border-radius:20px 20px 0 0;padding:12px 4px 22px;
  max-width:480px;width:100%;margin:0 auto;
}
.osk-lbl{
  font-size:9px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--copper3);margin:0 4px 5px 6px;display:block;
}
.osk-disp{
  background:rgba(240,240,236,.06);border:1.5px solid var(--copper3);border-radius:9px;
  min-height:44px;padding:8px 12px;margin:0 4px 8px;
  font-family:'Courier New',monospace;font-size:17px;color:var(--bone);
  display:flex;align-items:center;word-break:break-all;gap:2px;overflow:hidden;
}
.osk-cur{width:2px;height:20px;background:var(--copper);animation:blink .8s infinite;flex-shrink:0}
.osk-rows{display:flex;flex-direction:column;gap:4px;padding:0}
.osk-row{display:flex;gap:2px}
.K{
  flex:1;min-height:44px;min-width:0;border-radius:7px;
  background:rgba(240,240,236,.07);border:1px solid var(--bdr2);
  color:var(--bone);font-family:Helvetica,sans-serif;font-size:13px;font-weight:500;padding:0;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:filter .1s;touch-action:manipulation;
}
.K:active{filter:brightness(1.4)}
.K.w2{flex:2}.K.w3{flex:3}.K.w4{flex:4}
.K.gold{background:rgba(195,152,107,.15);color:var(--copper2);border-color:var(--bdr)}
.K.del{background:rgba(185,64,64,.12);color:#e07070;border-color:rgba(185,64,64,.2)}
.K.ok{background:var(--copper);color:var(--navy4);font-weight:700;border-color:var(--copper)}
.K.space{font-size:10px;color:rgba(240,240,236,.3);letter-spacing:.06em}
.K.shift-on{background:rgba(195,152,107,.2);border-color:var(--copper3)}