/* ═══════════════════════════════════════════════
   DESIGN TOKENS — Bakery palette
   ═══════════════════════════════════════════════ */
:root{
  --bg:#F5EDE0;--surface:#FFFDF6;--border:#E6D9C6;--border-s:#D4C4AC;
  --txt:#3E2723;--txt-s:#6D534E;--txt-m:#9E8A82;
  --brand:#674744;--brand-soft:#FFF0CF;--brand-h:#523835;--brand-light:#F0DFC8;--brand-dark:#4A302D;
  --ok:#5A8C5E;--ok-bg:#EAF3EA;--warn:#8B6530;--warn-bg:#FFF5E0;
  --err:#B33A2A;--err-bg:#FCEAE7;--info:#5E7D99;--info-bg:#E8EFF5;
  --edit:#674744;--edit-bg:#FFF0CF;--edit-border:rgba(103,71,68,.25);
  --diario:#674744;--diario-bg:#FFF0CF;--fijo:#6B7B8E;--fijo-bg:#E8EEF3;
  --fijo-mod:#7B6E5E;--fijo-mod-bg:#F0EBE3;
  --side-w:68px;--hdr-h:56px;--r:10px;--rs:6px;--rl:14px;--touch:48px;
  --ease:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box}
input,button,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}
html,body{margin:0;padding:0;font-family:'DM Sans',-apple-system,sans-serif;font-size:17px;
  color:var(--txt);background:var(--bg);overflow:hidden;height:100dvh;
  -webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased}

/* ═══════ UTILITIES (Bootstrap replacement) ═══════ */
.d-flex{display:flex}.d-block{display:block}
.align-items-center{align-items:center}.align-items-stretch{align-items:stretch}
.justify-content-center{justify-content:center}
.gap-2{gap:.5rem}.gap-3{gap:1rem}
.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}
.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}
.me-2{margin-right:.5rem}
.p-2{padding:.5rem}
.w-100{width:100%}

/* ═══════ LOGIN ═══════ */
.login-screen{display:flex;align-items:center;justify-content:center;min-height:100dvh;
  background:var(--bg);padding:20px}
.login-card{width:100%;max-width:380px}
.login-header{background:var(--brand-dark);color:#fff;padding:30px 24px 24px;border-radius:var(--rl) var(--rl) 0 0;
  text-align:center}
.login-logo{width:64px;height:64px;border-radius:12px;margin-bottom:12px}
.login-title{font-size:22px;font-weight:700;margin:0}
.login-subtitle{font-size:13px;opacity:.7;margin:4px 0 0}
.login-body{background:var(--surface);padding:24px;border-radius:0 0 var(--rl) var(--rl);
  border:1px solid var(--border);border-top:0}
.login-field{margin-bottom:16px}
.login-field .inp{height:44px;font-size:15px}
.login-error{font-size:13px;font-weight:600;color:var(--err);min-height:20px;margin-bottom:8px;text-align:center}

/* ═══════ LAYOUT ═══════ */
.app{display:flex;height:100dvh}
.side{width:var(--side-w);min-width:var(--side-w);background:#4A302D;display:flex;
  flex-direction:column;align-items:center;padding:10px 0 14px;gap:2px;z-index:100}
.side-logo{width:44px;height:44px;border-radius:10px;overflow:hidden;
  margin-bottom:14px;flex-shrink:0}
.side-logo img{width:100%;height:100%;object-fit:cover}
.side-nav{display:flex;flex-direction:column;gap:2px;width:100%;padding:0 8px;flex:1}
.nav-i{display:flex;align-items:center;justify-content:center;height:var(--touch);
  border-radius:var(--r);color:rgba(255,255,255,.4);cursor:pointer;transition:all .15s var(--ease);
  text-decoration:none;position:relative;font-size:19px}
