/* ════════════════════════════════════════════
   SELECTOR DE PRODUCTOS (cuadros táctiles) — Producción
════════════════════════════════════════════ */
.prod-picker{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:14px}
.prod-chip{
  display:flex;align-items:center;gap:9px;
  border:2px solid var(--cream3);background:#fff;border-radius:14px;
  padding:10px 14px;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:600;
  color:var(--brown);transition:transform .13s,border-color .13s,box-shadow .13s;
}
.prod-chip .pc-emoji{font-size:1.35rem;line-height:1}
.prod-chip:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--sh)}
.prod-chip.sel{border-color:var(--orange);background:var(--cream);box-shadow:var(--sh)}
.prod-chip.sel::after{content:"✓";margin-left:2px;color:#fff;background:var(--orange);width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:.72rem;font-weight:800}
.prod-picker-more{align-self:center;color:var(--gray);font-size:.82rem;font-weight:600}
.viewer-mode .prod-picker{display:none}

/* ════════════════════════════════════════════
   VARIABLES & RESET
════════════════════════════════════════════ */
:root{
  --cream:#FFF8F0;--cream2:#F0E4D4;--cream3:#E8D8C8;
  --brown:#3D1A06;--brown2:#7A3B12;--brown3:#5C2E0A;
  --orange:#C8511A;--orange2:#E07040;--orange3:#F08050;
  --green:#2D6A4F;--green2:#52B788;
  --blue:#1A4A7A;--blue2:#4A90C4;
  --red:#9B2335;--gold:#C8920A;--gray:#7A6E68;
  --sh:0 2px 12px rgba(61,26,6,.1);
  --sh2:0 4px 24px rgba(61,26,6,.14);
  --r:16px;--r2:10px;--r3:8px;
  --nav-h:64px;--header-h:56px;
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--cream);
  color:var(--brown);
  min-height:100vh;
  max-width:100vw;
  overflow-x:hidden;
}
button{font-family:'DM Sans',sans-serif;cursor:pointer}
input,select,textarea{font-family:'DM Sans',sans-serif}

/* ════════════════════════════════════════════
   LOGIN
════════════════════════════════════════════ */
#login-overlay{
  position:fixed;inset:0;
  background:linear-gradient(160deg,var(--brown) 0%,#6B2E10 60%,#8B4513 100%);
  z-index:500;display:flex;align-items:center;justify-content:center;
  padding:24px;
}
#login-box{
  background:rgba(255,248,240,.97);
  border-radius:24px;
  padding:40px 32px;
  width:100%;max-width:360px;
  text-align:center;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}
.login-logo{
  width:68px;height:68px;
  background:linear-gradient(135deg,var(--orange),var(--brown2));
  border-radius:20px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:2rem;margin-bottom:18px;
  box-shadow:0 6px 20px rgba(200,81,26,.35);
}
#login-box h2{
  font-family:'Playfair Display',serif;
  font-size:1.8rem;color:var(--brown);margin-bottom:4px;
}
#login-box p{color:var(--gray);font-size:.88rem;margin-bottom:28px}
.login-input{
  width:100%;padding:14px 16px;
  border:2px solid var(--cream3);
  border-radius:12px;
  font-size:1rem;margin-bottom:12px;
  outline:none;transition:border-color .2s;
  background:var(--cream);color:var(--brown);
}
.login-input:focus{border-color:var(--orange);background:#fff}
.login-btn{
  width:100%;padding:14px;
  background:linear-gradient(135deg,var(--orange),var(--brown2));
  color:#fff;border:none;border-radius:12px;
  font-size:1rem;font-weight:600;
  box-shadow:0 4px 16px rgba(200,81,26,.4);
  transition:all .2s;
}
.login-btn:active{transform:scale(.98);opacity:.9}
#login-err{color:var(--red);font-size:.82rem;margin-top:10px;min-height:18px}

/* ════════════════════════════════════════════
   HEADER FIJO
════════════════════════════════════════════ */
#app-header{
  position:fixed;top:0;left:0;right:0;
  height:var(--header-h);z-index:90;
  background:var(--brown);
  display:flex;align-items:center;
  padding:0 16px;gap:12px;
  box-shadow:0 2px 12px rgba(0,0,0,.2);
}
#header-title{
  font-family:'Playfair Display',serif;
  color:var(--cream);font-size:1.25rem;
  flex:1;
}
#header-sub{
  font-size:.65rem;font-weight:600;
  color:var(--orange2);letter-spacing:.1em;
  text-transform:uppercase;display:block;line-height:1.2;
}
.sync-pill{
  display:flex;align-items:center;gap:5px;
  padding:5px 10px;border-radius:20px;
  background:rgba(255,255,255,.1);
  font-size:.68rem;color:rgba(255,255,255,.7);font-weight:500;
}
.sdot{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:var(--green2)}
.sdot.off{background:var(--red)}.sdot.sync{background:var(--gold);animation:blink .7s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
#role-pill{
  padding:4px 10px;border-radius:20px;
  font-size:.7rem;font-weight:700;
}
#role-pill.admin{background:rgba(200,81,26,.25);color:var(--orange3)}
#role-pill.viewer{background:rgba(74,144,196,.25);color:#90CAF9}

