:root {
  --bg: #09090b;
  --bg-subtle: #0f0f13;
  --s1: #131318;
  --s2: #1a1a22;
  --s3: #23232e;
  --s4: #2c2c3a;
  --border: rgba(255,255,255,0.06);
  --border-h: rgba(255,255,255,0.12);
  --border-a: rgba(255,255,255,0.18);
  --accent: #f59e0b;
  --accent-h: #fbbf24;
  --accent-glow: rgba(245,158,11,0.15);
  --accent-gs: rgba(245,158,11,0.25);
  --text: #fafafa;
  --text2: #a1a1aa;
  --text3: #52525b;
  --green: #22c55e;
  --green-g: rgba(34,197,94,0.15);
  --red: #ef4444;
  --red-g: rgba(239,68,68,0.15);
  --blue: #3b82f6;
  --blue-g: rgba(59,130,246,0.15);
  --orange: #f97316;
  --orange-g: rgba(249,115,22,0.15);
  --r-sm: 8px; --r: 12px; --r-lg: 16px; --r-xl: 20px; --r-full: 9999px;
  --shadow: 0 4px 16px rgba(0,0,0,0.3);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.4);
  --tr: 0.2s cubic-bezier(0.4,0,0.2,1);
  --font: 'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;overscroll-behavior:none;-webkit-font-smoothing:antialiased}
::selection{background:var(--accent);color:#000}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--s4);border-radius:3px}

/* AUTH */
#auth-wrap{position:fixed;inset:0;background:var(--bg);z-index:999;display:flex;align-items:center;justify-content:center;padding:20px}
.abox{position:relative;background:rgba(19,19,24,0.9);border:1px solid var(--border);border-radius:var(--r-xl);padding:44px 32px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}
.alogo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:6px}
.alogo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--accent),#d97706);border-radius:var(--r);display:flex;align-items:center;justify-content:center}
.alogo-icon svg{width:22px;height:22px}
.alogo-text{font-weight:800;font-size:28px;letter-spacing:-0.5px;color:var(--text)}
.alogo-text em{font-style:normal;color:var(--accent)}
.asub{font-size:13px;color:var(--text3);text-align:center;margin-bottom:32px;font-weight:500}
.aerr{font-size:12px;color:var(--red);min-height:18px;text-align:center;margin-top:10px;font-weight:500}

/* APP */
#app{display:none;flex-direction:column;height:100dvh}
#topbar{background:rgba(13,13,17,0.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;position:sticky;top:0;z-index:100;gap:12px}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.lmark{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),#d97706);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.lmark svg{width:16px;height:16px}
#lname{font-weight:700;font-size:16px;letter-spacing:-0.3px}
#lname em{font-style:normal;color:var(--accent)}
.bytag{font-size:10px;color:var(--text3);white-space:nowrap;font-weight:500}
#sync{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;transition:all var(--tr)}
#sync.s{background:var(--accent);animation:pulse .8s infinite}
#sync.e{background:var(--red)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* NAV */
#dnav{display:flex;gap:2px;background:var(--s1);border-radius:var(--r);padding:3px;border:1px solid var(--border)}
.dn{background:none;border:none;color:var(--text3);font-family:var(--font);font-size:12px;font-weight:500;padding:7px 14px;border-radius:9px;cursor:pointer;transition:all var(--tr);white-space:nowrap}
.dn:hover{color:var(--text2);background:rgba(255,255,255,0.03)}
.dn.on{background:var(--accent);color:#000;font-weight:600}
.ubtn{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text3);font-family:var(--font);font-size:12px;font-weight:500;padding:7px 14px;cursor:pointer;transition:all var(--tr);white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:6px}
.ubtn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}
.ubtn:hover{border-color:var(--red);color:var(--red);background:var(--red-g)}

/* MOBILE NAV */
#mnav{display:none;grid-template-columns:repeat(5,1fr);background:rgba(13,13,17,0.92);backdrop-filter:blur(20px);border-top:1px solid var(--border);height:64px;flex-shrink:0;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0)}
.mn{background:none;border:none;color:var(--text3);font-family:var(--font);font-size:10px;font-weight:500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:all var(--tr);padding:5px 0;position:relative}
.mn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.mn.on{color:var(--accent)}
.mn.on::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:24px;height:2px;background:var(--accent);border-radius:0 0 2px 2px}