.nav-i:hover,.nav-i:active{color:rgba(255,255,255,.8);background:rgba(255,255,255,.07)}
.nav-i.on{color:#fff;background:rgba(255,255,255,.12)}
.nav-i.on::before{content:'';position:absolute;left:-8px;top:50%;transform:translateY(-50%);
  width:3px;height:22px;background:var(--brand);border-radius:0 3px 3px 0}
.nav-sp{flex:1}
.nav-i.nav-out{color:rgba(255,255,255,.3)}
.nav-i.nav-out:hover{color:var(--err);background:rgba(192,57,43,.08)}

.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.top{height:var(--hdr-h);min-height:var(--hdr-h);background:var(--surface);
  border-bottom:2.5px solid var(--brand);display:flex;align-items:center;padding:0 20px;gap:14px;
  box-shadow:0 1px 4px rgba(0,0,0,.04)}
.top-t{font-size:20px;font-weight:700;color:var(--txt);letter-spacing:-.2px}.top-sp{flex:1}
.top-acts{display:flex;align-items:center;gap:8px}
.page{flex:1;overflow-y:auto;overflow-x:hidden;padding:14px 18px 20px;-webkit-overflow-scrolling:touch}
.view{display:none}.view.on{display:block}

/* ═══════ BUTTONS ═══════ */
.bt{height:var(--touch);min-height:var(--touch);padding:0 18px;border-radius:var(--r);
  font-weight:600;font-size:16px;display:inline-flex;align-items:center;gap:7px;
  border:none;cursor:pointer;transition:all .12s var(--ease);white-space:nowrap}
.bt:active{transform:scale(.97)}
.bt-brand{background:var(--brand);color:#fff;font-weight:700}.bt-brand:hover{background:var(--brand-h);color:#fff}
.bt-soft{background:var(--border);color:var(--txt)}.bt-soft:hover{background:var(--border-s);color:var(--txt)}
.bt-outline{background:0 0;color:var(--txt);border:1.5px solid var(--border-s)}
.bt-outline:hover{background:var(--bg);color:var(--txt)}
.bt-ghost{background:0 0;color:var(--txt-s);padding:0 10px}.bt-ghost:hover{color:var(--txt);background:var(--bg)}
.bt-err{background:var(--err-bg);color:var(--err)}.bt-err:hover{background:#f9d5d1;color:var(--err)}
.bt-ok{background:var(--ok-bg);color:var(--ok)}
.bt-icon{width:var(--touch);padding:0;justify-content:center;border:1.5px solid var(--border);
  background:var(--surface);color:var(--txt-s);font-size:17px;border-radius:var(--r)}
.bt-icon:hover{border-color:var(--border-s);color:var(--txt)}
.bd{height:var(--touch);min-height:var(--touch);padding:0 14px;border-radius:var(--r);font-weight:600;
  font-size:16px;border:1.5px solid var(--border);background:var(--surface);color:var(--txt-s);
  cursor:pointer;transition:all .12s var(--ease)}
.bd:hover{border-color:var(--brand);color:var(--brand)}
.bd.on{background:var(--brand);border-color:var(--brand);color:#fff}

/* Yesterday pending badge */
.badge-pend{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;
  border-radius:9px;background:var(--brand);color:#fff;font-size:12px;font-weight:700;
  display:flex;align-items:center;justify-content:center;padding:0 4px;
  box-shadow:0 1px 4px rgba(0,0,0,.15);pointer-events:none}

/* ═══════ INPUTS ═══════ */
.inp{height:var(--touch);padding:0 12px;border:1.5px solid var(--border-s);border-radius:var(--r);
  font-size:16px;color:var(--txt);background:var(--surface);transition:border .12s,box-shadow .12s;width:100%}
.inp:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px rgba(103,71,68,.12)}
.inp::placeholder{color:var(--txt-m)}
textarea.inp{height:auto;min-height:72px;padding:10px 12px;resize:vertical}
.inp-label{display:block;font-size:15px;font-weight:600;color:var(--txt-s);margin-bottom:5px;
  text-transform:uppercase;letter-spacing:.4px}
.date-inp{height:38px;padding:0 12px;border:1.5px solid var(--border);border-radius:var(--r);
  font-size:16px;font-weight:600;color:var(--txt);background:var(--surface);cursor:pointer;text-align:center;
  width:100%;box-sizing:border-box}
.date-inp:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px rgba(139,105,20,.1)}

/* ═══════ FLATPICKR THEME ═══════ */
.flatpickr-calendar{background:var(--surface);border:1.5px solid var(--border-s);border-radius:var(--rl);
  box-shadow:0 8px 24px rgba(74,48,45,.12);font-family:'DM Sans',-apple-system,sans-serif}
.flatpickr-wrapper{position:relative;display:inline-block}
.flatpickr-wrapper .inp{width:100%;box-sizing:border-box}
/* In flex containers like forms, wrapper fills space */
.d-flex .flatpickr-wrapper,.form-grid .flatpickr-wrapper{flex:1}
/* In modals, wrapper fills full width */
.mo-b .flatpickr-wrapper{display:block;width:100%}
/* In filter bars, wrapper stays compact */
.fbar .flatpickr-wrapper{flex:none}
.fbar .flatpickr-wrapper .date-inp{width:160px}
.flatpickr-calendar::before,.flatpickr-calendar::after{display:none}
.flatpickr-months{padding:0 4px;height:36px;align-items:center}
.flatpickr-months .flatpickr-month{height:36px}
.flatpickr-current-month{font-size:16px;font-weight:700;color:var(--txt);padding:0;height:36px;
  display:flex;align-items:center;justify-content:center}
.flatpickr-current-month .flatpickr-monthDropdown-months{font-size:16px;font-weight:700;color:var(--txt);
  background:transparent;border:none;appearance:none;-webkit-appearance:none;padding:0 4px}
.flatpickr-current-month input.cur-year{font-size:16px;font-weight:700;color:var(--txt);
  background:transparent;border:none;padding:0 4px}
.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{padding:6px;
  display:flex;align-items:center;justify-content:center;height:32px;width:32px;border-radius:var(--rs);
  transition:all .12s}
.flatpickr-months .flatpickr-prev-month:hover,.flatpickr-months .flatpickr-next-month:hover{
  background:var(--brand-soft)}
.flatpickr-months .flatpickr-prev-month svg,.flatpickr-months .flatpickr-next-month svg{
  fill:var(--txt-s);width:12px;height:12px}
.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{
  fill:var(--brand)}
span.flatpickr-weekday{color:var(--txt-m);font-size:13px;font-weight:700;text-transform:uppercase}
.flatpickr-innerContainer{padding-top:4px}
.dayContainer{padding:2px 0}
.flatpickr-day{color:var(--txt);font-size:15px;font-weight:500;border-radius:var(--rs);
  border:none;transition:all .1s}
.flatpickr-day:hover{background:var(--brand-soft);color:var(--brand);border:none}
.flatpickr-day.today{background:var(--bg);color:var(--brand);font-weight:700;border:none}
.flatpickr-day.today:hover{background:var(--brand-soft);color:var(--brand)}
.flatpickr-day.selected,.flatpickr-day.selected:hover{background:var(--brand);color:#fff;
  font-weight:700;border:none}
.flatpickr-day.today.selected{background:var(--brand);color:#fff}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{
  color:var(--txt-m);opacity:.4}
.flatpickr-day.prevMonthDay:hover,.flatpickr-day.nextMonthDay:hover{background:var(--bg)}
.numInputWrapper:hover{background:transparent}
.numInputWrapper span{border:none;opacity:.5}
.numInputWrapper span:hover{background:var(--brand-soft)}
.flatpickr-monthDropdown-months:hover{background:var(--brand-soft)!important}

/* ═══════ TIME PICKER ═══════ */
.time-pick{cursor:pointer;caret-color:transparent}
.tp-pop{position:absolute;z-index:1100;display:none;padding-top:4px}
.tp-pop.open{display:block}
.tp-body{background:var(--surface);border:1.5px solid var(--border-s);border-radius:var(--rl);
  box-shadow:0 8px 24px rgba(74,48,45,.12);padding:12px;display:flex;gap:12px;
  font-family:'DM Sans',-apple-system,sans-serif;width:400px}
.tp-col{display:flex;flex-direction:column}
.tp-col-h{flex:1;min-width:0}
.tp-col-m{width:150px;flex-shrink:0}
.tp-sep{width:1px;background:var(--border);margin:20px 0 0}
.tp-label{font-size:12px;font-weight:700;color:var(--txt-m);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.tp-grid-h{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;max-height:180px;overflow-y:auto;padding:1px}
.tp-grid-m{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.tp-btn{height:38px;border:1.5px solid var(--border);border-radius:var(--rs);background:var(--surface);
  color:var(--txt);font-size:16px;font-weight:600;cursor:pointer;transition:all .12s var(--ease);
  display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;user-select:none}
.tp-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.tp-btn:active{transform:scale(.94)}
.tp-btn.on{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ═══════ BADGES ═══════ */
.badge-t{display:inline-flex;align-items:center;padding:2px 7px;border-radius:20px;font-size:11px;
  font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.badge-d{background:var(--diario-bg);color:var(--diario);border:1px solid rgba(74,127,181,.2)}
.badge-f{background:var(--fijo-bg);color:var(--fijo);border:1px solid rgba(139,105,20,.2)}
.badge-fm{background:var(--fijo-mod-bg);color:var(--fijo-mod);border:1px solid rgba(199,127,27,.2)}
.badge-off{background:var(--err-bg);color:var(--err);border:1px solid rgba(192,57,43,.15)}

/* ═══════ ENCARGO CARD ═══════ */
.enc{background:var(--surface);border:1px solid var(--border-s);border-radius:var(--rl);
  padding:0;margin-bottom:10px;display:flex;align-items:stretch;
  transition:border-left-color .25s var(--ease),box-shadow .12s;
  border-left:4px solid var(--border-s);box-shadow:0 1px 3px rgba(74,48,45,.06);overflow:hidden}
.enc[data-tipo="diario"]{border-left-color:var(--diario)}
.enc[data-tipo="fijo"]{border-left-color:var(--brand)}
.enc:hover{box-shadow:0 3px 10px rgba(74,48,45,.1)}
.enc.enc-prep{border-left-color:var(--info)}
.enc.enc-done{border-left-color:var(--ok)}

/* Left: info — centered */
.enc-info{width:20%;min-width:130px;padding:12px 14px;display:flex;flex-direction:column;gap:4px;
  border-right:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:flex-start;position:relative}
.enc-info[onclick]{cursor:pointer}
.enc-info[onclick]:active .enc-cli{opacity:.7}
.enc-cli{font-weight:700;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.enc-cli-ph{font-size:11px;opacity:.35;margin-left:2px}
.enc-phone{position:absolute;left:0;right:0;top:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--brand-soft);border-radius:var(--r);z-index:2;font-size:15px;color:var(--brand);
  cursor:pointer;animation:phoneFade .15s var(--ease);gap:4px;line-height:1.3;font-weight:700}
.enc-phone i{font-size:14px}
.enc-phone:active{opacity:.7}
@keyframes phoneFade{from{opacity:0}to{opacity:1}}
.enc-time{color:var(--txt-m);font-size:15px;font-weight:500;white-space:nowrap}
.enc-cmt{font-size:14px;color:var(--txt-s);margin-top:2px;display:flex;align-items:center;gap:4px}
.enc-cmt i{font-size:11px;color:var(--txt-m)}

/* Center: articles grid 2 columns */
.enc-arts-grid{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:5px;padding:10px 12px;align-content:center}
.enc-days-row{grid-column:1/-1;padding-bottom:4px;border-bottom:1px solid var(--border);margin-bottom:2px}

/* Right: actions */
.fijo-side-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0;padding:10px 12px;
  justify-content:center;align-items:center;border-left:1px solid var(--border)}

/* Status dots */
.st-row{display:flex;gap:3px}
.st{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:15px;cursor:pointer;transition:all .12s var(--ease);border:2px solid var(--border);
  background:var(--surface);color:var(--txt-m)}
.st:active{transform:scale(.88)}
.st.prep{border-color:var(--info);background:var(--info);color:#fff}
.st.done{border-color:var(--ok);background:var(--ok);color:#fff}

/* Dot feedback animations */
.st.st-pop{animation:stPop .3s var(--ease)}
@keyframes stPop{0%{transform:scale(1)}40%{transform:scale(1.12)}100%{transform:scale(1)}}
.st.st-shake{animation:stShake .4s var(--ease)}
@keyframes stShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-4px)}40%{transform:translateX(4px)}60%{transform:translateX(-3px)}80%{transform:translateX(2px)}}

/* Day dots / chips */
.dd{display:flex;gap:2px}
.dd span{width:28px;height:28px;border-radius:50%;font-size:12px;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;color:var(--txt-m);background:var(--bg)}
.fijo-days-side{display:flex;align-items:center;flex-shrink:0;padding:0 8px}
.fijo-days-side .dd{gap:4px}
.dd span.on{background:var(--brand);color:#fff}
.dc{display:flex;gap:5px}
.dc div{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);background:var(--surface);
  color:var(--txt-s);font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .12s var(--ease)}
.dc div:active{transform:scale(.92)}
.dc div.on{border-color:var(--brand);background:var(--brand);color:#fff}

/* Toggle */
.tgl{position:relative;width:48px;height:26px;background:var(--border-s);border-radius:13px;
  cursor:pointer;transition:background .2s var(--ease);flex-shrink:0}
.tgl::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;
  background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.12);transition:transform .2s var(--ease)}
.tgl.on{background:var(--brand)}
.tgl.on::after{transform:translateX(22px)}

/* Qty stepper */
.qs{display:inline-flex;align-items:center;background:var(--bg);border-radius:var(--r);
  border:1.5px solid var(--border);overflow:hidden}
.qs button{width:48px;height:44px;border:0;background:0 0;color:var(--txt);font-size:22px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700}
.qs button:hover{background:var(--border)}
.qs button:active{background:var(--border-s)}
.qs input{width:48px;text-align:center;font-size:20px;font-weight:700;border:0;background:0 0;
  color:var(--txt);-moz-appearance:textfield}
.qs input::-webkit-inner-spin-button,.qs input::-webkit-outer-spin-button{-webkit-appearance:none}

/* Filter bar */
.fbar{display:flex;align-items:center;gap:8px;padding:10px 14px;flex-wrap:wrap;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);margin-bottom:10px;
  box-shadow:0 1px 3px rgba(74,48,45,.05)}
.fsep{width:1px;height:24px;background:var(--border);flex-shrink:0}

/* Encargos single column */
.enc-single{display:flex;flex-direction:column;height:calc(100dvh - var(--hdr-h) - 84px)}
.enc-col{display:flex;flex-direction:column;min-height:0}
.enc-col-h{display:flex;align-items:center;gap:8px;padding:8px 0;flex-shrink:0;
  border-bottom:2px solid var(--brand);margin-bottom:8px}
.enc-col-t{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--brand)}
.enc-col-c{background:var(--brand);color:#fff;font-size:12px;font-weight:700;padding:2px 8px;border-radius:10px}
.enc-search{margin-left:auto;max-width:250px;height:34px;font-size:16px}
.enc-col-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-right:4px}

/* Form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-sec{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  color:var(--brand);margin-bottom:10px;display:flex;align-items:center;gap:6px;
  padding-bottom:8px;border-bottom:2px solid var(--brand)}
.sel-art{display:flex;flex-direction:column;gap:5px}
.sel-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--brand-soft);
  border:1px solid var(--border-s);border-radius:var(--r)}
.sel-row .name{flex:1;font-size:17px;font-weight:600}
.sel-row .rm{color:var(--txt-m);cursor:pointer;width:40px;height:40px;display:flex;align-items:center;
  justify-content:center;border-radius:var(--rs);border:1px solid var(--border);background:var(--surface);
  font-size:16px;flex-shrink:0;transition:all .12s}
.sel-row .rm:hover{color:#fff;background:var(--err);border-color:var(--err)}

/* Edit fijo articles – tablet friendly */
.edit-fijo-arts{display:flex;flex-direction:column;gap:5px}
.efa-row{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--brand-soft);
  border:1px solid var(--border);border-radius:var(--r)}
