*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#1a1a18;--paper:#f5f2eb;--surface:#fffef9;--muted:#888780;
  --border:rgba(0,0,0,0.12);--border-strong:rgba(0,0,0,0.22);
  --green:#3B6D11;--green-bg:#EAF3DE;--green-text:#27500A;
  --amber:#854F0B;--amber-bg:#FAEEDA;--amber-text:#633806;
  --red:#A32D2D;--red-bg:#FCEBEB;--red-text:#791F1F;
  --blue:#185FA5;--blue-bg:#E6F1FB;--blue-text:#0C447C;
  --purple:#534AB7;--purple-bg:#EEEDFE;--purple-text:#3C3489;
}
body.dark{
  --ink:#e8e4dc;--paper:#1a1917;--surface:#222120;--muted:#9b988f;
  --border:rgba(255,255,255,0.09);--border-strong:rgba(255,255,255,0.18);
  --green:#6aaa2a;--green-bg:#1e2e10;--green-text:#8dc957;
  --amber:#d4872a;--amber-bg:#2e1f08;--amber-text:#e8a84a;
  --red:#d95555;--red-bg:#2e1010;--red-text:#e87777;
  --blue:#4a9de8;--blue-bg:#0d1e30;--blue-text:#6db3f2;
  --purple:#8b82e8;--purple-bg:#1a1630;--purple-text:#a89ff2;
}
body{font-family:'IBM Plex Mono',monospace;background:var(--paper);color:var(--ink);font-size:15px;min-height:100vh;-webkit-text-size-adjust:100%}
.container{max-width:1100px;margin:0 auto;padding:0 1.25rem 4rem}
h1{font-family:Fraunces,serif;font-weight:600;font-size:26px;letter-spacing:-0.5px}
h2{font-family:Fraunces,serif;font-weight:600;font-size:19px;letter-spacing:-0.3px}

/* ── Topbar ─────────────────────────────────────────────── */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 0 0.4rem}
.brand{font-family:Fraunces,serif;font-weight:600;font-size:21px;letter-spacing:-0.3px;display:flex;align-items:center;gap:10px}
.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--green)}
.topbar-right{display:flex;gap:8px;align-items:center}
.role-tag{font-family:'IBM Plex Mono',monospace;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:0.5px;color:var(--muted);padding:6px 10px;border:0.5px solid var(--border-strong);border-radius:8px}
.role-tag:empty{display:none}
.icon-btn{font-size:18px;width:42px;height:42px;border:0.5px solid var(--border-strong);background:var(--surface);color:var(--ink);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.icon-btn:active{background:rgba(0,0,0,0.06)}

/* ── Tabs (touch) ───────────────────────────────────────── */
.tabs-nav{display:flex;gap:6px;flex-wrap:wrap;padding:0.5rem 0 0}
.tab-btn{font-family:'IBM Plex Mono',monospace;font-size:14px;padding:12px 20px;border:0.5px solid var(--border-strong);background:var(--surface);color:var(--muted);cursor:pointer;border-radius:10px;transition:all 0.12s;font-weight:500;min-height:48px}
.tab-btn.active{background:var(--ink);color:var(--surface);border-color:var(--ink)}
.tab-btn:not(.active):active{background:rgba(0,0,0,0.06)}
.tab-panel{display:none;margin-top:1rem}
.tab-panel.active{display:block}

/* ── Cards / paneles ────────────────────────────────────── */
.card{background:var(--surface);border:0.5px solid var(--border-strong);border-radius:14px;padding:1.25rem;margin-bottom:1.1rem}
.card-title{font-family:Fraunces,serif;font-size:18px;font-weight:600;margin-bottom:0.9rem;display:flex;align-items:center;justify-content:space-between;gap:10px}

/* ── Formularios (grandes para dedo) ────────────────────── */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0.85rem}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
label{font-size:12px;text-transform:uppercase;letter-spacing:0.5px;color:var(--muted);font-weight:500}
input,select,textarea{font-family:'IBM Plex Mono',monospace;font-size:16px;padding:12px 14px;border:0.5px solid var(--border-strong);border-radius:10px;background:var(--paper);color:var(--ink);outline:none;width:100%;min-height:50px}
input:focus,select:focus,textarea:focus{border-color:var(--ink)}
textarea{min-height:70px;resize:vertical}
select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%23888' fill='none' stroke-width='1.5'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}