/* CONTENT */
#content{flex:1;overflow-y:auto;padding:24px 20px 32px;scroll-behavior:smooth}
.sec{display:none;max-width:960px;margin:0 auto}
.sec.on{display:block}

/* CARDS */
.card{background:var(--s1);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;margin-bottom:16px;transition:border-color var(--tr)}
.card:hover{border-color:var(--border-h)}
.ctitle{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);margin-bottom:20px;display:flex;align-items:center;gap:8px}
.ctitle svg{width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* FORM */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;color:var(--text3);transition:color var(--tr)}
.field:focus-within label{color:var(--accent)}
input,select,textarea{background:var(--s2);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-family:var(--font);font-size:13px;font-weight:500;padding:10px 14px;outline:none;transition:all var(--tr);width:100%}
input:hover,select:hover,textarea:hover{border-color:var(--border-h)}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:var(--s3)}
input::placeholder{color:var(--text3);font-weight:400}
select option{background:var(--s2)}
textarea{resize:vertical;min-height:70px}
.trow{display:flex;gap:8px;align-items:flex-end}
.trow>*{flex:1}
.tsep{color:var(--text3);font-size:22px;font-weight:300;padding-bottom:8px;flex:0}
.divider{height:1px;background:var(--border);margin:16px 0}
.hint{font-size:12px;color:var(--text3);margin-top:4px;line-height:1.6}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--r-sm);font-family:var(--font);font-size:13px;font-weight:600;padding:10px 20px;cursor:pointer;transition:all var(--tr);white-space:nowrap}
.btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.by{background:linear-gradient(135deg,var(--accent),#d97706);color:#000;box-shadow:0 2px 12px var(--accent-glow)}
.by:hover{box-shadow:0 4px 20px var(--accent-gs);transform:translateY(-1px)}
.by:active{transform:translateY(0) scale(.98)}
.bg{background:linear-gradient(135deg,var(--green),#16a34a);color:#000;box-shadow:0 2px 12px var(--green-g)}
.bg:hover{box-shadow:0 4px 20px rgba(34,197,94,0.25);transform:translateY(-1px)}
.bg:active{transform:translateY(0) scale(.98)}
.bs{background:var(--s2);color:var(--text);border:1px solid var(--border)}
.bs:hover{border-color:var(--border-a);background:var(--s3)}
.br{background:transparent;color:var(--red);border:1px solid rgba(239,68,68,0.3)}
.br:hover{background:var(--red-g);border-color:var(--red)}
.brow{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}

/* RESULTS */
.rbox{background:var(--s1);border:1px solid rgba(245,158,11,0.2);border-radius:var(--r-lg);padding:24px;margin-top:20px;position:relative;overflow:hidden}
.rbox::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),#d97706,var(--accent))}
.rrow{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.rrow:last-child{border:none}
.rl{color:var(--text3);font-weight:500}
.rbig{font-size:28px;font-weight:800;color:var(--accent);letter-spacing:-0.5px}
.rbig-g{font-size:28px;font-weight:800;color:var(--green);letter-spacing:-0.5px}
.rmain{display:flex;justify-content:space-between;align-items:center;padding:14px 0 6px}
.rmain .rl{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text)}
.fbox{background:var(--s2);border-left:3px solid var(--accent);border-radius:0 var(--r-sm) var(--r-sm) 0;padding:14px 16px;margin-top:16px;font-size:12px;color:var(--text3);line-height:1.9}
.fbox strong{color:var(--accent);font-weight:600}

/* PRINTER GRID */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-bottom:14px}
.pc{background:var(--s2);border:1px solid var(--border);border-radius:var(--r);padding:18px;transition:all var(--tr)}
.pc:hover{border-color:var(--border-h);transform:translateY(-2px);box-shadow:var(--shadow)}
.pc-name{font-weight:700;font-size:15px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.pc-name svg{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:2}
.pc-stat{font-size:12px;color:var(--text3);display:flex;justify-content:space-between;padding:3px 0;font-weight:500}
.pc-stat span{color:var(--text)}
.pc-actions{display:flex;gap:8px;margin-top:14px}
.pc-edit{flex:1;background:var(--s3);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-family:var(--font);font-size:12px;font-weight:500;padding:7px;cursor:pointer;transition:all var(--tr);text-align:center}
.pc-edit:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.pc-del{background:transparent;border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text3);font-size:12px;padding:7px 12px;cursor:pointer;transition:all var(--tr);font-family:var(--font)}
.pc-del:hover{border-color:var(--red);color:var(--red);background:var(--red-g)}

/* TABLES */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text3);padding:10px 12px;border-bottom:1px solid var(--border)}
.tbl td{padding:8px 12px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.tbl tr:last-child td{border:none}
.tbl input{padding:6px 10px;font-size:12px}
.tbl tr:hover{background:rgba(255,255,255,0.02)}
.cdot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;vertical-align:middle}
.qtbl{width:100%;border-collapse:collapse}
.qtbl th{text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text3);padding:10px 12px;background:var(--s2);border-bottom:1px solid var(--border)}
.qtbl td{padding:8px 12px;border-bottom:1px solid var(--border);font-size:13px}
.qtbl input{padding:6px 10px;font-size:12px}
.qtbl tr:hover{background:rgba(255,255,255,0.02)}