.efa-name{flex:1;font-size:17px;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.efa-row .rm{color:var(--txt-m);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;
  justify-content:center;border-radius:var(--rs);border:1px solid var(--border);background:var(--surface);
  font-size:15px;flex-shrink:0;transition:all .12s}
.efa-row .rm:hover{color:#fff;background:var(--err);border-color:var(--err)}
.qs-sm{display:inline-flex;align-items:center;background:var(--bg);border-radius:var(--r);
  border:1.5px solid var(--border);overflow:hidden;flex-shrink:0}
.qs-sm button{width:40px;height:38px;border:0;background:0 0;color:var(--txt);font-size:20px;
  cursor:pointer;font-weight:700;display:flex;align-items:center;justify-content:center}
.qs-sm button:hover{background:var(--border)}
.qs-sm button:active{background:var(--border-s)}
.qs-sm input{width:40px;text-align:center;font-size:18px;font-weight:700;border:0;background:0 0;
  color:var(--txt);-moz-appearance:textfield}
.qs-sm input::-webkit-inner-spin-button,.qs-sm input::-webkit-outer-spin-button{-webkit-appearance:none}

/* Cancellations */
.canc-row{display:flex;align-items:center;gap:8px;padding:5px 10px;background:var(--err-bg);
  border:1px solid rgba(179,58,42,.15);border-radius:var(--rs);margin-bottom:3px;font-size:14px;font-weight:500}

/* Add button lateral */
.efa-add-btn{width:72px;min-width:72px;height:auto!important;min-height:auto!important;
  display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:14px;
  border-radius:var(--r);flex-shrink:0;gap:2px;line-height:1.2;text-align:center;white-space:normal}

/* Modal */
.mo{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:1000;display:none;
  align-items:flex-end;justify-content:center;animation:fadeIn .15s var(--ease)}
.mo.open{display:flex}
/* Article selector modal always on top (can be opened from edit modal) */
.mo.mo-top{z-index:1100}
.mo-sheet{background:var(--surface);border-radius:var(--rl) var(--rl) 0 0;width:100%;
  max-height:90vh;display:flex;flex-direction:column;animation:sheetUp .25s var(--ease)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.mo-h{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0}
.mo-h h4{font-size:18px;font-weight:600;margin:0;flex:1}
.mo-b{flex:1;overflow-y:auto;padding:14px 18px;-webkit-overflow-scrolling:touch}
.mo-f{padding:10px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}
.mo.center{align-items:center}
.mo.center .mo-sheet{border-radius:var(--rl);max-width:600px;max-height:80vh}
.mo.mo-wide.center .mo-sheet{max-width:720px!important;max-height:88vh!important}

/* ── Article form sections ── */
.af-form{display:flex;gap:0}
.af-col-left{flex:1;padding-right:18px;border-right:1px solid var(--border)}
.af-col-right{width:200px;padding-left:18px;flex-shrink:0}
.af-section{padding:12px 0;border-bottom:1px solid var(--border)}
.af-section:last-child{border-bottom:none}
.af-sec-title{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--brand);
  margin-bottom:10px;display:flex;align-items:center;gap:5px}
.af-row{display:flex;gap:10px;margin-bottom:8px}
.af-row:last-child{margin-bottom:0}
.af-field{display:flex;flex-direction:column}
.af-grow{flex:1}
.af-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none;
  padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r);height:42px}
.af-toggle span{font-size:16px;font-weight:600}
.af-max-row{display:flex;gap:8px;align-items:center}
.af-max-row .inp{flex:1}
.af-unlimited{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:15px;font-weight:600;
  padding:8px 14px;border-radius:var(--r);border:1.5px solid var(--border);background:var(--bg);
  color:var(--txt-s);white-space:nowrap;transition:all .15s;height:42px}
.af-unlimited:hover{border-color:var(--brand);color:var(--brand)}
.af-unlimited.on{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}
.af-unlimited input{display:none}
.al-checks-v{display:flex;flex-direction:column;gap:4px}
.al-checks-v .al-check{font-size:16px;padding:7px 10px;border-radius:var(--r);border:1.5px solid var(--border);
  background:var(--bg);display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .12s}
.al-checks-v .al-check:hover{border-color:var(--brand);background:var(--brand-soft)}
.al-checks-v .al-check:has(input:checked){border-color:var(--brand);background:var(--brand-soft)}
.al-checks-v .al-check input{display:none}
.al-checks-v .al-check .al-box{width:18px;height:18px;border-radius:4px;border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;transition:all .12s;flex-shrink:0}
.al-checks-v .al-check .al-box i{font-size:12px;color:#fff;opacity:0;transition:opacity .1s}
.al-checks-v .al-check:has(input:checked) .al-box{background:var(--brand);border-color:var(--brand)}
.al-checks-v .al-check:has(input:checked) .al-box i{opacity:1}

/* Article grid */
/* Article category tabs */
.art-tabs{display:flex;gap:4px;flex-wrap:wrap;padding-bottom:10px;margin-bottom:10px;
  border-bottom:1.5px solid var(--border)}
.art-tabs::-webkit-scrollbar{height:0}
.art-tab{flex-shrink:0;padding:6px 14px;border-radius:var(--r);font-size:15px;font-weight:600;
  border:1.5px solid var(--border);background:var(--surface);color:var(--txt-s);
  cursor:pointer;transition:all .12s var(--ease);display:flex;align-items:center;gap:5px}
.art-tab:hover{border-color:var(--brand);color:var(--brand)}
.art-tab.on{background:var(--brand);border-color:var(--brand);color:#fff}
.art-tab-badge{min-width:18px;height:18px;border-radius:9px;font-size:12px;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.3);color:#fff;padding:0 4px}
.art-tab:not(.on) .art-tab-badge{background:var(--brand-light);color:var(--brand-dark)}
.art-panel{display:none}
.art-panel.on{display:block}
.art-cat-label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  color:var(--brand-dark);padding:8px 0 4px;border-bottom:1px solid var(--brand-light);margin-bottom:6px}
.art-cat-label:first-child{padding-top:0}

/* Article modal fixed height */
#moArts .mo-sheet{height:80vh;max-height:80vh;min-height:80vh}
#moArts .mo-b{flex:1;overflow-y:auto}

.agrid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.agrid-i{padding:10px;border:1.5px solid var(--border);border-radius:var(--r);display:flex;
  align-items:center;justify-content:space-between;gap:6px;transition:all .12s var(--ease)}
.agrid-i.has{border-color:var(--brand);background:var(--brand-soft)}
.agrid-i.over{border-color:var(--err)!important;background:var(--err-bg)!important;animation:pulse-over .4s}
@keyframes pulse-over{0%,100%{transform:scale(1)}50%{transform:scale(1.02)}}
.agrid-i .an{font-size:15px;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.agrid-i .ac{font-size:11px;color:var(--txt-m);text-transform:uppercase;letter-spacing:.2px}

/* Summary table */
.stbl{width:100%;border-collapse:separate;border-spacing:0}
.stbl thead th{padding:8px 12px;font-size:12px;font-weight:700;text-transform:uppercase;
  letter-spacing:.4px;color:var(--txt-m);border-bottom:2px solid var(--border);text-align:left}
.stbl tbody td{padding:8px 12px;font-size:16px;border-bottom:1px solid var(--border)}
.stbl tbody tr:last-child td{border:0}
.stbl tbody tr:hover{background:var(--bg)}

/* Toast */
.toast-w{position:fixed;top:14px;right:14px;z-index:9999;display:flex;flex-direction:column;gap:6px}
.toast-m{padding:10px 16px;border-radius:var(--r);font-size:16px;font-weight:500;
  display:flex;align-items:center;gap:8px;box-shadow:0 6px 20px rgba(0,0,0,.1);
  animation:toastIn .25s var(--ease);max-width:320px;color:#fff}
.toast-m.ok{background:var(--ok)}.toast-m.err{background:var(--err)}
.toast-m.warn{background:var(--warn)}.toast-m.info{background:var(--info)}
@keyframes toastIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}

/* Empty state */
.empty{text-align:center;padding:40px 20px;color:var(--txt-m)}
.empty i{font-size:38px;margin-bottom:10px;opacity:.3}
.empty p{font-size:16px;margin:0}

/* Stock availability hint in article modal */
.stock-hint{font-size:12px;font-weight:600;margin-top:2px;display:flex;align-items:center;gap:3px}
.stock-hint i{font-size:11px}

/* Scrollbar */
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}
::-webkit-scrollbar-thumb{background:var(--border-s);border-radius:3px}

/* Client dropdown */
.cli-dd{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1.5px solid var(--border-s);
  border-radius:0 0 var(--r) var(--r);max-height:240px;overflow-y:auto;z-index:50;display:none;
  box-shadow:0 8px 24px rgba(0,0,0,.1)}

/* ── Client/Article list cards ── */
.item-card{background:var(--surface);border:1px solid var(--border-s);border-radius:var(--r);
  padding:10px 14px;margin-bottom:6px;display:flex;align-items:center;gap:12px;
  transition:all .12s var(--ease);box-shadow:0 1px 3px rgba(74,48,45,.05)}
.item-card:hover{border-color:var(--brand-light);box-shadow:0 2px 8px rgba(74,48,45,.08)}
.item-card .ic-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}
.item-card .ic-avatar.cli{background:var(--brand-soft);color:var(--brand)}
.item-card .ic-avatar.art{background:var(--brand-light);color:var(--brand-dark)}
.item-card .ic-avatar.art-off{background:var(--err-bg);color:var(--err);opacity:.5}
.item-card .ic-info{flex:1;min-width:0}
.item-card .ic-name{font-size:17px;font-weight:600;color:var(--txt)}
.item-card .ic-meta{font-size:14px;color:var(--txt-m);margin-top:1px;display:flex;gap:10px;flex-wrap:wrap}
.item-card .ic-meta span{display:inline-flex;align-items:center;gap:3px}
.item-card .ic-actions{display:flex;gap:6px;flex-shrink:0;padding-left:10px;
  border-left:1px solid var(--border);margin-left:auto}