/* ════════════════════════════════════════════
   MAIN CONTENT AREA
════════════════════════════════════════════ */
#main{
  margin-top:var(--header-h);
  padding-bottom:calc(var(--nav-h) + 12px + var(--safe-bottom));
  min-height:calc(100vh - var(--header-h));
}
.page{display:none}.page.active{display:block}

/* ════════════════════════════════════════════
   BOTTOM NAV
════════════════════════════════════════════ */
#bottom-nav{
  position:fixed;bottom:0;left:0;right:0;
  height:calc(var(--nav-h) + var(--safe-bottom));
  background:var(--brown);
  display:flex;align-items:stretch;
  padding-bottom:var(--safe-bottom);
  z-index:90;
  box-shadow:0 -2px 16px rgba(0,0,0,.25);
}
.nav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:8px 4px;cursor:pointer;
  border:none;background:transparent;
  transition:all .15s;
  position:relative;
}
.nav-item::after{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:0;height:2px;background:var(--orange);
  border-radius:0 0 3px 3px;transition:width .2s;
}
.nav-item.active::after{width:60%}
.nav-item.active .nav-ico{color:var(--orange3)}
.nav-item.active .nav-lbl{color:#fff}
.nav-ico{font-size:1.25rem;color:rgba(255,255,255,.45);transition:color .15s;line-height:1}
.nav-lbl{font-size:.6rem;font-weight:600;color:rgba(255,255,255,.4);
  text-transform:uppercase;letter-spacing:.04em;line-height:1;transition:color .15s}

/* ════════════════════════════════════════════
   PAGE HEADERS
════════════════════════════════════════════ */
.page-header{padding:20px 16px 0}
.ptitle{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--brown);line-height:1.2}
.psub{color:var(--gray);font-size:.82rem;margin-top:4px;margin-bottom:16px}

/* ════════════════════════════════════════════
   CARDS
════════════════════════════════════════════ */
.card{
  background:#fff;border-radius:var(--r);
  box-shadow:var(--sh);padding:16px;
  margin:0 12px 14px;
}
.card-title{
  font-family:'Playfair Display',serif;
  font-size:.95rem;color:var(--brown);
  margin-bottom:14px;
  display:flex;align-items:center;gap:7px;
}