/* TOTALS */
.totbox{background:var(--s2);border-radius:var(--r);padding:18px 22px;margin-top:16px;border:1px solid var(--border)}
.tr2{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;align-items:center;font-weight:500}
.tr2.grand{border-top:2px solid var(--accent);margin-top:10px;padding-top:12px;font-size:20px;font-weight:800;color:var(--accent);letter-spacing:-0.3px}

/* HISTORIAL */
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.sbox{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:18px}
.slbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin-bottom:8px}
.sval{font-size:22px;font-weight:800;letter-spacing:-0.5px}
.sval.y{color:var(--accent)} .sval.g{color:var(--green)} .sval.o{color:var(--orange)}
.fbtns{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.fb{background:var(--s2);border:1px solid var(--border);border-radius:var(--r-full);color:var(--text3);font-family:var(--font);font-size:12px;font-weight:500;padding:6px 16px;cursor:pointer;transition:all var(--tr)}
.fb:hover{border-color:var(--border-h);color:var(--text2)}
.fb.on{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);font-weight:600}
.hempty{text-align:center;padding:56px 20px;color:var(--text3)}
.hempty svg{width:48px;height:48px;stroke:var(--text3);fill:none;stroke-width:1.2;margin-bottom:12px;opacity:.5}
.hempty span{display:block;font-size:14px;margin-top:8px}

/* DOC CARDS */
.dcard{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;margin-bottom:10px;transition:all var(--tr)}
.dcard:hover{border-color:var(--border-h)}
.dnum{font-weight:700;font-size:16px;letter-spacing:-0.3px}
.dmeta{font-size:12px;color:var(--text3);margin-top:4px}
.dcli{font-size:14px;margin-top:4px;font-weight:600}
.dtotal{font-weight:800;font-size:20px;color:var(--accent);white-space:nowrap;letter-spacing:-0.3px}
.eflow{display:flex;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;margin-top:14px}
.efb{flex:1;background:none;border:none;border-right:1px solid var(--border);color:var(--text3);font-family:var(--font);font-size:10px;font-weight:500;padding:8px 4px;cursor:pointer;transition:all var(--tr);text-align:center}
.efb:last-child{border-right:none}
.efb:hover{background:rgba(255,255,255,0.03);color:var(--text2)}
.efb.ac{background:var(--blue-g);color:var(--blue);font-weight:600}
.efb.af{background:var(--accent-glow);color:var(--accent);font-weight:600}
.efb.ap{background:var(--green-g);color:var(--green);font-weight:600}
.efb.ax{background:var(--red-g);color:var(--red);font-weight:600}
.ebadge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:var(--r-full)}
.ebc{background:var(--blue-g);color:var(--blue)}
.ebf{background:var(--accent-glow);color:var(--accent)}
.ebp{background:var(--green-g);color:var(--green)}
.ebx{background:var(--red-g);color:var(--red)}
.dbtns{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.dbtn{background:var(--s2);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text3);font-family:var(--font);font-size:12px;font-weight:500;padding:6px 14px;cursor:pointer;transition:all var(--tr)}
.dbtn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.dbtn.del:hover{border-color:var(--red);color:var(--red);background:var(--red-g)}