/* ── Botones ────────────────────────────────────────────── */
.btn{font-family:'IBM Plex Mono',monospace;font-size:15px;padding:13px 22px;border:0.5px solid var(--border-strong);background:var(--surface);color:var(--ink);border-radius:10px;cursor:pointer;transition:all 0.12s;font-weight:500;min-height:50px;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn:active{background:rgba(0,0,0,0.06)}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-primary:active{background:#333}
.btn-block{width:100%}
.btn-lg{font-size:17px;padding:16px 24px;min-height:58px}
.btn-ghost{background:transparent}
.btn-danger{color:var(--red-text);border-color:var(--red-bg);background:var(--red-bg)}

/* ── Stats / KPIs ───────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:0.8rem;margin-bottom:1.1rem}
.stat{background:var(--surface);border:0.5px solid var(--border-strong);border-radius:14px;padding:1.1rem 1.2rem}
.stat-label{font-size:12px;color:var(--muted);letter-spacing:0.4px;text-transform:uppercase;margin-bottom:8px}
.stat-val{font-size:28px;font-weight:600;font-family:Fraunces,serif;line-height:1.1}
.stat-sub{font-size:12px;color:var(--muted);margin-top:4px}
.stat-val.green{color:var(--green)}
.stat-val.amber{color:var(--amber)}
.stat-val.blue{color:var(--blue)}

/* ── Segmented control ──────────────────────────────────── */
.segmented{display:inline-flex;gap:4px;background:var(--paper);border:0.5px solid var(--border-strong);border-radius:12px;padding:4px;flex-wrap:wrap}
.seg-btn{font-family:'IBM Plex Mono',monospace;font-size:14px;padding:10px 18px;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:9px;font-weight:500;min-height:42px}
.seg-btn.active{background:var(--ink);color:var(--surface)}

/* ── Listas (cards de filas, touch) ─────────────────────── */
.row-list{display:flex;flex-direction:column;gap:8px}
.row-item{background:var(--surface);border:0.5px solid var(--border);border-radius:12px;padding:13px 15px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.row-main{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.row-title{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.row-meta{font-size:13px;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap}
.row-qty{font-family:Fraunces,serif;font-size:18px;font-weight:600;white-space:nowrap;text-align:right}
.row-qty .sub{font-size:12px;color:var(--muted);font-family:'IBM Plex Mono',monospace;font-weight:400}
.row-actions{display:flex;gap:6px}
.mini-btn{font-size:13px;padding:8px 12px;border:0.5px solid var(--border);border-radius:8px;background:transparent;cursor:pointer;font-family:'IBM Plex Mono',monospace;color:var(--muted);min-height:40px}
.mini-btn:active{background:rgba(0,0,0,0.05)}
.mini-btn.danger{color:var(--red-text)}

/* ── Lista de selección de partidas (envío) ─────────────── */
.pick-list{display:flex;flex-direction:column;gap:8px;max-height:55vh;overflow-y:auto}
.pick-item{display:flex;align-items:center;gap:12px;background:var(--paper);border:0.5px solid var(--border-strong);border-radius:12px;padding:12px 14px;cursor:pointer;transition:background 0.12s}
.pick-item:active{background:rgba(0,0,0,0.04)}
.pick-item:has(.env-pick:checked){border-color:var(--ink);background:var(--surface);box-shadow:inset 0 0 0 1px var(--ink)}
.pick-item input[type=checkbox]{width:26px;height:26px;min-height:26px;flex-shrink:0;accent-color:var(--green);margin:0}
.pick-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.pick-title{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pick-meta{font-size:13px;color:var(--muted)}
.pick-qty{font-family:Fraunces,serif;font-size:17px;font-weight:600;text-align:right;white-space:nowrap}
.pick-qty .sub{font-size:12px;color:var(--muted);font-family:'IBM Plex Mono',monospace;font-weight:400}

/* ── Badges ─────────────────────────────────────────────── */
.badge{display:inline-block;font-size:12px;padding:3px 11px;border-radius:20px;font-weight:600;letter-spacing:0.2px;white-space:nowrap}
.badge-pendiente{background:var(--amber-bg);color:var(--amber-text)}
.badge-recibido{background:var(--green-bg);color:var(--green-text)}
.badge-envio{background:var(--blue-bg);color:var(--blue-text)}
.badge-recepcion{background:var(--green-bg);color:var(--green-text)}
.badge-proveedor{background:var(--blue-bg);color:var(--blue-text)}
.badge-tintoreria{background:var(--purple-bg);color:var(--purple-text)}
.badge-off{background:var(--border);color:var(--muted)}

/* ── Tabla stock ────────────────────────────────────────── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead tr{border-bottom:1px solid var(--border-strong)}
th{font-size:12px;text-transform:uppercase;letter-spacing:0.4px;color:var(--muted);padding:11px 12px;text-align:left;font-weight:500}
td{padding:13px 12px;border-bottom:0.5px solid var(--border)}
td.num{text-align:right;font-family:Fraunces,serif;font-weight:600;font-size:16px;white-space:nowrap}
tr:last-child td{border-bottom:none}

td.num .cell-sub{font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:400;color:var(--muted);margin-top:2px}
.text-muted{color:var(--muted)}

/* Grupos por tintorería */
.tint-grupo{margin-bottom:1.1rem}
.tint-grupo:last-child{margin-bottom:0}
.tint-grupo-head{display:flex;justify-content:space-between;align-items:baseline;padding:6px 2px 10px;border-bottom:1px solid var(--border-strong);margin-bottom:10px}
.tint-grupo-head span:first-child{font-family:Fraunces,serif;font-weight:600;font-size:16px}
.tint-grupo-total{font-family:Fraunces,serif;font-weight:600;font-size:16px;color:var(--amber)}

.empty{text-align:center;padding:2.5rem 1rem;color:var(--muted);font-size:14px}
.section-label{font-size:12px;text-transform:uppercase;letter-spacing:0.5px;color:var(--muted);margin:1.2rem 0 0.6rem;font-weight:600}

/* ── Toast ──────────────────────────────────────────────── */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--ink);color:var(--surface);padding:14px 24px;border-radius:10px;font-size:15px;z-index:10000;transition:transform 0.25s;max-width:90vw;text-align:center}
#toast.show{transform:translateX(-50%) translateY(0)}

/* ── Overlays / modales ─────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:9000;display:none;align-items:center;justify-content:center;padding:1rem}
.overlay.open{display:flex}
.modal{background:var(--surface);border-radius:16px;padding:1.5rem;max-width:440px;width:100%}
.modal-title{font-family:Fraunces,serif;font-size:20px;font-weight:600;margin-bottom:1rem}
.modal-actions{display:flex;gap:10px;margin-top:1.3rem}
.modal-actions .btn{flex:1}

/* ── Cartel código de partida ───────────────────────────── */
.codigo-modal{max-width:560px;text-align:center;padding:2.2rem 1.8rem}
.codigo-label{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:1rem}
.codigo-big{font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:clamp(36px,11vw,72px);letter-spacing:2px;line-height:1.1;color:var(--ink);background:var(--paper);border:2px dashed var(--border-strong);border-radius:14px;padding:1.4rem 1rem;word-break:break-all}
.codigo-hint{font-size:14px;color:var(--muted);margin-top:1rem}
.codigo-chip{display:inline-block;font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:13px;background:var(--ink);color:var(--surface);padding:3px 10px;border-radius:7px;letter-spacing:0.5px;cursor:pointer}

/* Cartel de código a pantalla completa: fondo verde claro, código verde oscuro */
#codigoOverlay{background:var(--green-bg);padding:0}
#codigoOverlay .codigo-modal{background:transparent;width:100%;max-width:none;min-height:100vh;min-height:100dvh;border-radius:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.6rem;padding:2rem}
#codigoOverlay .codigo-label{color:var(--green);font-size:16px;margin:0}
#codigoOverlay .codigo-big{color:var(--green-text);background:transparent;border:none;border-radius:0;padding:0;margin:0;font-size:120px;letter-spacing:2px;line-height:1;white-space:nowrap}
#codigoOverlay .codigo-hint{color:var(--green);font-size:16px;margin:0}
#codigoOverlay .modal-actions{margin-top:1rem;display:flex;gap:12px}

/* ── Login ──────────────────────────────────────────────── */
#loginScreen{position:fixed;inset:0;background:var(--paper);z-index:11000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem}
.login-box{width:100%;max-width:360px;text-align:center}
.login-brand{font-family:Fraunces,serif;font-size:30px;font-weight:600;margin-bottom:6px}
.login-sub{color:var(--muted);font-size:14px;margin-bottom:2rem}
.pin-display{font-family:Fraunces,serif;font-size:34px;letter-spacing:14px;height:50px;margin-bottom:1.2rem;color:var(--ink)}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pin-key{font-family:'IBM Plex Mono',monospace;font-size:24px;padding:18px;border:0.5px solid var(--border-strong);background:var(--surface);border-radius:14px;cursor:pointer;color:var(--ink);min-height:64px}
.pin-key:active{background:rgba(0,0,0,0.08)}
.login-error{color:var(--red-text);font-size:13px;height:18px;margin-top:12px}

/* ── Responsive ─────────────────────────────────────────── */
@media(max-width:640px){
  .form-grid{grid-template-columns:1fr}
  .container{padding:0 0.9rem 4rem}
  .row-item{flex-wrap:wrap}
}
.hidden{display:none!important}
