/* Fuentes self-hosted. Variable woff2: una sola descarga cubre todos los pesos. */
@font-face{
  font-family:'Hanken Grotesk';
  font-style:normal;
  font-weight:400 800;
  font-display:swap;
  src:url('./fonts/hanken-grotesk.woff2') format('woff2-variations'),
      url('./fonts/hanken-grotesk.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'JetBrains Mono';
  font-style:normal;
  font-weight:400 700;
  font-display:swap;
  src:url('./fonts/jetbrains-mono.woff2') format('woff2-variations'),
      url('./fonts/jetbrains-mono.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

:root{
  --bg:#15140f;
  --surface:#1f1e17;
  --surface-2:#272519;
  --line:#332f22;
  --ink:#f5f3ea;
  --ink-2:#a8a496;
  --ink-3:#6f6c5e;
  --brand:#cdf23a;
  --brand-ink:#1a1c08;
  --pos:#4ade80;
  --neg:#fb7185;
  --paper:#f7f4e9;
  --paper-ink:#1c1a12;
  --paper-line:#cdc7b2;
  --radius:16px;
  --radius-sm:11px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:16px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select{font-family:inherit;font-size:16px}
input:focus-visible,button:focus-visible,select:focus-visible{outline:2px solid var(--brand);outline-offset:2px}

/* shell */
#app{max-width:480px;margin:0 auto;padding:0 18px;padding-top:max(18px,env(safe-area-inset-top));padding-bottom:108px;min-height:100%}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:6px 0 18px}
.brandmark{display:flex;align-items:center;gap:9px;font-weight:800;letter-spacing:-.03em;font-size:18px}
.brandmark .dot{width:26px;height:26px;border-radius:8px;background:var(--brand);display:grid;place-items:center;color:var(--brand-ink);flex:none}
.brandmark .dot svg{width:15px;height:15px}
.biz{font-size:12.5px;color:var(--ink-2);font-weight:600;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}

/* generic */
.eyebrow{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:700}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.card+.card{margin-top:14px}
.muted{color:var(--ink-2)}
.amount{font-size:13px}

/* status pill */
.status{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:var(--ink-2);margin-bottom:4px}
.status .led{width:8px;height:8px;border-radius:50%;background:var(--ink-3)}
.status.open .led{background:var(--pos);box-shadow:0 0 0 4px rgba(74,222,128,.16)}
.status.stale .led{background:#f0c14b;box-shadow:0 0 0 4px rgba(240,193,75,.18)}
.status.stale{color:#dab866}

/* warning hint dentro de una card (caja vieja, etc.) */
.card-hint{margin-top:14px;padding:11px 13px;border-radius:11px;font-size:13px;font-weight:500;line-height:1.4}
.card-hint.warn{background:rgba(240,193,75,.10);color:#e0bd6b;border:1px solid rgba(240,193,75,.25)}

/* hero closed */
.hero-closed{text-align:center;padding:46px 20px 30px}
.hero-closed h1{font-size:25px;font-weight:800;letter-spacing:-.03em;margin-bottom:8px}
.hero-closed p{color:var(--ink-2);font-size:14.5px;max-width:280px;margin:0 auto 26px}
.coin{width:74px;height:74px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#e6ff63,#a9cf1f);margin:0 auto 22px;display:grid;place-items:center;color:#2a2e08;box-shadow:0 10px 30px -10px rgba(205,242,58,.5),inset 0 -3px 8px rgba(0,0,0,.25)}
.coin svg{width:34px;height:34px}

/* big number */
.bignum-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.bignum{font-size:42px;font-weight:700;letter-spacing:-.03em;line-height:1.05}
.bignum .cur{font-size:24px;color:var(--ink-3);margin-right:4px;font-weight:500}

/* method grid */
.methods{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.method{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 13px}
.method .mlabel{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-2);font-weight:600;margin-bottom:4px}
.method .mlabel .ic{width:9px;height:9px;border-radius:3px;flex:none}
.ic-efectivo{background:#7dd87d}.ic-tarjeta{background:#76b8ff}.ic-transferencia{background:#f0c14b}.ic-qr{background:#c79bff}
.method .mval{font-size:16px;font-weight:500}

/* cash-on-hand strip */
.strip{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding:13px 15px;background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--line)}
.strip .k{font-size:13px;color:var(--ink-2);font-weight:600}
.strip .v{font-size:17px;font-weight:600}

/* buttons */
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;border-radius:13px;font-weight:700;font-size:15.5px;transition:transform .08s,filter .15s;letter-spacing:-.01em}
.btn:active{transform:scale(.985)}
.btn-primary{background:var(--brand);color:var(--brand-ink)}
.btn-primary:active{filter:brightness(.95)}
.btn-ghost{background:var(--surface-2);color:var(--ink);border:1px solid var(--line)}
.btn-line{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-danger{background:transparent;color:var(--neg);border:1px solid rgba(251,113,133,.3)}
.btn svg{width:18px;height:18px;flex:none}
.btn-row{display:flex;gap:10px;margin-top:14px}
.btn-row .btn{margin:0}
.btn.sm{padding:12px;font-size:14px}
.actions{margin-top:18px}
.actions .btn+.btn{margin-top:10px}

/* sales list (detalle) */
.list-head{display:flex;align-items:center;justify-content:space-between;margin:22px 4px 10px}
.list-head h2{font-size:15px;font-weight:700;letter-spacing:-.02em}
.list-head .count{font-size:12.5px;color:var(--ink-3);font-weight:600}
.row{display:flex;align-items:center;gap:12px;padding:13px 15px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm)}
.row+.row{margin-top:8px}
.row .tag{width:9px;height:9px;border-radius:3px;flex:none}
.row .rmid{flex:1;min-width:0}
.row .rmeth{font-size:14px;font-weight:600}
.row .rtime{font-size:12px;color:var(--ink-3)}
.row .rval{font-size:15px;font-weight:600}
.row .del{color:var(--ink-3);padding:6px;margin:-6px -6px -6px 2px;border-radius:8px}
.row .del:active{color:var(--neg)}
.row .del svg{width:16px;height:16px;display:block}
.empty{text-align:center;color:var(--ink-3);font-size:13.5px;padding:24px 16px;border:1px dashed var(--line);border-radius:var(--radius-sm)}

/* movement chips */
.mv-row{display:flex;align-items:center;gap:11px;padding:12px 15px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm)}
.mv-row+.mv-row{margin-top:8px}
.mv-ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:none}
.mv-ic svg{width:15px;height:15px}
.mv-ic.out{background:rgba(251,113,133,.14);color:var(--neg)}
.mv-ic.in{background:rgba(74,222,128,.14);color:var(--pos)}
.mv-ic.gasto{background:rgba(240,193,75,.14);color:#f0c14b}
.mv-row .mmid{flex:1;min-width:0}
.mv-row .mtit{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mv-row .msub{font-size:12px;color:var(--ink-3)}
.mv-row .mval{font-size:14.5px;font-weight:600}

/* nav */
.nav{position:fixed;bottom:0;left:0;right:0;z-index:40;background:rgba(21,20,15,.86);backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:8px 0 max(8px,env(safe-area-inset-bottom))}
.nav-inner{max-width:480px;margin:0 auto;display:flex;padding:0 30px}
.nav button{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:5px;color:var(--ink-3);font-size:11px;font-weight:600}
.nav button svg{width:22px;height:22px}
.nav button.on{color:var(--brand)}

/* modal */
.scrim{position:fixed;inset:0;z-index:60;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.scrim.show{opacity:1;pointer-events:auto}
.sheet{width:100%;max-width:480px;background:var(--surface);border:1px solid var(--line);border-bottom:none;border-radius:22px 22px 0 0;padding:8px 20px max(20px,env(safe-area-inset-bottom));transform:translateY(102%);transition:transform .26s cubic-bezier(.22,1,.36,1);max-height:90vh;overflow-y:auto}
.scrim.show .sheet{transform:translateY(0)}
.grip{width:38px;height:4px;border-radius:2px;background:var(--line);margin:8px auto 14px}
.sheet h2{font-size:19px;font-weight:800;letter-spacing:-.03em;margin-bottom:4px}
.sheet .sub{color:var(--ink-2);font-size:13.5px;margin-bottom:18px}

/* form */
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink-2);margin-bottom:7px;letter-spacing:.01em}
.money-input{position:relative}
.money-input .pfx{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--ink-3);font-weight:600;font-size:19px;pointer-events:none}
.inp{width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:14px 15px;color:var(--ink);font-weight:600}
.inp.big{padding-left:34px;font-size:21px;font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums}
.inp::placeholder{color:var(--ink-3);font-weight:400}
.inp:focus{border-color:var(--brand)}
select.inp{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23a8a496' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}

/* segmented + chips */
.seg{display:flex;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:13px;padding:5px}
.seg button{flex:1;padding:11px;border-radius:9px;font-weight:700;font-size:13.5px;color:var(--ink-2);transition:.15s}
.seg button.on{background:var(--brand);color:var(--brand-ink)}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:10px 15px;border-radius:11px;background:var(--surface-2);border:1px solid var(--line);font-weight:600;font-size:14px;color:var(--ink-2);transition:.15s;display:flex;align-items:center;gap:7px}
.chip .ic{width:9px;height:9px;border-radius:3px}
.chip.on{border-color:var(--brand);color:var(--ink);background:rgba(205,242,58,.08)}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--line)}
.toggle-row:last-child{border-bottom:none}
.toggle-row .tl{font-size:14.5px;font-weight:600}
.sw{width:46px;height:27px;border-radius:14px;background:var(--surface-2);border:1px solid var(--line);position:relative;transition:.2s;flex:none}
.sw::after{content:'';position:absolute;top:2px;left:2px;width:21px;height:21px;border-radius:50%;background:var(--ink-3);transition:.2s}
.sw.on{background:var(--brand);border-color:var(--brand)}
.sw.on::after{left:21px;background:var(--brand-ink)}

/* ===== TICKET (signature) ===== */
.ticket-wrap{filter:drop-shadow(0 18px 40px rgba(0,0,0,.45))}
.ticket{
  background:var(--paper);color:var(--paper-ink);
  padding:26px 22px 22px;
  --notch:9px;
  -webkit-mask:
    radial-gradient(var(--notch) at 0 50%,#0000 98%,#000) 0 0/100% 100% no-repeat,
    radial-gradient(var(--notch) at 100% 50%,#0000 98%,#000) 0 0/100% 100% no-repeat;
  -webkit-mask-composite:source-in;
  mask:
    radial-gradient(var(--notch) at 0 50%,#0000 98%,#000),
    radial-gradient(var(--notch) at 100% 50%,#0000 98%,#000);
  mask-composite:intersect;
  position:relative;
}
.ticket::before,.ticket::after{
  content:'';position:absolute;left:0;right:0;height:9px;
  background:radial-gradient(circle at 6px -1px,#0000 6px,var(--paper) 6.5px) repeat-x;
  background-size:14px 9px;
}
.ticket::before{top:-1px;transform:scaleY(-1)}
.ticket::after{bottom:-1px}
.t-head{text-align:center;margin-bottom:16px}
.t-head .t-biz{font-weight:800;font-size:16px;letter-spacing:-.02em}
.t-head .t-title{font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:#8a8470;margin-top:3px}
.t-head .t-date{font-family:'JetBrains Mono',monospace;font-size:12px;color:#6f6a58;margin-top:5px}
.t-rule{border:none;border-top:1.5px dashed var(--paper-line);margin:14px 0}
.t-line{display:flex;justify-content:space-between;align-items:baseline;font-size:13.5px;padding:3px 0}
.t-line .tk{color:#4a4636}
.t-line .tv{font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums;font-weight:500}
.t-line .tv.neg{color:#c4453f}
.t-sub{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#8a8470;font-weight:700;margin:4px 0 2px}
.t-big{display:flex;justify-content:space-between;align-items:center;padding:6px 0}
.t-big .bk{font-size:13px;font-weight:700}
.t-big .bv{font-family:'JetBrains Mono',monospace;font-size:19px;font-weight:700;font-variant-numeric:tabular-nums}
.t-result{text-align:center;padding:14px 0 8px}
.t-result .rk{font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:#8a8470}
.t-result .rv{font-family:'JetBrains Mono',monospace;font-size:30px;font-weight:700;margin-top:4px;letter-spacing:-.02em}
.t-result.pos .rv{color:#2f9e54}
.t-result.neg .rv{color:#c4453f}
.t-result.zero .rv{color:#1c1a12}
.t-result .rbadge{display:inline-flex;align-items:center;gap:5px;margin-top:8px;font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:20px}
.t-result.pos .rbadge{background:#dff3e2;color:#2f9e54}
.t-result.neg .rbadge{background:#fbe1e0;color:#c4453f}
.t-result.zero .rbadge{background:#ecf5cf;color:#5a6b15}
.t-total{display:flex;justify-content:space-between;align-items:center;background:#1c1a12;color:var(--paper);margin:6px -22px -22px;padding:16px 22px}
.t-total .ttk{font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700}
.t-total .ttv{font-family:'JetBrains Mono',monospace;font-size:20px;font-weight:700}

/* history: toolbar (selector de mes + botón Excel) + stats line */
.hist-toolbar{display:flex;gap:10px;align-items:center;margin-bottom:10px}
.hist-toolbar select{flex:1;min-width:0;padding:11px 38px 11px 14px;font-size:14px}
.hist-toolbar .btn-mini{flex:none;padding:11px 14px;font-size:13px}
.hist-stats{font-size:12.5px;color:var(--ink-3);margin:0 4px 14px;font-weight:600;line-height:1.4}

/* history */
.h-item{display:flex;align-items:center;gap:13px;padding:15px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm)}
.h-item+.h-item{margin-top:9px}
.h-item:active{border-color:var(--ink-3)}
.h-diff{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;flex:none;font-size:18px;font-weight:700}
.h-diff.pos{background:rgba(74,222,128,.13);color:var(--pos)}
.h-diff.neg{background:rgba(251,113,133,.13);color:var(--neg)}
.h-diff.zero{background:rgba(205,242,58,.13);color:var(--brand)}
.h-mid{flex:1;min-width:0}
.h-date{font-size:14.5px;font-weight:700;letter-spacing:-.01em}
.h-meta{font-size:12.5px;color:var(--ink-3);margin-top:1px}
.h-sig{font-size:11.5px;color:var(--ink-2);margin-top:3px;font-weight:600;text-transform:capitalize;letter-spacing:.01em}
.h-tot{text-align:right}
.h-tot .ht-v{font-size:15px;font-weight:700}
.h-tot .ht-k{font-size:11px;color:var(--ink-3)}

/* mini button used in list headers (e.g. "Excel" en Historial) */
.btn-mini{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:9px;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-2);font-weight:700;font-size:12px;letter-spacing:.01em;transition:.15s}
.btn-mini:active{transform:scale(.97)}
.btn-mini svg{width:14px;height:14px}

/* ticket meta (turno · cajero) */
.t-meta{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:#6f6a58;margin-top:3px;text-transform:capitalize}

/* misc */
.sec-title{font-size:13px;font-weight:700;color:var(--ink-2);margin:24px 4px 11px;letter-spacing:-.01em}
.hint{font-size:12px;color:var(--ink-3);margin-top:7px;line-height:1.4}
.toast{position:fixed;bottom:120px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--bg);font-weight:700;font-size:13.5px;padding:11px 18px;border-radius:30px;z-index:90;opacity:0;transition:.22s;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.fade{animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* sección Instalar app (Ajustes) */
.install-card{border-color:rgba(205,242,58,.35);background:linear-gradient(180deg,rgba(205,242,58,.06),var(--surface))}
.install-ios-title{font-weight:800;font-size:15px;letter-spacing:-.02em;margin-bottom:10px}
.install-ios-steps{padding-left:20px;font-size:13.5px;color:var(--ink-2);line-height:1.55}
.install-ios-steps li{margin-bottom:5px}
.install-ios-steps strong{color:var(--ink)}

/* update banner (nueva versión disponible) */
.update-banner{
  position:fixed;left:50%;top:max(0px,env(safe-area-inset-top));
  transform:translate(-50%,-110%);
  background:var(--brand);color:var(--brand-ink);
  padding:11px 18px;border-radius:0 0 18px 18px;
  font-family:inherit;font-weight:700;font-size:13.5px;letter-spacing:-.01em;
  display:flex;align-items:center;gap:10px;
  z-index:80;cursor:pointer;
  border:none;
  box-shadow:0 12px 28px -10px rgba(0,0,0,.4);
  transition:transform .28s cubic-bezier(.22,1,.36,1),opacity .2s;
  max-width:calc(100vw - 32px)
}
.update-banner.show{transform:translate(-50%,0)}
.update-banner.loading{opacity:.6;pointer-events:none}
.ub-dot{width:7px;height:7px;border-radius:50%;background:var(--brand-ink);animation:ub-pulse 1.4s infinite ease-in-out;flex:none}
.ub-text{font-weight:700}
.ub-cta{font-weight:800;opacity:.85;font-size:12.5px;border-left:1px solid rgba(26,28,8,.25);padding-left:10px}
@keyframes ub-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.8)}}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