/* MODALS */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:500;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(8px)}
.overlay.on{display:flex}
.modal{background:var(--s1);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal h2{font-weight:700;font-size:18px;margin-bottom:20px;color:var(--text);letter-spacing:-0.3px}
.mfields{display:flex;flex-direction:column;gap:14px}
.mbtns{display:flex;gap:10px;margin-top:22px}
#cbox{max-width:360px;text-align:center}
#cbox h3{font-size:18px;margin-bottom:12px;color:var(--red);font-weight:700}
#cbox p{font-size:13px;color:var(--text3);margin-bottom:20px;line-height:1.7}

/* TOAST */
#toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--s1);border:1px solid var(--green);color:var(--green);padding:12px 24px;border-radius:var(--r-full);font-size:13px;font-weight:600;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.16,1,.3,1);z-index:999;white-space:nowrap;box-shadow:var(--shadow-lg)}
#toast.on{opacity:1;transform:translateX(-50%) translateY(0)}


/* EXTRAS */
.extra-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.extra-row input[type="text"]{flex:1;min-width:0}
.extra-row input[type="number"]{width:110px;flex-shrink:0}
.extra-del{background:transparent;border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text3);font-size:16px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--tr);flex-shrink:0;font-family:var(--font);padding:0}
.extra-del:hover{border-color:var(--red);color:var(--red);background:var(--red-g)}
.r-final-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;font-weight:500}
.r-final-row .r-final-label{color:var(--text3)}
.r-final-row .r-final-val{color:var(--text);font-weight:600}
.r-final-row.extra-item .r-final-label{color:var(--orange)}
.r-final-row.extra-item .r-final-val{color:var(--orange)}

/* ITEM ACTIONS */
.item-actions{display:flex;gap:6px}
.item-btn{background:var(--s3);border:1px solid var(--border);border-radius:6px;color:var(--text3);font-family:var(--font);font-size:11px;font-weight:500;padding:4px 10px;cursor:pointer;transition:all var(--tr);white-space:nowrap}
.item-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.item-btn.del:hover{border-color:var(--red);color:var(--red);background:var(--red-g)}

/* COMBINE */
.cb-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--s2);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:all var(--tr);user-select:none}
.cb-item:hover{border-color:var(--border-h)}
.cb-item.selected{border-color:var(--accent);background:var(--accent-glow)}
.cb-check{width:18px;height:18px;border:2px solid var(--border);border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--tr)}
.cb-item.selected .cb-check{background:var(--accent);border-color:var(--accent)}
.cb-item.selected .cb-check::after{content:'';width:5px;height:9px;border:solid #000;border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px)}
.cb-info{flex:1;min-width:0}
.cb-info-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cb-info-meta{font-size:11px;color:var(--text3);margin-top:2px}
.cb-info-price{font-weight:700;color:var(--accent);flex-shrink:0;font-size:14px}
.cb-bd-row{display:flex;justify-content:space-between;padding:4px 0;font-size:12px}
.cb-bd-row span:first-child{color:var(--text3)}
.cb-bd-row span:last-child{color:var(--text);font-weight:500}
.item-desglose{margin-top:4px;padding:6px 10px;background:var(--s2);border-radius:6px;font-size:11px;color:var(--text3);line-height:1.6;border:1px solid var(--border)}
.item-desglose strong{color:var(--accent);font-weight:600}

/* MISC */
.info-banner{background:var(--accent-glow);border:1px solid rgba(245,158,11,0.15);border-radius:var(--r-sm);padding:12px 16px;margin-bottom:14px;font-size:12px;color:var(--text2);line-height:1.7}
.info-banner strong{color:var(--accent);font-weight:600}
.total-piezas-box{background:var(--s3);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 14px;font-size:14px;font-weight:700;color:var(--green)}

/* RESPONSIVE */
@media(max-width:768px){
  .g2,.g3{grid-template-columns:1fr}
  #dnav{display:none}
  #mnav{display:grid}
  #content{padding:16px 14px 12px}
  #toast{bottom:72px}
  .sgrid{grid-template-columns:1fr 1fr}
  .bytag{display:none}
  .card{padding:20px 16px}
  .rbox{padding:20px 16px}
  .abox{padding:36px 24px}
  .pgrid{grid-template-columns:1fr}
  .sbox{padding:14px}
  .sval{font-size:18px}
  .rbig,.rbig-g{font-size:24px}
  .dtotal{font-size:18px}
  .tr2.grand{font-size:18px}
  .ubtn span{display:none}
}
@media(min-width:769px){#mnav{display:none}}
@media(max-width:400px){.sgrid{grid-template-columns:1fr}}