/* Article category header */
.cat-header{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  color:var(--brand-dark);padding:10px 12px 6px;border-bottom:1.5px solid var(--brand-light);margin-bottom:6px;margin-top:10px;
  display:flex;align-items:center;gap:4px}
.cat-header:first-child{margin-top:0}
.cat-toggle{cursor:pointer;margin-left:auto;flex-shrink:0;display:flex;align-items:center;gap:6px;
  padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;transition:all .12s}
.cat-toggle-on{background:rgba(61,139,94,.1);color:var(--ok)}
.cat-toggle-off{background:var(--err-bg);color:var(--err)}

/* Day availability dots in article view */
.avail-dots{display:flex;gap:2px}
.avail-dots span{width:18px;height:18px;border-radius:50%;font-size:9px;font-weight:700;
  display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--txt-m)}
.avail-dots span.on{background:var(--brand);color:#fff}
.cli-dd.open{display:block}
.cli-dd-i{padding:10px 14px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--border);font-size:16px;transition:background .1s}
.cli-dd-i:hover,.cli-dd-i:active{background:var(--brand-soft)}
.cli-dd-i:last-child{border:0}
.cli-dd-i .ph{color:var(--txt-m);font-size:15px}
.cli-warn{margin-top:6px;padding:8px 12px;background:var(--err-bg);border:1px solid rgba(179,58,42,.2);
  border-radius:var(--rs);font-size:14px;font-weight:600;color:var(--err);
  display:flex;align-items:center;gap:6px}

/* Load more / pagination */
.load-more-bar{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 0;
  border-top:1px solid var(--border);margin-top:8px}
.load-more-count{font-size:14px;color:var(--txt-m);font-weight:500}
.load-more-btn{height:36px!important;font-size:14px!important;padding:0 16px!important}

/* Collapsible categories */
.cat-collapsible{cursor:pointer;user-select:none;transition:all .12s;
  min-height:var(--touch);padding:12px 14px;margin:6px 0 4px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;
  text-transform:uppercase;letter-spacing:.4px;color:var(--brand-dark)}
.cat-collapsible:first-child{margin-top:0}
.cat-collapsible:hover,.cat-collapsible:active{background:var(--brand-soft);border-color:var(--brand-light)}
.cat-chevron{font-size:13px;color:var(--txt-m);width:16px;transition:transform .15s}

/* Category manager */
.cat-mgr-list{display:flex;flex-direction:column;gap:4px}
.cat-mgr-item{background:var(--brand-soft);border:1px solid var(--brand-light);border-radius:var(--r);overflow:hidden}
.cat-mgr-view{display:flex;align-items:center;gap:8px;padding:10px 12px}
.cat-mgr-edit{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--surface)}
.cat-mgr-name{flex:1;font-weight:600;font-size:16px;color:var(--txt)}
.cat-mgr-count{font-size:13px;color:var(--txt-m);font-weight:500;white-space:nowrap;
  background:var(--surface);padding:2px 8px;border-radius:10px}

/* ── Resum del dia ── */
.rk-bar{display:flex;gap:6px;margin-bottom:12px}
.rk-item{flex:1;display:flex;align-items:center;gap:8px;padding:10px 12px;
  border-radius:var(--r);border:1px solid var(--border);background:var(--surface)}