/* ════════════════════════════════════════════
   FORMS
════════════════════════════════════════════ */
.fg{display:flex;flex-direction:column;gap:5px;min-width:0}
.fg label{
  font-size:.68rem;font-weight:700;
  color:var(--brown2);text-transform:uppercase;letter-spacing:.07em;
}
.fg input,.fg select,.fg textarea{
  padding:11px 12px;
  border:2px solid var(--cream3);
  border-radius:var(--r3);
  font-size:.9rem;color:var(--brown);
  background:var(--cream);outline:none;
  transition:border-color .15s,background .15s;
  -webkit-appearance:none;
}
.fg input:focus,.fg select:focus{border-color:var(--orange);background:#fff}
.ac-list{
  position:fixed;z-index:9999;display:none;
  max-height:210px;overflow:auto;
  background:#fff;border:2px solid var(--cream3);
  border-radius:10px;box-shadow:0 10px 28px rgba(74,44,30,.16);
  padding:4px;
}
.ac-list.open{display:block}
.ac-item{
  padding:9px 10px;border-radius:7px;
  font-size:.88rem;color:var(--brown);cursor:pointer;
}
.ac-item:hover,.ac-item.active{background:var(--cream2);color:var(--orange)}
.ac-empty{
  padding:9px 10px;font-size:.82rem;color:var(--gray);
}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.fgrid.one{grid-template-columns:1fr}
.fgrid.three{grid-template-columns:1fr 1fr 1fr}

/* ════════════════════════════════════════════
   BUTTONS
════════════════════════════════════════════ */
.btn{
  padding:11px 20px;border:none;border-radius:var(--r3);
  font-size:.88rem;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  transition:all .15s;-webkit-tap-highlight-color:transparent;
}
.btn:active{transform:scale(.97)}
.bp{background:var(--orange);color:#fff;box-shadow:0 3px 10px rgba(200,81,26,.3)}
.bg2{background:var(--green);color:#fff;box-shadow:0 3px 10px rgba(45,106,79,.25)}
.bb{background:var(--blue);color:#fff;box-shadow:0 3px 10px rgba(26,74,122,.25)}
.br{background:var(--red);color:#fff}
.bgold{background:var(--gold);color:#fff}
.bsec{background:var(--cream2);color:var(--brown)}
.bsm{padding:7px 12px;font-size:.78rem}
.btn-full{width:100%;justify-content:center}
.ocr-panel{
  border:1.5px solid var(--cream3);
  background:var(--cream);
  border-radius:var(--r3);
  padding:12px;
  margin-bottom:14px;
}
.ocr-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.ocr-file{
  width:100%;padding:10px 12px;border:2px dashed var(--cream3);
  border-radius:var(--r3);background:#fff;color:var(--brown);
  font-size:.86rem;
}
.ocr-file-hidden{display:none}
.ocr-selected{
  margin-top:8px;padding:8px 10px;border-radius:var(--r3);
  background:#fff;border:1.5px solid var(--cream3);
  color:var(--gray);font-size:.78rem;
}
.ocr-status{
  display:none;margin-top:10px;padding:9px 10px;border-radius:var(--r3);
  background:#fff;color:var(--gray);font-size:.78rem;line-height:1.35;
}
.ocr-status.show{display:block}
.ocr-status.ok{color:var(--green);border:1px solid rgba(45,106,79,.25)}
.ocr-status.warn{color:var(--gold);border:1px solid rgba(200,146,10,.28)}
.ocr-status.err{color:var(--red);border:1px solid rgba(155,35,53,.24)}

/* ════════════════════════════════════════════
   STAT CARDS (DASHBOARD)
════════════════════════════════════════════ */
.stats-row{
  display:grid;grid-template-columns:1fr 1fr;
  gap:10px;padding:0 12px;margin-bottom:14px;
}
.scard{
  background:#fff;border-radius:var(--r);
  padding:14px 16px;box-shadow:var(--sh);
  border-top:3px solid var(--orange);
}
.scard.g{border-top-color:var(--green)}
.scard.b{border-top-color:var(--blue)}
.scard.gd{border-top-color:var(--gold)}
.slbl{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gray)}
.sval{font-family:'Playfair Display',serif;font-size:1.7rem;color:var(--brown);line-height:1.1;margin-top:2px}
.ssub{font-size:.68rem;color:var(--gray);margin-top:1px}

/* ════════════════════════════════════════════
   TABS
════════════════════════════════════════════ */
.tabs{
  display:flex;gap:2px;
  padding:0 12px;margin-bottom:14px;
  border-bottom:2px solid var(--cream2);
}
.tab{
  padding:10px 16px;cursor:pointer;
  font-size:.82rem;font-weight:600;color:var(--gray);
  border-bottom:2px solid transparent;margin-bottom:-2px;
  transition:all .15s;white-space:nowrap;
}
.tab.active{color:var(--orange);border-bottom-color:var(--orange)}
.tc{display:none}.tc.active{display:block}

/* ════════════════════════════════════════════
   TABLES — SCROLL HORIZONTAL EN MÓVIL
════════════════════════════════════════════ */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:-4px}
table{width:100%;border-collapse:collapse;font-size:.78rem;min-width:520px}
thead th{
  background:var(--brown);color:#fff;
  padding:9px 10px;text-align:left;
  font-weight:600;font-size:.68rem;
  text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;
}
tbody tr{border-bottom:1px solid #F0E4D4;transition:background .1s}
tbody tr:hover{background:#FFF3E8}
tbody td{padding:8px 10px;color:var(--brown);vertical-align:middle}
.empty{text-align:center;padding:24px;color:var(--gray);font-size:.85rem}

/* ════════════════════════════════════════════
   BADGE
════════════════════════════════════════════ */
.badge{
  display:inline-block;padding:2px 9px;
  border-radius:20px;font-size:.68rem;font-weight:600;white-space:nowrap;
}
.bpan{background:#F5E6D3;color:var(--brown2)}
.bpast{background:#D6EAD8;color:var(--green)}
.bins{background:#FFF0E0;color:var(--orange)}
.bsal{background:#E3EEF9;color:var(--blue)}

/* ════════════════════════════════════════════
   LÍNEAS MÚLTIPLES (INSUMOS)
════════════════════════════════════════════ */
.row-ins{
  background:var(--cream);border:1.5px solid var(--cream3);
  border-radius:var(--r3);padding:12px;
  margin-bottom:10px;
}
.row-ins .fgrid{margin-bottom:8px}
.row-ins-del{
  width:100%;padding:7px;border:none;
  background:#FFECEC;color:var(--red);
  border-radius:var(--r3);font-size:.78rem;font-weight:600;cursor:pointer;
}

/* ════════════════════════════════════════════
   INVENTARIO — BARRAS
════════════════════════════════════════════ */
.ibar{display:flex;align-items:center;gap:6px}
.bar{height:5px;border-radius:3px;background:#E8D8C8;flex:1;overflow:hidden;min-width:40px}
.barfill{height:100%;border-radius:3px;background:var(--green2);transition:width .3s}
.barfill.low{background:var(--red)}.barfill.mid{background:var(--gold)}
.stock-red{color:var(--red)!important;font-weight:700}
.stock-gold{color:var(--gold)!important;font-weight:700}

/* ════════════════════════════════════════════
   INVENTORY CARDS (MODO MÓVIL)
════════════════════════════════════════════ */
.inv-card{
  background:#fff;border-radius:var(--r2);
  border:1.5px solid var(--cream3);
  padding:12px 14px;margin-bottom:8px;
}
.inv-card.low-stock{background:#FFF5F5;border-color:#FFCDD2}
.inv-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.inv-card-name{font-weight:600;font-size:.9rem;color:var(--brown)}
.inv-card-row{display:flex;gap:8px;margin-bottom:8px;align-items:end}
.inv-card-row .fg{flex:1}
.inv-mini-input{
  padding:8px 10px;border:2px solid var(--cream3);
  border-radius:var(--r3);font-size:.85rem;color:var(--brown);
  background:var(--cream);outline:none;width:100%;
  transition:border-color .15s;-webkit-appearance:none;
}
.inv-mini-input:focus{border-color:var(--orange);background:#fff}

/* ════════════════════════════════════════════
   INVENTARIO — VISTA MEJORADA
════════════════════════════════════════════ */
.inv-toolbar{
  display:flex;gap:8px;align-items:center;
  padding:0 12px 12px;flex-wrap:wrap;
}
.inv-search{
  flex:1;min-width:140px;
  padding:9px 12px 9px 34px;
  border:2px solid var(--cream3);border-radius:var(--r3);
  font-size:.88rem;color:var(--brown);background:var(--cream);
  outline:none;transition:border-color .15s;
  font-family:'DM Sans',sans-serif;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237A6E68' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:10px center;
}
.inv-search:focus{border-color:var(--orange);background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23C8511A' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E")}
.inv-sort-btn{
  padding:8px 12px;border:2px solid var(--cream3);border-radius:var(--r3);
  background:var(--cream);color:var(--brown);font-size:.78rem;font-weight:600;
  cursor:pointer;white-space:nowrap;font-family:'DM Sans',sans-serif;
  transition:all .15s;
}
.inv-sort-btn.active{border-color:var(--orange);color:var(--orange);background:#FFF0E8}
.inv-summary-table{width:100%;border-collapse:collapse;font-size:.82rem}
.inv-summary-table th{
  padding:8px 10px;text-align:left;font-size:.65rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.07em;color:var(--gray);
  border-bottom:2px solid var(--cream3);background:var(--cream);
  position:sticky;top:0;
}
.inv-summary-row{cursor:pointer;transition:background .12s}
.inv-summary-row:hover{background:#FFF0E8}
.inv-summary-row.low-row{background:#FFF5F5}
.inv-summary-row.low-row:hover{background:#FFECEC}
.inv-summary-row td{
  padding:9px 10px;border-bottom:1px solid var(--cream3);
  vertical-align:middle;
}
.inv-name-main{font-weight:600;color:var(--brown);font-size:.84rem;line-height:1.3}
.inv-name-sub{font-size:.68rem;color:var(--gray);margin-top:1px}
.inv-stock-val{font-weight:700;font-size:.92rem}
.inv-stock-ok{color:var(--green)}
.inv-stock-low{color:var(--red)}
.inv-stock-mid{color:var(--gold)}
.inv-bar-sm{height:5px;border-radius:3px;background:var(--cream3);overflow:hidden;margin-top:3px;min-width:50px}
.inv-bar-sm-fill{height:100%;border-radius:3px;transition:width .3s}
.inv-edit-panel{display:none}
.inv-edit-panel.open{display:table-row}
.inv-edit-inner{
  padding:12px 10px;background:var(--cream);
  border-bottom:2px solid var(--orange);
  display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;
}
.inv-edit-inner .fg{min-width:72px;flex:1}
.inv-count-badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 5px;
  background:var(--red);color:#fff;
  border-radius:9px;font-size:.62rem;font-weight:700;
  margin-left:5px;vertical-align:middle;
}

/* ════════════════════════════════════════════
   MODAL
════════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);
  z-index:200;display:none;
  align-items:flex-end;justify-content:center;
}
.modal-overlay.open{display:flex}
.modal{
  background:#fff;
  border-radius:24px 24px 0 0;
  padding:24px 20px;
  width:100%;max-height:90vh;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  box-shadow:0 -8px 40px rgba(0,0,0,.2);
}
/* En tablet/desktop: modal centrado */
@media(min-width:640px){
  .modal-overlay{align-items:center}
  .modal{border-radius:24px;max-width:560px;max-height:85vh}
}
.modal h2{
  font-family:'Playfair Display',serif;
  font-size:1.15rem;margin-bottom:16px;color:var(--brown);
}
.modal-handle{
  width:40px;height:4px;background:var(--cream3);
  border-radius:2px;margin:0 auto 20px;
}

/* ════════════════════════════════════════════
   TOAST
════════════════════════════════════════════ */
#toast{
  position:fixed;bottom:calc(var(--nav-h) + 16px + var(--safe-bottom));
  left:50%;transform:translateX(-50%) translateY(10px);
  background:var(--green);color:#fff;
  padding:12px 22px;border-radius:var(--r2);
  font-size:.85rem;font-weight:600;
  box-shadow:0 4px 20px rgba(0,0,0,.2);
  opacity:0;transition:all .25s;z-index:999;
  white-space:nowrap;pointer-events:none;
}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ════════════════════════════════════════════
   VIEWER MODE
════════════════════════════════════════════ */
body.viewer-mode .edit-btn,
body.viewer-mode .del-btn,
body.viewer-mode .form-card,
body.viewer-mode #btn-save-cats,
body.viewer-mode .inv-save-btn,
body.viewer-mode .add-line-btn,
body.viewer-mode .dash-actions{display:none!important}

/* Inventario — viewer: no abrir panel de edición, ocultar botón guardar */
body.viewer-mode .inv-summary-row{cursor:default!important}
body.viewer-mode .inv-edit-panel{display:none!important}

/* Catálogos — viewer: inputs de nombres de productos en solo lectura */
body.viewer-mode .cat-item input{
  pointer-events:none;background:transparent!important;
  border-color:transparent!important;color:var(--brown)!important;
  -webkit-appearance:none;cursor:default;
}
/* Catálogos — viewer: ocultar secciones de agregar encargados/destinos */
body.viewer-mode .add-item-row{display:none!important}
body.viewer-mode .cat-add-row{display:none!important}

/* Widget Doraemon: oculto por defecto (incluye pantalla de login); solo visible para admin */
body.admin-mode #doraemon-widget{display:block}

/* ── Intro splash (solo admin) ── */
#intro-overlay{
  display:none;
  position:fixed;
  inset:0;
  z-index:20000;
  background:var(--brown);
  align-items:center;
  justify-content:center;
}
#intro-overlay.active{display:flex}
#intro-overlay.fade-out{animation:introFadeOut .6s ease-out forwards}
@keyframes introFadeOut{to{opacity:0}}
#intro-canvas{
  max-width:100%;
  max-height:100%;
  width:auto;
  height:auto;
}

/* ════════════════════════════════════════════
   DASHBOARD ESPECÍFICO
════════════════════════════════════════════ */
.dash-actions{
  display:flex;flex-direction:column;gap:8px;
  padding:0 12px;margin-bottom:14px;
}
.report-range{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
  padding:10px;border:1px solid var(--cream3);
  background:var(--cream);border-radius:var(--r3);
}
.report-range label{
  display:flex;flex-direction:column;gap:4px;
  font-size:.72rem;color:var(--gray);font-weight:700;
}
.report-range input{
  padding:8px 10px;border:2px solid var(--cream3);
  border-radius:var(--r3);background:#fff;color:var(--brown);
  font-family:'DM Sans',sans-serif;font-size:.82rem;outline:none;
}
.report-range input:focus{border-color:var(--orange)}
@media(min-width:480px){
  .dash-actions{flex-direction:row;flex-wrap:wrap}
  .dash-actions .btn{flex:1;min-width:140px}
  .dash-actions .report-range{flex:1 1 100%}
}
#dash-fecha{
  font-size:.78rem;color:var(--gray);
  padding:0 12px;margin-bottom:12px;
  font-style:italic;
}

/* ════════════════════════════════════════════
   CATÁLOGOS
════════════════════════════════════════════ */
.cat-section{
  background:#fff;border-radius:var(--r);
  box-shadow:var(--sh);padding:16px;
  margin:0 12px 14px;
}
.cat-title{
  font-family:'Playfair Display',serif;
  font-size:.95rem;padding-bottom:10px;
  border-bottom:2px solid var(--cream2);margin-bottom:12px;
}
.cat-search{
  width:100%;padding:9px 12px;margin:0 0 12px;
  border:2px solid var(--cream3);border-radius:var(--r3);
  background:var(--cream);color:var(--brown);outline:none;
  font-family:'DM Sans',sans-serif;font-size:.84rem;
}
.cat-search:focus{background:#fff;border-color:var(--orange)}
.cat-empty{
  color:var(--gray);font-size:.82rem;
  padding:10px 2px;text-align:center;
}
.cat-items-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
}
@media(min-width:720px){
  .cat-items-grid{grid-template-columns:1fr 1fr}
}
.cat-item{
  display:flex;align-items:center;gap:5px;
  padding:4px 6px;
  border:1px solid var(--cream2);
  border-radius:6px;
  background:var(--cream);
  font-size:.82rem;
  min-width:0;
}
.cat-item input{
  flex:1;border:none;background:transparent;
  font-family:'DM Sans',sans-serif;font-size:.78rem;
  color:var(--brown);outline:none;padding:1px 2px;
  border-radius:4px;min-width:0;
}
.cat-item input:focus{background:#fff;padding:1px 6px}
.cat-item input[data-cat-unit]{
  flex:.7;color:var(--brown2);
  border-left:1px solid var(--cream3);
  padding-left:6px;
}
.cat-unit-card{
  display:grid;
  grid-template-columns:18px minmax(120px,1.1fr) minmax(88px,.7fr) minmax(180px,1.4fr) auto;
  align-items:start;
  gap:6px;
}
.cat-unit-card textarea{
  width:100%;min-height:38px;resize:vertical;
  border:1px solid var(--cream3);border-radius:6px;
  background:#fff;color:var(--brown);font-size:.72rem;
  font-family:'DM Sans',sans-serif;padding:5px 7px;outline:none;
}
.cat-unit-card textarea:focus{border-color:var(--orange)}
.cat-base-wrap,.cat-equiv-wrap{display:flex;flex-direction:column;gap:2px;min-width:0}
.cat-mini-label{font-size:.62rem;color:var(--gray);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
@media(max-width:620px){
  .cat-unit-card{grid-template-columns:18px 1fr}
  .cat-base-wrap,.cat-equiv-wrap{grid-column:2}
  .cat-unit-card button{grid-column:2;justify-self:flex-start}
}
.cat-item-num{
  color:var(--gray);font-size:.65rem;
  width:16px;text-align:right;flex-shrink:0;
}
.add-item-row{
  display:flex;gap:8px;margin-top:10px;
}
.add-item-input{
  flex:1;padding:8px 12px;
  border:2px solid var(--cream3);border-radius:var(--r3);
  font-size:.85rem;color:var(--brown);background:var(--cream);outline:none;
}
.add-item-input:focus{border-color:var(--orange);background:#fff}
.add-item-btn{
  padding:8px 14px;border:none;border-radius:var(--r3);
  font-size:.8rem;font-weight:600;cursor:pointer;color:#fff;
}

/* ════════════════════════════════════════════
   RESPONSIVE: TABLET/DESKTOP
════════════════════════════════════════════ */
@media(min-width:768px){
  /* Sidebar en tablet+ */
  #sidebar-desktop{
    position:fixed;top:0;left:0;width:220px;height:100vh;
    background:var(--brown);z-index:95;
    display:flex;flex-direction:column;
  }
  #bottom-nav{display:none}
  #app-header{left:220px}
  #main{margin-left:220px}

  .stats-row{grid-template-columns:repeat(5,1fr)}
  .fgrid{grid-template-columns:repeat(3,1fr)}
  table{min-width:unset}

  .modal-overlay{align-items:center}
  .modal{border-radius:24px;max-width:580px}
  .modal-handle{display:none}
}
@media(max-width:767px){
  #sidebar-desktop{display:none}
}

/* Sidebar desktop estilos */
#sidebar-desktop{display:none}
@media(min-width:768px){
  #sidebar-desktop{display:flex}
  #sd-logo{padding:22px 18px 16px;border-bottom:1px solid rgba(255,255,255,.1)}
  #sd-logo h1{font-family:'Playfair Display',serif;color:var(--cream);font-size:1.4rem}
  #sd-logo p{color:var(--orange2);font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-top:3px}
  .sd-sync{padding:8px 18px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:6px;font-size:.7rem;color:rgba(255,255,255,.5)}
  #sd-nav{flex:1;padding:12px 0;overflow-y:auto}
  .sni{
    display:flex;align-items:center;gap:10px;padding:11px 18px;
    color:rgba(255,255,255,.6);cursor:pointer;font-size:.84rem;font-weight:500;
    transition:all .15s;border-left:3px solid transparent;border:none;background:none;
    width:100%;text-align:left;
  }
  .sni:hover{color:#fff;background:rgba(255,255,255,.07)}
  .sni.active{color:#fff;background:rgba(200,81,26,.2);border-left:3px solid var(--orange)}
  .sni-ico{font-size:1rem;width:20px;text-align:center;flex-shrink:0}
  #sd-date{padding:12px 18px;border-top:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.35);font-size:.7rem}
  #sd-role{padding:8px 18px;border-top:1px solid rgba(255,255,255,.1)}
}

/* Utilidades */
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}
.gap8{gap:8px}.flex{display:flex}.flex-row{display:flex;flex-direction:row}
.row-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}

#doraemon-widget{
  display:none;
  position:fixed;
  bottom:90px;
  right:18px;
  width:160px;
  height:160px;
  z-index:99999;
  cursor:grab;
  user-select:none;
  touch-action:none;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.35));
  transition:filter .15s;
  transform-origin:bottom right;
}
#doraemon-widget:active{cursor:grabbing;filter:drop-shadow(0 6px 16px rgba(0,0,0,.45));}
#doraemon-widget.excited{
  animation:doraExcited 3s ease-in-out forwards;
  filter:drop-shadow(0 10px 30px rgba(0,0,0,.6)) !important;
  cursor:default !important;
}
@keyframes doraExcited{
  0%  {transform:scale(1) rotate(0)}
  8%  {transform:scale(2.1) rotate(-6deg)}
  20% {transform:scale(2) rotate(4deg) translateY(-14px)}
  35% {transform:scale(2.05) rotate(-5deg) translateY(-22px)}
  50% {transform:scale(2) rotate(6deg) translateY(-12px)}
  65% {transform:scale(2.1) rotate(-4deg) translateY(-20px)}
  80% {transform:scale(2) rotate(3deg) translateY(-8px)}
  90% {transform:scale(1.35) rotate(-1deg)}
  100%{transform:scale(1) rotate(0)}
}
.latas-wrap{display:flex;align-items:center;gap:6px;}
.latas-wrap input{flex:1;min-width:0;}
.latas-x{font-weight:700;color:var(--brown);font-size:1.1rem;flex-shrink:0;}
#doraemon-video{
  width:100%;
  height:100%;
  display:block;
  pointer-events:none;
}