.rk-item>i{font-size:20px}
.rk-data{display:flex;flex-direction:column}
.rk-num{font-size:22px;font-weight:800;line-height:1.1}
.rk-lbl{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--txt-m)}
.rk-pending>i{color:#B8860B}.rk-pending .rk-num{color:#B8860B}
.rk-prep>i{color:var(--info)}.rk-prep .rk-num{color:var(--info)}
.rk-total{background:var(--brand-soft);border-color:var(--brand-light)}
.rk-total>i{color:var(--brand)}.rk-total .rk-num{color:var(--brand)}

.rk-prog-wrap{margin-bottom:16px}
.rk-progress{height:22px;background:var(--border);border-radius:11px;display:flex;overflow:hidden;border:1px solid var(--border)}
.rk-prog-done{background:#3D8B5E;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:width .3s}
.rk-prog-prep{background:#5B9BD5;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:width .3s}
.rk-prog-pend{background:#D4C9A8;color:#6B5D3E;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:width .3s}
.rk-prog-legend{display:flex;gap:12px;justify-content:center;margin-top:6px}
.rk-leg{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500;color:var(--txt-m)}
.rk-leg-dot{width:10px;height:10px;border-radius:50%}
.rk-leg-ok{background:#3D8B5E}.rk-leg-info{background:#5B9BD5}.rk-leg-pend{background:#D4C9A8}

.rk-table{border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.rk-thead{display:flex;align-items:center;background:var(--brand-soft);padding:8px 12px;
  font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--brand-dark);border-bottom:1px solid var(--brand-light)}
.rk-th-name{flex:1}
.rk-th{width:90px;text-align:center;display:flex;align-items:center;justify-content:center;gap:4px}
.rk-th i{font-size:12px}
.rk-th-total{width:70px;font-weight:800}

.rk-row{display:flex;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);background:var(--surface)}
.rk-row:last-child{border-bottom:0}
.rk-td-name{flex:1;font-weight:600;font-size:16px}
.rk-td{width:90px;text-align:center;font-size:16px;font-weight:700}
.rk-td-pend{color:#856404;background:#FFF8E1;border-radius:var(--rs);padding:3px 0}
.rk-td-prep{color:#0C5460;background:#E3F2FD;border-radius:var(--rs);padding:3px 0}
.rk-td-total{width:70px;font-size:18px;font-weight:800;color:var(--brand)}
.rk-td-zero{color:var(--txt-m);font-weight:400;font-size:15px}

/* ── Stock view ── */
.stk-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.stk-kpi{text-align:center;padding:10px 8px;background:var(--bg);border-radius:var(--r);border:1px solid var(--border)}
.stk-kpi-num{font-size:24px;font-weight:800;color:var(--brand);line-height:1.2;display:block}
.stk-kpi-lbl{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--txt-m);
  display:flex;align-items:center;justify-content:center;gap:3px}
.stk-kpi-warn{border-color:rgba(184,134,11,.3);background:#FFFCF0}
.stk-kpi-warn .stk-kpi-num{color:#B8860B}
.stk-kpi-alert{border-color:rgba(192,57,43,.3);background:var(--err-bg)}
.stk-kpi-alert .stk-kpi-num{color:var(--err)}

.stk-table .rk-row{padding:10px 12px;transition:background .12s}
.stk-table .rk-row:hover{background:rgba(103,71,68,.03)}
.stk-thead{position:sticky;top:0;z-index:1}
.stk-th-name{flex:2;font-weight:700;display:flex;align-items:center;gap:4px;cursor:pointer}
.stk-th{flex:1;text-align:center;font-weight:700;display:flex;align-items:center;justify-content:center;gap:3px}
.stk-th-hl{background:rgba(103,71,68,.12);border-radius:var(--rs)}
.stk-th-act{width:140px;text-align:center}
.stk-sort-idle{font-size:12px;opacity:.3}
.stk-sort-on{font-size:12px;color:var(--brand)}

.stk-td-name{flex:2;display:flex;align-items:center;gap:6px}
.stk-art-name{font-weight:600;font-size:17px}
.stk-warn-icon{font-size:15px;flex-shrink:0}
.stk-warn-out{color:var(--err)}
.stk-warn-low{color:#B8860B}
.stk-td{flex:1;text-align:center;font-size:17px;font-weight:600;display:flex;align-items:center;justify-content:center}
.stk-td-stock{cursor:pointer;border-radius:var(--rs);transition:background .12s}
.stk-td-stock:hover{background:var(--brand-soft)}
.stk-val-click{display:flex;align-items:center;gap:4px;font-size:17px;font-weight:700;color:var(--brand)}
.stk-td-enc{color:var(--txt);font-weight:700}
.stk-td-sacar{color:#fff;background:var(--brand);border-radius:var(--rs);font-weight:800;font-size:16px;padding:4px 8px;margin:0 4px}
.stk-td-final{font-size:20px;font-weight:800}
.stk-final-neg{color:var(--err)}
.stk-final-low{color:#B8860B}
.stk-final-ok{color:var(--ok)}
.stk-td-act{width:140px;display:flex;align-items:center;justify-content:center;gap:4px}

.stk-inp{width:56px;height:32px;border:1px solid var(--border);border-radius:var(--rs);text-align:center;
  font-size:16px;font-weight:600;background:var(--bg);padding:0 4px}
.stk-inp:focus{border-color:var(--brand);outline:none;background:#fff}
.stk-td-botiga{cursor:pointer}
.stk-botiga-val{font-weight:700;color:var(--brand)}

.stk-row{border-left:3px solid transparent}
.stk-row-alert{background:#FFF5F5!important;border-left-color:var(--err)}
.stk-row-low{background:#FFFCF0!important;border-left-color:#B8860B}

.stk-mode{display:flex;gap:4px}
.stk-mode .bd{min-width:80px}

/* Stock modal */
/* ═══ CLIENT SUMMARY ═══ */
.cs-filters{display:flex;gap:4px;margin-bottom:12px;justify-content:center}
.cs-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.cs-kpi{text-align:center;padding:10px 6px;background:var(--bg);border-radius:var(--r);border:1px solid var(--border)}
.cs-kpi-num{font-size:24px;font-weight:800;color:var(--brand);line-height:1.2}
.cs-kpi-lbl{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--txt-m)}
.cs-kpi-warn{border-color:rgba(192,57,43,.3);background:var(--err-bg)}
.cs-kpi-warn .cs-kpi-num{color:var(--err)}
.cs-insights{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.cs-chip{font-size:13px;padding:4px 10px;background:var(--bg);border-radius:20px;color:var(--txt-m);display:inline-flex;align-items:center;gap:4px}
.cs-chip b{color:var(--brand)}
.cs-section{margin-bottom:14px}
.cs-sec-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--txt-m);margin-bottom:6px;
  display:flex;align-items:center;gap:5px}
.cs-top-arts{display:flex;flex-direction:column;gap:3px}
.cs-top-art{display:flex;align-items:center;gap:8px;padding:5px 8px;background:var(--bg);border-radius:var(--rs);font-size:14px}
.cs-top-rank{width:22px;text-align:center;font-size:15px}
.cs-top-name{flex:1;font-weight:600;color:var(--txt)}
.cs-top-qty{font-weight:700;color:var(--brand);min-width:40px;text-align:right}
.cs-top-times{font-size:12px;color:var(--txt-s);min-width:28px;text-align:right}
.cs-orders{display:flex;flex-direction:column;gap:6px}
.cs-order{padding:8px 10px;background:var(--bg);border-radius:var(--r);border-left:3px solid var(--border)}
.cs-order.cs-st-ok{border-left-color:var(--ok)}
.cs-order.cs-st-prep{border-left-color:#2980b9}
.cs-order.cs-st-pend{border-left-color:var(--warn)}
.cs-ord-head{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600}
.cs-ord-date{color:var(--brand)}
.cs-ord-day{text-transform:uppercase;font-size:12px;font-weight:700;color:var(--txt-m)}
.cs-ord-time{color:var(--txt-m)}
.cs-ord-status{font-size:12px;font-weight:600;padding:2px 7px;border-radius:10px}
.cs-st-ok .cs-ord-status{color:var(--ok);background:rgba(39,174,96,.1)}
.cs-st-prep .cs-ord-status{color:#2980b9;background:rgba(41,128,185,.1)}
.cs-st-pend .cs-ord-status{color:var(--warn);background:rgba(243,156,18,.1)}
.cs-ord-qty{margin-left:auto;font-weight:700;color:var(--brand)}
.cs-ord-arts{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}
.cs-art-chip{font-size:12px;padding:2px 8px;background:var(--surface);border:1px solid var(--border);border-radius:12px;color:var(--txt-m)}
.cs-ord-comm{font-size:12px;color:var(--txt-s);margin-top:4px;font-style:italic}

/* ── Enc created date ── */
/* ═══ STOCK MODAL ═══ */
.stk-mo-vals{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px}
.stk-mo-val{text-align:center;flex:1;padding:12px;background:var(--bg);border-radius:var(--r);border:1px solid var(--border)}
.stk-mo-val-new{background:var(--brand-soft);border-color:var(--brand-light)}
.stk-mo-lbl{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--txt-m);margin-bottom:4px}
.stk-mo-num{font-size:34px;font-weight:800;color:var(--brand);line-height:1.1}
.stk-mo-arrow{color:var(--txt-m);font-size:18px}
.stk-mo-mode{display:flex;justify-content:center;gap:6px;margin-bottom:16px}
.stk-mo-mode .bd{min-width:100px;height:40px;font-size:16px}
.stk-mo-delta{display:flex;align-items:center;justify-content:center;gap:8px}
.stk-mo-btn{width:48px;height:48px;font-size:22px;padding:0;display:flex;align-items:center;justify-content:center}
.enc-created{font-size:12px;color:var(--txt-s);display:inline-flex;align-items:center;gap:3px;
  padding:2px 6px;background:var(--bg);border-radius:8px;font-weight:600;white-space:nowrap;
  position:absolute;top:6px;right:6px}
.enc-created i{font-size:11px;color:var(--brand)}
.enc-created-fijo{background:#E8EDF3;color:#556270}
.enc-created-fijo i{color:#556270}

/* ── Enc actions row ── */
.enc-actions{display:flex;gap:4px;margin-top:6px}

/* ── Diario: articles in grid ── */
.diari-art{display:flex;align-items:stretch;gap:0;padding:0;
  background:var(--brand-soft);border:1px solid var(--brand-light);border-radius:var(--r);min-width:0;overflow:hidden}
.diari-art-name{font-size:16px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;min-width:0;padding:8px 0 8px 12px;display:flex;align-items:center}
.diari-art-qty{font-size:17px;font-weight:800;color:var(--brand);min-width:20px;text-align:center;
  flex-shrink:0;margin-left:auto;display:flex;align-items:center;padding:0 10px}

/* Action wrapper — gap + grouped buttons */
.enc-act{display:flex;flex-shrink:0;padding-left:6px}
.enc-act-in{display:flex;border-radius:0 calc(var(--r) - 1px) calc(var(--r) - 1px) 0;
  overflow:hidden;border-left:1px solid rgba(103,71,68,.12)}

/* Status buttons — rectangular, integrated into action group */
.st.sm{width:48px;height:auto;min-height:44px;font-size:17px;flex-shrink:0;
  border:none;border-left:1px solid rgba(103,71,68,.12);border-radius:0;
  background:transparent;color:var(--txt-m)}
.st.sm:first-child{border-left:none}
.st.sm:active{transform:scale(.96)}
.st.sm.prep{background:var(--info);color:#fff}
.st.sm.done{background:var(--ok);color:#fff}

/* Status hover hints */
.st:not(.prep):not(.done):hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.st.sm:not(.prep):not(.done):hover{background:var(--brand-light);color:var(--brand)}

/* Article day availability warning */
.art-not-avail{opacity:.6;border-style:dashed!important}
.art-not-avail .an{text-decoration:line-through;text-decoration-color:var(--err)}
.art-day-warn{font-size:12px;font-weight:700;color:var(--err);display:flex;align-items:center;gap:3px;margin-top:1px}
.art-day-warn i{font-size:11px}

/* Fijo side action buttons */
.fijo-act{width:42px;height:42px;border-radius:var(--rs);border:1.5px solid var(--border);
  background:var(--surface);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .12s var(--ease);font-size:18px;color:var(--txt-m)}
.fijo-act:active{transform:scale(.9)}
/* Edit button — warm amber/orange */
.fijo-act-edit{color:var(--brand);border-color:rgba(139,107,62,.25);background:var(--brand-soft)}
.fijo-act-edit:hover{background:var(--brand-light);border-color:var(--brand);color:var(--brand-h)}
/* Cancel/delete button — same warm style as edit but in red */
.fijo-act-cancel{color:#C0392B;border-color:rgba(192,57,43,.25);background:var(--err-bg)}
.fijo-act-cancel:hover{background:#f9d5d1;border-color:var(--err);color:#A93226}
.fijo-act-ok{color:var(--ok);border-color:rgba(39,174,96,.25);background:#eafaf1}
.fijo-act-ok:hover{background:#d5f5e3;border-color:var(--ok);color:#1e8449}
.fijo-act-info{color:#2980b9;border-color:rgba(41,128,185,.25);background:#ebf5fb}
.fijo-act-info:hover{background:#d4e6f1;border-color:#2980b9;color:#1a5276}
.enc-actions{display:flex;gap:4px;margin-top:6px}
.enc-actions button{font-size:13px;padding:4px 10px;border-radius:var(--rs);border:1px solid var(--border);
  background:var(--surface);color:var(--txt-s);cursor:pointer;transition:all .1s}
.enc-actions button:hover{border-color:var(--brand);color:var(--brand)}
.enc-actions button.del:hover{border-color:var(--err);color:var(--err)}

/* ── Allergens ── */
.al-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;
  font-size:13px;font-weight:600;border:1px solid var(--border);background:var(--surface);
  color:var(--txt-s);cursor:pointer;transition:all .12s;margin:0 2px 2px 0}
.al-chip:hover{border-color:var(--brand);color:var(--brand)}
.al-chip.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.al-chip-clear{background:var(--err-bg);border-color:rgba(179,58,42,.2);color:var(--err);padding:4px 8px}
.al-chip-clear:hover{background:var(--err);color:#fff}
.al-chip i{font-size:12px}
.art-alergen-filter{display:flex;flex-wrap:wrap;align-items:center;gap:2px;padding:0 2px}

.al-icons{display:inline-flex;gap:3px;margin-left:6px;vertical-align:middle}
.al-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;
  border-radius:50%;background:var(--brand-soft);border:1px solid var(--brand-light);
  font-size:11px;color:var(--brand)}

.al-checks{display:flex;flex-wrap:wrap;gap:6px}
.al-check{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--r);
  border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:14px;font-weight:600;
  color:var(--txt-s);transition:all .12s;user-select:none}
.al-check:has(input:checked){background:var(--brand-soft);border-color:var(--brand-light);color:var(--brand)}
.al-check input{accent-color:var(--brand);width:15px;height:15px}
.al-check i{font-size:14px}

/* Allergen icon grid picker */
.al-icon-grid{display:flex;flex-wrap:wrap;gap:4px}
.al-icon-opt{width:36px;height:36px;border-radius:var(--rs);border:1.5px solid var(--border);
  background:var(--surface);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .12s;font-size:16px;color:var(--txt-m)}
.al-icon-opt:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.al-icon-opt.on{border-color:var(--brand);background:var(--brand);color:#fff}

/* Icon picker dropdown */
.al-icon-pick{flex-shrink:0}
.al-icon-pick-btn{width:42px;height:38px;border:1.5px solid var(--border);border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;gap:4px;cursor:pointer;
  background:var(--surface);font-size:18px;color:var(--brand);transition:all .12s}
.al-icon-pick-btn:hover{border-color:var(--brand);background:var(--brand-soft)}
.al-icon-pick-grid{display:none}

/* Icon picker overlay */
.al-icon-overlay{position:absolute;inset:0;background:rgba(0,0,0,.25);display:flex;align-items:center;
  justify-content:center;z-index:50;border-radius:inherit}
.al-icon-overlay-box{background:var(--surface);border-radius:var(--rl);padding:16px;
  box-shadow:0 8px 32px rgba(0,0,0,.18);border:1.5px solid var(--border)}
.al-icon-overlay-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.al-icon-opt-lg{width:48px;height:48px;border-radius:var(--r);border:1.5px solid var(--border);
  background:var(--surface);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .12s;font-size:20px;color:var(--txt-m)}
.al-icon-opt-lg:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.al-icon-opt-lg.on{border-color:var(--brand);background:var(--brand);color:#fff}

/* Allergen section */
.al-section-new{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:12px;margin-bottom:12px}
.al-section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;
  color:var(--txt-m);margin-bottom:8px;display:flex;align-items:center;gap:6px}
/* Allergen manager cards */
.al-mgr-list{display:flex;flex-direction:column;gap:6px}
.al-mgr-item{background:var(--brand-soft);border:1px solid var(--brand-light);border-radius:var(--r);overflow:hidden}
.al-mgr-view{display:flex;align-items:center;gap:12px;padding:10px 12px}
.al-mgr-icon{width:40px;height:40px;border-radius:var(--rs);background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.al-mgr-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.al-mgr-name{font-size:17px;font-weight:700;color:var(--txt)}
.al-mgr-count{font-size:13px;color:var(--txt-m);font-weight:500}
.al-mgr-actions{display:flex;gap:6px;flex-shrink:0}

/* ── Client filters & pagination ── */
.cli-filters{display:flex;flex-wrap:wrap;gap:4px;padding:0 2px;margin-bottom:6px}
.cli-letters{display:flex;flex-wrap:wrap;gap:2px;padding:0 2px;margin-bottom:10px}
.cli-letter{width:28px;height:28px;border-radius:var(--rs);border:1px solid var(--border);
  background:var(--surface);font-size:12px;font-weight:700;color:var(--txt-m);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .12s;padding:0}
.cli-letter:first-child{width:auto;padding:0 10px;font-size:13px}
.cli-letter:hover{border-color:var(--brand);color:var(--brand)}
.cli-letter.on{background:var(--brand);color:#fff;border-color:var(--brand)}

.cli-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 4px;margin-top:6px}
.pag-info{font-size:14px;color:var(--txt-m);font-weight:600}
.pag-btns{display:flex;gap:4px;align-items:center}
.pag-btn{width:34px;height:34px;border-radius:var(--rs);border:1px solid var(--border);
  background:var(--surface);font-size:14px;font-weight:700;color:var(--txt);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .12s}
.pag-btn:hover:not(:disabled){border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.pag-btn.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.pag-btn:disabled{opacity:.35;cursor:default}
.pag-dots{font-size:14px;color:var(--txt-m);padding:0 2px}

/* ═══ STATS DASHBOARD ═══ */
.stats-dashboard{display:flex;flex-direction:column;gap:16px}

/* KPI Cards — 3 columns */
.stat-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.stat-kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);
  padding:16px;display:flex;align-items:center;gap:12px}
.stat-kpi-icon{width:42px;height:42px;border-radius:50%;background:var(--brand-soft);
  display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--brand);flex-shrink:0}
.stat-kpi-data{display:flex;flex-direction:column}
.stat-kpi-val{font-size:24px;font-weight:700;color:var(--txt);line-height:1.1}
.stat-kpi-label{font-size:13px;color:var(--txt-m);font-weight:500;margin-top:2px}

/* Trend badges */
.stat-trend{font-size:12px;font-weight:700;padding:1px 6px;border-radius:8px;margin-left:4px;white-space:nowrap}
.stat-up{color:#16a34a;background:#dcfce7}
.stat-down{color:#dc2626;background:#fee2e2}

/* Card rows */
.stat-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden}
.stat-card-h{padding:12px 16px;font-size:15px;font-weight:700;color:var(--brand);
  border-bottom:1.5px solid var(--border);background:var(--bg)}
.stat-card-h i{margin-right:6px}
.stat-card-body{padding:10px 16px;display:flex;flex-direction:column;gap:6px;max-height:400px;overflow-y:auto}

/* Stat items */
.stat-item{display:flex;align-items:center;gap:8px;font-size:15px;padding:4px 0;
  border-bottom:1px solid var(--bg)}
.stat-item:last-child{border-bottom:0}
.stat-pos{width:22px;height:22px;border-radius:50%;background:var(--brand-soft);color:var(--brand);
  font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stat-val{font-weight:700;color:var(--txt);white-space:nowrap;font-size:14px;min-width:60px;text-align:right}
.stat-empty{color:var(--txt-m);font-size:14px;padding:12px 0;text-align:center}

/* Horizontal bars */
.stat-bar{flex:1;height:8px;background:var(--bg);border-radius:4px;overflow:hidden;min-width:60px}
.stat-bar-fill{height:100%;border-radius:4px;transition:width .4s var(--ease)}

/* Section headers */
.stat-section-h{font-size:15px;font-weight:700;color:var(--txt-m);padding:8px 0 2px;
  border-bottom:1.5px solid var(--border);margin-top:4px}
.stat-section-h i{margin-right:6px;color:var(--brand)}

/* Legend */
.stat-legend{float:right;font-size:13px;font-weight:500;color:var(--txt-m)}
.stat-leg-dot{display:inline-block;width:8px;height:8px;border-radius:2px;margin:0 3px 0 8px;vertical-align:middle}

/* Grouped vertical bar chart */
.stat-chart-body{padding:8px 14px !important;max-height:none !important;overflow:visible !important}
.stat-gfill-o{background:var(--brand)}
.stat-gfill-a{background:var(--info)}

/* Horizontal trend rows */
.stat-trow{display:flex;align-items:center;gap:10px;padding:5px 0;border-bottom:1px solid var(--bg)}
.stat-trow:last-child{border-bottom:0}
.stat-trow-label{min-width:70px;font-size:14px;font-weight:600;color:var(--txt);white-space:nowrap}
.stat-trow-bars{flex:1;display:flex;flex-direction:column;gap:3px}
.stat-trow-bar{display:flex;align-items:center;gap:6px;height:14px}
.stat-trow-fill{height:100%;border-radius:3px;min-width:3px;transition:width .4s var(--ease)}
.stat-trow-val{font-size:12px;font-weight:700;white-space:nowrap;min-width:30px}
.stat-trow-bar:first-child .stat-trow-val{color:var(--brand)}
.stat-trow-bar:last-child .stat-trow-val{color:var(--info)}

/* Footer */
.stat-footer{text-align:center;font-size:13px;color:var(--txt-m);padding:12px 0;
  border-top:1px solid var(--border)}
.stat-footer i{margin-right:4px}

@media(max-width:768px){
  .stat-row{grid-template-columns:1fr}
  .stat-kpis{grid-template-columns:repeat(2,1fr)}
}

/* ═══ STOCK HISTORY ═══ */
.sh-unified{display:flex;flex-direction:column;max-height:460px;overflow-y:auto}
.sh-thead{display:grid;grid-template-columns:90px 1fr 55px 55px 70px;gap:6px;padding:6px 8px;
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--txt-m);
  border-bottom:1.5px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}
.sh-th-r{text-align:right}
.sh-trow{display:grid;grid-template-columns:90px 1fr 55px 55px 70px;gap:6px;padding:7px 8px;
  font-size:14px;border-bottom:1px solid var(--bg);align-items:center}
.sh-trow:last-child{border-bottom:0}
.sh-trow.sh-row-alert{background:var(--err-bg)}
.sh-trow.sh-row-low{background:var(--warn-bg)}
.sh-trow.sh-row-first{background:var(--brand-soft);font-weight:600}
.sh-td{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sh-td-date{font-size:13px;font-weight:600;color:var(--txt-s)}
.sh-td-r{text-align:right}
.sh-td-stock{font-weight:700;color:var(--txt)}
.sh-td-bar{display:flex;align-items:center}
.sh-bar-bg{flex:1;height:14px;background:var(--bg);border-radius:4px;overflow:hidden}
.sh-bar-fill{height:100%;border-radius:4px;transition:width .4s var(--ease);min-width:3px}
.sh-diff{font-size:13px;font-weight:700;white-space:nowrap}
.sh-diff i{font-size:11px;margin-left:1px}
.sh-diff-up{color:var(--ok)}
.sh-diff-down{color:var(--err)}
.sh-diff-eq{color:var(--txt-m)}
.sh-diff-na{color:var(--txt-m);font-weight:400}
@media(max-width:600px){
  .sh-thead,.sh-trow{grid-template-columns:70px 1fr 40px 40px 55px;gap:4px}
  .sh-td-date{font-size:12px}
}

/* ═══ ARTICLE CONFLICTS ═══ */
.aconf-list{display:flex;flex-direction:column;gap:10px;margin:10px 0}
.aconf-row{border:1px solid rgba(139,99,48,.2);border-radius:var(--r);overflow:hidden}
.aconf-name{font-size:15px;font-weight:700;color:var(--txt);padding:8px 12px;background:var(--warn-bg);
  display:flex;align-items:center;gap:6px;border-bottom:1px solid rgba(139,99,48,.15)}
.aconf-name i{color:var(--warn);font-size:14px}
.aconf-issues{display:flex;flex-direction:column}
.aconf-issue{display:flex;align-items:center;gap:10px;padding:7px 12px;border-bottom:1px solid var(--bg);font-size:14px}
.aconf-issue:last-child{border-bottom:0}
.aconf-issue-label{min-width:100px;font-weight:700;color:var(--txt);font-size:14px}
.aconf-issue-val{color:var(--txt-s);display:flex;align-items:center;gap:4px}
.aconf-issue-val i{font-size:12px}
.aconf-issue-day{background:rgba(192,57,43,.05)}
.aconf-issue-day .aconf-issue-label{color:var(--err)}
.aconf-issue-day .aconf-issue-val{color:var(--err)}
.aconf-issue-stock{background:rgba(139,99,48,.04)}
.aconf-issue-stock .aconf-issue-label{color:var(--brand)}
.aconf-issue-stock .aconf-issue-val{color:#8B6330}
.sel-row-conflict{background:var(--err-bg)!important;border-left:3px solid var(--err);border-radius:var(--r);animation:conflict-pulse .6s ease}
.efa-row.sel-row-conflict{background:var(--err-bg)!important;border-left:3px solid var(--err);border-radius:var(--r);animation:conflict-pulse .6s ease}
.conflict-btn{background:var(--err);color:#fff;border:none;border-radius:50%;width:22px;height:22px;
  font-size:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  margin-left:6px;vertical-align:middle;flex-shrink:0;transition:transform .15s ease}
.conflict-btn:hover{transform:scale(1.15)}
.conflict-btn:active{transform:scale(.95)}
@keyframes conflict-pulse{0%{opacity:.5}50%{opacity:1}100%{opacity:1}}

/* ═══ DISTRIBUCIÓ ═══ */
/* Step 1 */
.dist-s1-row{display:flex;gap:12px;margin-bottom:16px}
.dist-s1-card{background:var(--bg);border-radius:var(--rl);padding:18px 20px}
.dist-s1-label{font-size:13px;font-weight:700;color:var(--txt-s);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.dist-s1-label i{margin-right:4px}
.dist-select{margin-bottom:0;font-size:16px;height:44px;width:100%}
.dist-s1-demand-box{flex-shrink:0;width:110px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.dist-s1-demand-num{font-size:30px;font-weight:800;color:var(--brand);line-height:1}
.dist-s1-demand-unit{font-size:13px;font-weight:600;color:var(--txt-m);margin-top:2px}
.dist-qty-row{display:flex;align-items:center;justify-content:center;gap:8px}
.dist-qty-btn{width:48px;height:48px;font-size:24px;font-weight:700;border-radius:var(--r)}
.dist-qty-inp{width:72px;height:48px;text-align:center;font-size:26px;font-weight:800;border-radius:var(--r);color:var(--brand)}
/* Progress bar */
.dist-progress{margin-bottom:14px}
.dist-progress-info{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.dist-progress-label{font-size:15px;font-weight:600;color:var(--txt)}
.dist-progress-nums{font-size:14px;font-weight:700;color:var(--ok)}
.dist-progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;position:relative}
.dist-progress-fill{height:100%;border-radius:4px;transition:width .3s var(--ease),background .3s var(--ease)}
.dist-progress-fill.fill-partial{background:var(--brand)}
.dist-progress-fill.fill-exact{background:var(--ok)}
.dist-progress-fill.fill-over{background:var(--err)}
/* Header step 2 — row with info + surplus */
.dist-header{margin-bottom:14px}
.dist-hdr-row{display:flex;gap:12px;align-items:stretch}
.dist-hdr-card{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--brand-soft);border-radius:var(--r)}
.dist-hdr-icon{width:36px;height:36px;border-radius:50%;background:var(--brand);color:#fff;display:flex;
  align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.dist-hdr-text{flex:1;font-size:16px;color:var(--txt);line-height:1.4}
.dist-hdr-hl{font-weight:800;color:var(--brand)}
.dist-surplus-box{flex-shrink:0;width:100px;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:2px}
.dist-surplus-num{font-size:28px;font-weight:800;color:var(--brand);line-height:1}
/* Step 2 layout */
.dist-hidden{display:none!important}
.dist-step-2{display:flex;flex-direction:column;max-height:calc(80vh - 90px)}
.dist-fixed-top{flex-shrink:0}
/* Body: sidebar + list */
.dist-body{display:flex;gap:8px;min-height:0;flex:1;overflow:hidden;margin-bottom:14px}
/* Sidebar — icon-only buttons */
.dist-sidebar{display:flex;flex-direction:column;gap:6px;flex-shrink:0;padding-top:2px}
.dist-sug-btn{width:42px;height:42px;min-height:42px;padding:0;border-radius:var(--r);display:flex;
  align-items:center;justify-content:center;font-size:17px}
.dist-sug-btn.on{background:var(--brand);color:#fff;border-color:var(--brand)}
/* List */
.dist-list{display:grid;grid-template-columns:1fr 1fr;gap:6px;overflow-y:auto;
  min-height:0;align-content:start;padding:2px;flex:1}
@media(max-width:520px){.dist-list{grid-template-columns:1fr}}
/* Footer */
.dist-footer{flex-shrink:0}
/* Cards */
.dist-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1.5px solid var(--border);
  border-radius:var(--r);cursor:pointer;transition:all .15s var(--ease);user-select:none;
  border-left:3px solid var(--border);background:var(--surface)}
.dist-row:hover{border-color:var(--border-s)}
.dist-row:active{transform:scale(.985)}
.dist-row-sel{background:var(--brand-soft);border-color:var(--brand);border-left-color:var(--brand)}
.dist-chk{font-size:20px;color:var(--border-s);flex-shrink:0;transition:all .15s var(--ease)}
.dist-row-sel .dist-chk{color:var(--brand)}
.dist-row-mid{flex:1;min-width:0}
.dist-client{font-size:16px;font-weight:700;color:var(--txt);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dist-meta{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--txt-m);margin-top:2px}
.dist-meta i{font-size:12px}
.dist-row-qty{font-size:17px;font-weight:800;color:var(--brand);flex-shrink:0;min-width:28px;text-align:center;
  background:var(--bg);border-radius:6px;padding:4px 8px}
.dist-row-sel .dist-row-qty{background:var(--brand);color:#fff}
/* Badges */
.dist-badge{font-size:11px;font-weight:700;padding:1px 5px;border-radius:4px;letter-spacing:.3px;text-transform:uppercase}
.dist-badge-fix{background:var(--brand-soft);color:var(--brand)}
.dist-badge-dia{background:var(--bg);color:var(--txt-m)}
/* Actions */
.dist-act-main{height:48px;font-size:16px;width:100%;margin-bottom:6px;display:flex;align-items:center;justify-content:center;gap:6px}
.dist-act-main:disabled{opacity:.4;cursor:not-allowed}
.dist-act-sub{font-size:13px;text-align:center;color:var(--txt-m);margin-bottom:4px}
.dist-act-back{font-size:14px;width:100%;text-align:center}

/* ═══ FREQUENT ARTICLES ═══ */
.freq-list{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.freq-item{display:flex;flex-direction:column;gap:4px;
  padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  transition:opacity .2s}
.freq-item.freq-added{pointer-events:none;position:relative}
.freq-item.freq-added::after{content:'✓ Afegit';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.35);color:var(--brand);font-size:15px;font-weight:700;letter-spacing:.5px;border-radius:var(--r)}
.freq-item.freq-not-avail{opacity:.5;border-style:dashed;border-color:var(--warn)}
.freq-main{display:flex;align-items:center;justify-content:space-between;gap:8px}
.freq-name{font-size:15px;font-weight:600;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.freq-bottom{display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.freq-tag{font-size:12px;color:var(--txt-m);background:var(--bg);padding:2px 6px;border-radius:4px}
.freq-tag-warn{color:var(--warn);background:#fff3cd;font-weight:600}
.freq-acts{display:flex;align-items:center;gap:6px;flex-shrink:0}
.freq-add{height:36px !important;min-height:36px !important;width:36px;padding:0 !important;font-size:16px !important;
  display:flex !important;align-items:center;justify-content:center}
.freq-add:disabled{opacity:.4;cursor:default}
.freq-list + .bt{grid-column:1/-1}
.freq-item .stock-hint{font-size:12px;padding:2px 6px;border-radius:4px;background:var(--bg)}
@media(max-width:600px){.freq-list{grid-template-columns:1fr}}

/* ═══════ PIN GATE ═══════ */
.pin-wrap{text-align:center;padding:0}
.pin-header{background:var(--brand-dark);color:#fff;padding:20px 16px 16px;margin:-14px -18px 16px;
  border-radius:var(--rl) var(--rl) 0 0}
.pin-icon{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:22px}
.pin-title{font-size:18px;font-weight:700}
.pin-subtitle{font-size:14px;opacity:.7;margin-top:4px}
.pin-inputs{display:flex;gap:8px;justify-content:center;margin-bottom:12px}
.pin-digit{width:44px;height:52px;border:2px solid var(--border-s);border-radius:var(--r);
  text-align:center;font-size:24px;font-weight:700;color:var(--brand);background:var(--surface);
  transition:border-color .15s,box-shadow .15s;caret-color:var(--brand)}
.pin-digit:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(103,71,68,.12)}
.pin-digit.pin-active{border-color:var(--brand);box-shadow:0 0 0 3px rgba(103,71,68,.12)}
.pin-error{font-size:14px;font-weight:600;color:var(--err);min-height:18px}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-width:260px;margin:16px auto 0}
.pin-key{height:52px;border-radius:var(--r);border:1.5px solid var(--border-s);background:var(--surface);
  display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:600;color:var(--txt);
  cursor:pointer;transition:all .12s var(--ease);user-select:none;-webkit-tap-highlight-color:transparent}
.pin-key:hover{border-color:var(--brand);background:var(--brand-soft);color:var(--brand)}
.pin-key:active{transform:scale(.95);background:var(--brand-dark);color:#fff;border-color:var(--brand-dark)}
.pin-key-fn{font-size:18px;color:var(--txt-m);background:var(--bg);border-color:var(--border)}
.pin-key-fn:active{background:var(--brand);color:#fff;border-color:var(--brand)}
@keyframes pinShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-4px)}40%{transform:translateX(4px)}60%{transform:translateX(-3px)}80%{transform:translateX(2px)}}
.pin-shake{animation:pinShake .4s var(--ease);border-color:var(--err)!important}

/* ═══════════════════════════════════════════════
   MOBILE — phones only (≤640px)
   No changes above this width → tablets untouched
   ═══════════════════════════════════════════════ */
@media(max-width:640px){

  /* ── Layout: sidebar → bottom nav ── */
  .app{flex-direction:column}
  .side{width:100%;min-width:100%;height:52px;min-height:52px;flex-direction:row;
    padding:0;gap:0;order:2;border-top:1px solid rgba(255,255,255,.1)}
  .side-logo{display:none}
  .side-nav{flex-direction:row;gap:0;padding:0;width:100%;justify-content:space-evenly;align-items:center}
  .nav-i{height:52px;width:100%;font-size:16px;border-radius:0}
  .nav-i.on::before{left:50%;top:0;bottom:auto;transform:translateX(-50%);
    width:22px;height:3px;border-radius:0 0 3px 3px}
  .nav-sp{display:none}
  .nav-i.nav-out{display:none}

  .main{order:1;flex:1;min-height:0}
  .top{height:46px;min-height:46px;padding:0 14px;gap:10px}
  .top-t{font-size:15px}
  .page{padding:10px 10px 14px}

  /* ── Filter bars ── */
  .fbar{padding:8px 10px;gap:6px;border-radius:var(--r)}
  .fbar .inp{height:34px;font-size:12px}
  .fbar .bd{height:34px;min-height:34px;padding:0 10px;font-size:12px}
  .fbar .bt{height:34px;font-size:11px;padding:0 10px}
  .fsep{height:18px}
  .enc-search{max-width:160px;height:30px!important;font-size:12px!important}

  /* ── Encargo cards: stack vertical ── */
  .enc{flex-direction:column;border-left-width:3px}
  .enc-info{width:100%;min-width:0;padding:10px 12px;border-right:none;border-bottom:1px solid var(--border);
    flex-direction:row;align-items:center;gap:8px;justify-content:flex-start;flex-wrap:wrap}
  .enc-cli{font-size:13px}
  .enc-time{font-size:11px}
  .enc-cmt{font-size:10px;margin-top:0}
  .enc-created{top:4px;right:4px;font-size:9px;padding:1px 5px}
  .enc-arts-grid{grid-template-columns:1fr;gap:4px;padding:8px 10px}
  .fijo-side-actions{flex-direction:row;border-left:none;border-top:1px solid var(--border);
    padding:8px 10px;justify-content:flex-end}
  .fijo-act{width:38px;height:38px;font-size:14px}

  /* ── Enc single column height ── */
  .enc-single{height:calc(100dvh - 46px - 52px - 74px)}

  /* ── Form grid ── */
  .form-grid{grid-template-columns:1fr;gap:14px}

  /* ── Article form: stack columns ── */
  .af-form{flex-direction:column}
  .af-col-left{padding-right:0;border-right:none;border-bottom:1px solid var(--border);padding-bottom:12px}
  .af-col-right{width:100%;padding-left:0;padding-top:12px}

  /* ── Modals ── */
  .mo.center .mo-sheet{max-width:100%;margin:0 8px;max-height:85vh}
  .mo-h{padding:10px 14px;gap:8px}
  .mo-h h4{font-size:14px}
  .mo-b{padding:10px 14px}

  /* ── Time picker ── */
  .tp-body{width:300px;padding:10px;gap:8px}
  .tp-col-m{width:120px}
  .tp-btn{height:34px;font-size:12px}

  /* ── Item cards (clients, articles) ── */
  .item-card{padding:8px 10px;gap:8px}
  .item-card .ic-name{font-size:13px}
  .item-card .ic-actions{gap:4px;padding-left:6px}
  .item-card .ic-actions .fijo-act{width:36px;height:36px;font-size:13px}

  /* ── Article tabs ── */
  .art-tabs{gap:3px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:8px}
  .art-tab{font-size:11px;padding:5px 10px;white-space:nowrap}

  /* ── Stock ── */
  .stk-kpis{grid-template-columns:repeat(2,1fr);gap:6px}
  /* ── Stock: 2-line card rows ── */
  .rk-table.stk-table{overflow:hidden}
  .stk-thead{display:none}
  .stk-table .rk-row{
    display:grid;
    grid-template-columns:auto auto auto auto 1fr auto auto;
    grid-template-rows:auto auto;
    gap:4px 8px;
    align-items:center;
    padding:10px 12px;
    min-width:0}
  /* Row 1: name spans left, final right, act far right */
  .stk-td-name{grid-column:1/6;grid-row:1;flex:none}
  .stk-art-name{font-size:13px}
  .stk-td-final{grid-column:6;grid-row:1;font-size:22px;text-align:right;flex:none}
  .stk-td-act{grid-column:7;grid-row:1/3;width:auto;flex-direction:column;gap:3px}
  .stk-td-act .fijo-act{width:32px;height:32px;font-size:12px}
  /* Row 2: detail cells with labels */
  .stk-td.stk-td-stock{grid-column:1;grid-row:2;flex:none;flex-direction:column;gap:1px;font-size:13px;justify-content:flex-start}
  .stk-td.stk-td-enc{grid-column:2;grid-row:2;flex:none;flex-direction:column;gap:1px;font-size:13px;justify-content:flex-start}
  .stk-td.stk-td-botiga{grid-column:3;grid-row:2;flex:none;flex-direction:column;gap:1px;font-size:13px;justify-content:flex-start}
  .stk-td.stk-td-sacar{grid-column:4;grid-row:2;flex:none}
  .stk-td.stk-td-stock::before{content:'Stock';font-size:9px;font-weight:700;color:var(--txt-m);letter-spacing:.3px;text-transform:uppercase}
  .stk-td.stk-td-enc::before{content:'Enc.';font-size:9px;font-weight:700;color:var(--txt-m);letter-spacing:.3px;text-transform:uppercase}
  .stk-td.stk-td-botiga::before{content:'Botiga';font-size:9px;font-weight:700;color:var(--txt-m);letter-spacing:.3px;text-transform:uppercase}
  .stk-val-click{font-size:13px}
  .stk-val-click i{display:none}
  .rk-bar{flex-wrap:wrap}
  .rk-item{padding:8px 10px}
  .rk-num{font-size:16px}

  /* ── Stats ── */
  .stat-kpis{grid-template-columns:repeat(2,1fr)}
  .stat-card{min-width:0}

  /* ── Client summary ── */
  .cs-kpis{grid-template-columns:repeat(2,1fr)}

  /* ── Distribution modal ── */
  .dist-s1-row{flex-direction:column;gap:10px}
  .dist-s1-demand-box{width:100%}
  .dist-s1-demand-num{font-size:22px}
  .dist-list{grid-template-columns:1fr}
  .dist-hdr-row{flex-direction:column;gap:8px}
  .dist-surplus-box{width:100%;flex-direction:row;gap:8px}
  .dist-surplus-num{font-size:20px}

  /* ── Day chips ── */
  .dc div{width:36px;height:36px;font-size:11px}
  .dd span{width:24px;height:24px;font-size:9px}

  /* ── Qty stepper ── */
  .qs button{width:40px;height:38px;font-size:18px}
  .qs input{width:40px;font-size:16px}
  .qs-sm button{width:34px;height:34px;font-size:16px}
  .qs-sm input{width:34px;font-size:14px}

  /* ── Sel rows (form articles) ── */
  .sel-row{padding:8px 10px;gap:8px}
  .sel-row .name{font-size:13px}
  .sel-row .rm{width:34px;height:34px;font-size:12px}

  /* ── Toast ── */
  .toast-w{top:auto;bottom:62px;right:10px;left:10px}
  .toast-m{max-width:100%}

  /* ── Allergen/category manager ── */
  .al-mgr-view{gap:8px;padding:8px 10px}
  .al-mgr-icon{width:34px;height:34px;font-size:14px}
  .al-mgr-name{font-size:13px}

  /* ── Resumen modal table ── */
  .resum-grid{grid-template-columns:1fr!important}

  /* ── Stock history ── */
  .sh-thead,.sh-trow{grid-template-columns:60px 1fr 40px 40px 50px;gap:3px;font-size:11px}
}