:root {
  /* COLORS & CONSTANTS */
  --primary: #10b981;
  --primary-dim: rgba(16, 185, 129, 0.15);
  --verde-vivo: #10b981;
  --verde-glow: rgba(16, 185, 129, 0.25);
  --amarillo: #f59e0b;
  --amarillo-dim: rgba(245, 158, 11, 0.15);
  --rojo: #ef4444;
  --rojo-dim: rgba(239, 68, 68, 0.15);
  --azul: #3b82f6;
  --azul-dim: rgba(59, 130, 246, 0.15);
  --font: 'Inter', system-ui, -apple-system, sans-serif;
  
  /* DEFAULT THEME: DARK (Mobile/Warehouse) */
  --bg: #0f172a;
  --bg-deep: #020617;
  --card: #1e293b;
  --card2: #0f172a;
  --borde: #334155;
  --borde2: #475569;
  --texto: #f8fafc;
  --texto2: #cbd5e1;
  --texto3: #94a3b8;
  --sombra: 0 4px 12px rgba(0,0,0,0.3);
  --sombra-lg: 0 20px 40px rgba(0,0,0,0.4);
  
  /* Aliases */
  --text: var(--texto);
  --text-muted: var(--texto3);
  --surface: var(--card);
  --border: var(--borde);
}

/* RESPONSIVE THEME: LIGHT (Desktop/Office) */
@media (min-width: 1024px) {
  :root {
    --bg: #f8fafc;
    --bg-deep: #f1f5f9;
    --card: #ffffff;
    --card2: #f1f5f9;
    --borde: #e2e8f0;
    --borde2: #cbd5e1;
    --texto: #0f172a;
    --texto2: #334155;
    --texto3: #64748b;
    --sombra: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
    --sombra-lg: 0 10px 25px -5px rgba(0, 0, 0, 0.08);

    /* En modo claro, el primary puede ser un poco más oscuro para mejor contraste */
    --primary: #059669; 
  }
}

.btn-refresh-big {
  width: calc(100% - 32px);
  margin: 8px 16px 4px;
  padding: 8px 12px;
  background: var(--card);
  border: 1px solid var(--borde2);
  border-radius: 10px;
  color: var(--primary);
  font-family: var(--font);
  font-weight: 800;
  font-size: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  transition: all 0.2s;
  text-decoration: none;
  outline: none;
}
.btn-refresh-big:active {
  transform: scale(0.98);
  background: var(--card2);
}
.btn-refresh-big svg {
  stroke: var(--primary);
}

/* Dark mode on mobile devices (or fallback) */
@media (max-width: 480px) {
  :root {
    --verde: #059669;
    --verde-vivo: #34d399;
    --verde-dim: #064e3b;
    --verde-glow: rgba(52, 211, 153, 0.25);
    --negro: #0f172a; /* Slate 900 */
    --panel: rgba(30, 41, 59, 0.95); /* Slate 800 */
    --card: #1e293b;
    --card2: #334155; /* Slate 700 */
    --borde: #334155;
    --borde2: #475569; /* Slate 600 */
    --texto: #f8fafc;
    --texto2: #cbd5e1;
    --texto3: #94a3b8;
    --amarillo: #fbbf24;
    --amarillo-dim: rgba(251, 191, 36, 0.15);
    --rojo: #f87171;
    --rojo-dim: rgba(248, 113, 113, 0.15);
    --azul: #60a5fa;
    --azul-dim: rgba(96, 165, 250, 0.15);

    /* Aliases must be redefined here too */
    --primary: #34d399;
    --surface: #1e293b;
    --bg: #0f172a;
    --border: #334155;
    --text: #f8fafc;
    --text-muted: #94a3b8;
  }
}
* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
body {
  background: var(--negro);
  background-image: radial-gradient(circle at 15% 50%, rgba(16, 185, 129, 0.08), transparent 30%), radial-gradient(circle at 85% 10%, rgba(59, 130, 246, 0.08), transparent 30%);
  color: var(--texto);
  font-family: var(--font);
  height: 100dvh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  overscroll-behavior: none;
  -webkit-font-smoothing: antialiased;
}

.lang-chip {
  min-width: 55px;
  height: 55px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 18px;
  font-size: 1.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
  box-shadow: var(--sombra);
}
.lang-chip.active {
  background: var(--primary-dim);
  border: 2px solid var(--primary);
  transform: scale(1.1);
}
.lang-chip:active {
  transform: scale(0.95);
}

/* HEADER */
header {
  background: var(--panel);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--borde);
  padding: 12px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
  position: relative;
  z-index: 10;
}
header::after {
  content: '';
  position: absolute;
  bottom: 0; left: 16px; right: 16px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--verde-vivo), transparent);
  opacity: 0.6;
}
.logo { display:flex; align-items:center; gap:10px; }
.logo-img { height:30px; width:auto; opacity:0.85; }
.logo-text { font-family:'Outfit', sans-serif; font-weight:800; font-size:1.1rem; letter-spacing:0.05em; text-transform:uppercase; background: linear-gradient(135deg, var(--verde-vivo) 0%, var(--azul) 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.logo-sub { font-family:'DM Mono',monospace; font-size:0.55rem; letter-spacing:0.15em; color:var(--texto3); display:block; margin-top:-2px; }
.header-right { display:flex; align-items:center; gap:12px; }
.sync-btn { background:var(--card); border:1px solid var(--borde); border-radius:20px; padding:6px 12px; font-size:0.7rem; font-family:'DM Mono',monospace; font-weight: 500; color:var(--texto3); cursor:pointer; display:flex; align-items:center; gap:6px; transition:var(--transicion-rapida); box-shadow: var(--sombra-sm); }
.sync-btn:hover { border-color:var(--verde-vivo); color:var(--verde-vivo); transform: translateY(-1px); box-shadow: var(--sombra-md); }
.status-dot { width:6px; height:6px; border-radius:50%; background:var(--texto3); flex-shrink:0; }
.status-dot.online { background:var(--verde-vivo); box-shadow:0 0 6px var(--verde-vivo); }
.status-dot.error { background:var(--rojo); }

/* ALERTAS BANNER */
.alert-banner {
  background: var(--rojo-dim);
  border-bottom: 1px solid rgba(192,57,43,0.3);
  padding: 8px 16px;
  display: none;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  cursor: pointer;
}
.alert-banner.visible { display:flex; }
.alert-icon { font-size:1rem; }
.alert-text { font-size:0.75rem; color:var(--rojo); flex:1; }
.alert-badge { background:var(--rojo); color:#fff; border-radius:20px; padding:2px 8px; font-size:0.65rem; font-family:'DM Mono',monospace; font-weight:500; }

/* SCREENS */
.screen { display:none; flex-direction:column; overflow:hidden; flex:1; min-height:0; }
.screen.active { display:flex; }

/* HOME MENU */
.home-screen { padding:24px 20px; gap:16px; overflow-y:auto; animation: fadeUp 0.4s ease-out; }
@keyframes fadeUp { from { opacity:0; transform:translateY(15px); } to { opacity:1; transform:translateY(0); } }
.home-greeting { margin-bottom:8px; }
.home-greeting h2 { font-family:'Outfit',sans-serif; font-weight:800; font-size:1.6rem; letter-spacing:-0.01em; color: var(--texto); }
.home-greeting p { font-size:0.85rem; color:var(--texto2); margin-top:2px; font-weight: 500; }
.home-stats { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:4px; }
.stat-card {
  background: var(--card);
  border: 1px solid var(--borde);
  border-radius: 10px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.stat-card-label { font-family:'Inter',sans-serif; font-size:0.65rem; font-weight:600; letter-spacing:0.1em; color:var(--texto3); text-transform:uppercase; }
.stat-card-value { font-family:'Outfit',sans-serif; font-weight:800; font-size:1.8rem; color:var(--verde-vivo); line-height:1.2; text-shadow: 0 2px 10px var(--verde-glow); }
.stat-card-sub { font-size:0.75rem; font-weight:500; color:var(--texto2); }
.menu-section-title { font-family:'Inter',sans-serif; font-size:0.68rem; font-weight:600; letter-spacing:0.12em; color:var(--texto3); text-transform:uppercase; margin-bottom:12px; }
.menu-grid { display:flex; flex-direction:column; gap:12px; }
.menu-btn {
  background: var(--card);
  border: 1px solid var(--borde);
  border-radius: 12px;
  padding: 16px 18px;
  display: flex;
  align-items: center;
  gap: 16px;
  cursor: pointer;
  transition: var(--transicion-base);
  text-align: left;
  width: 100%;
  position: relative;
  overflow: hidden;
  box-shadow: var(--sombra-sm);
}
.menu-btn::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  border-radius: 3px 0 0 3px;
  transition: all 0.2s;
}
.menu-btn.verde::before { background: var(--verde-vivo); }
.menu-btn.amarillo::before { background: var(--amarillo); }
.menu-btn.azul::before { background: var(--azul); }
.menu-btn.chat-btn::before { background: var(--texto3); }
.menu-btn:hover { transform: translateY(-3px); box-shadow: var(--sombra-md); border-color: var(--verde-vivo); }
.menu-btn:active { transform:scale(0.98); }
.menu-icon { font-size:1.8rem; flex-shrink:0; transition: transform 0.3s; }
.menu-btn:hover .menu-icon { transform: scale(1.1) rotate(5deg); }
.menu-info { flex:1; }
.menu-title { font-family:'Outfit',sans-serif; font-weight:700; font-size:1.05rem; letter-spacing:0.01em; color: var(--texto); }
.menu-desc { font-size:0.78rem; font-weight:500; color:var(--texto2); margin-top:2px; }
.menu-badge { background:var(--rojo); color:#fff; border-radius:20px; padding:2px 8px; font-size:0.65rem; font-family:'DM Mono',monospace; }
.menu-badge.verde { background:var(--verde-vivo); color:#fff; }
.menu-arrow { color:var(--texto3); font-size:1.2rem; }

/* MODAL BASE */
.modal {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  transition: opacity 0.25s ease;
}
.modal.open {
  display: flex;
  opacity: 1;
}
.modal-content {
  background: var(--card);
  border: 1px solid var(--borde2);
  border-radius: 22px;
  width: 92%;
  max-width: 420px;
  padding: 28px;
  box-shadow: var(--sombra-lg);
  transform: scale(0.95);
  transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.modal.open .modal-content {
  transform: scale(1);
}


/* BACK HEADER */
.back-header {
  background: var(--panel);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--borde);
  padding: 12px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-shrink: 0;
  z-index: 10;
}
.back-btn { background:var(--card2); border:1px solid var(--borde); border-radius: 50%; width: 32px; height: 32px; display: flex; align-items:center; justify-content:center; color:var(--texto); font-size:1.3rem; font-weight:700; cursor:pointer; line-height:1; transition: var(--transicion-rapida); }
.back-btn:hover { background: var(--borde); transform: translateX(-2px); }
.back-title { font-family:'Outfit',sans-serif; font-weight:800; font-size:1.1rem; letter-spacing:0.02em; flex:1; color: var(--texto); }
.back-subtitle { font-family:'Inter',sans-serif; font-weight:500; font-size:0.72rem; color:var(--texto3); }

/* FILTER TABS */
.filter-tabs { display:flex; background:var(--panel); border-bottom:1px solid var(--borde); flex-shrink:0; }
.filter-tab { flex:1; padding:10px 6px; text-align:center; font-family:'DM Mono',monospace; font-size:0.68rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--texto3); cursor:pointer; border-bottom:2px solid transparent; transition:all 0.2s; }
.filter-tab.active { color:var(--verde-vivo); border-bottom-color:var(--verde-vivo); }

/* SCROLL CONTENT */
.scroll-content { 
  flex: 1; 
  overflow-y: auto; 
  -webkit-overflow-scrolling: touch; 
  padding: 12px; 
  display: block; 
  min-height: 0; 
  width: 100%; /* Ensure it always takes full width */
}
.scroll-content::-webkit-scrollbar { width: 4px; }
.scroll-content::-webkit-scrollbar-thumb { background: var(--borde2); border-radius: 4px; }


/* PEDIDO CARD */
.pedido-card {
  background: var(--card);
  border: 1px solid var(--borde);
  border-radius: 14px;
  overflow: hidden;
  transition: var(--transicion-base);
  min-height: 76px;
  flex-shrink: 0;
  box-shadow: var(--sombra-sm);
  animation: fadeUp 0.3s ease-out;
}
.pedido-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--sombra-md);
  border-color: var(--borde2);
}
.pedido-card.confeccionado { border-color: var(--amarillo); background: var(--amarillo-dim); }
.pedido-card.en-manipulado { border-color: var(--azul); background: var(--azul-dim); }
.pedido-card.cargado { border-color: var(--verde-vivo); opacity: 0.8; }
.pedido-card-header {
  padding: 14px 16px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  color: var(--texto);
}
.pedido-producto { font-size:0.82rem; font-weight:600; color: var(--texto) !important; }
.pedido-cliente { font-size:0.7rem; color:var(--texto2) !important; }
.pedido-num {
  font-family: 'DM Mono', monospace;
  font-weight: 500;
  font-size: 1.1rem;
  color: var(--verde-vivo);
  line-height: 1;
  flex-shrink: 0;
}
.pedido-main { flex:1; min-width:0; }
.pedido-producto { font-size:0.82rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pedido-cliente { font-size:0.7rem; color:var(--texto2); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pedido-chips { display:flex; gap:6px; margin-top:6px; flex-wrap:wrap; }
.chip { display:inline-flex; align-items:center; gap:3px; padding:2px 8px; border-radius:20px; font-size:0.65rem; font-family:'DM Mono',monospace; border:1px solid var(--borde2); color:var(--texto2); white-space:nowrap; }
.chip.verde { border-color:rgba(61,139,61,0.4); color:var(--verde-vivo); background:rgba(61,139,61,0.08); }
.chip.amarillo { border-color:rgba(200,168,75,0.4); color:var(--amarillo); background:var(--amarillo-dim); }
.chip.rojo { border-color:rgba(192,57,43,0.4); color:var(--rojo); background:var(--rojo-dim); }
.pedido-status { flex-shrink:0; display:flex; flex-direction:column; align-items:flex-end; gap:4px; }
.status-badge {
  font-family: 'DM Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.08em;
  padding: 3px 8px;
  border-radius: 20px;
  border: 1px solid var(--borde2);
  color: var(--texto3);
  text-transform: uppercase;
  white-space: nowrap;
}
.status-badge.confeccionado { border-color:var(--amarillo); color:var(--amarillo); background:var(--amarillo-dim); }
.status-badge.cargado { border-color:var(--verde-vivo); color:var(--verde-vivo); background:rgba(61,139,61,0.1); }

/* PEDIDO DETAIL */
.pedido-detail {
  display: none;
  border-top: 1px solid var(--borde);
  padding: 12px 14px;
  gap: 10px;
  flex-direction: column;
}
.pedido-detail.open { display:flex; }
.detail-row { display:flex; justify-content:space-between; align-items:center; padding:5px 0; border-bottom:1px solid var(--borde); font-size:0.78rem; }
.detail-row:last-child { border-bottom:none; }
.detail-label { color:var(--texto3); font-size:0.72rem; }
.detail-value { font-weight:500; text-align:right; max-width:60%; }
.action-btns { display:flex; gap:8px; margin-top:4px; }
.action-btn {
  flex: 1;
  padding: 10px;
  border-radius: 8px;
  border: 1px solid var(--borde2);
  background: transparent;
  color: var(--texto2);
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: all 0.2s;
  text-transform: uppercase;
}
.action-btn.amarillo:not(.active) { border-color:rgba(200,168,75,0.4); color:var(--amarillo); }
.action-btn.verde:not(.active) { border-color:rgba(61,139,61,0.4); color:var(--verde-vivo); }
.action-btn.active.amarillo { background:var(--amarillo-dim); border-color:var(--amarillo); color:var(--amarillo); font-weight:600; }
.action-btn.azul { border-color:rgba(59,130,246,0.4); color:var(--azul); }
.action-btn.active.azul { background:var(--azul-dim); border-color:var(--azul); color:var(--azul); font-weight:600; }

/* MODAL CONFECCION */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.8); z-index:1000; align-items:flex-end; justify-content:center; }
.modal-overlay.open { display:flex; }
.modal-box { background:var(--panel); border:1px solid var(--borde2); border-radius:16px 16px 0 0; width:100%; max-height:85vh; overflow-y:auto; -webkit-overflow-scrolling:touch; padding:20px 16px 40px; }
.modal-title { font-family:'Syne',sans-serif; font-weight:800; font-size:1.1rem; color:var(--texto); margin-bottom:4px; }
.modal-sub { font-size:0.72rem; color:var(--texto2); margin-bottom:16px; }
.modal-label { font-family:'DM Mono',monospace; font-size:0.6rem; color:var(--texto3); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:4px; display:block; }
.premium-search-group {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}
.premium-search-group i {
  position: absolute;
  left: 16px;
  color: var(--texto3);
  font-size: 1rem;
  pointer-events: none;
  z-index: 2;
  opacity: 0.7;
}
.premium-search {
  width: 100%;
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1.5px solid var(--borde2);
  border-radius: 12px; 
  padding: 10px 16px 10px 42px; 
  color: var(--texto);
  font-family: var(--font);
  font-size: 0.88rem;
  font-weight: 500;
  outline: none;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.1);
}
.premium-search:focus {
  border-color: var(--primary);
  background: rgba(255, 255, 255, 0.05);
  box-shadow: 0 0 0 4px var(--primary-dim), inset 0 2px 4px rgba(0,0,0,0.1);
  transform: translateY(-1px);
}
.premium-search::placeholder {
  color: var(--texto3);
  opacity: 0.6;
}
.modal-input { width:100%; background:var(--card); border:1px solid var(--borde2); border-radius:8px; padding:10px 12px; color:var(--texto); font-family:'DM Sans',sans-serif; font-size:0.9rem; outline:none; margin-bottom:12px; }
.modal-input:focus { border-color:var(--verde-vivo); }
.lote-row { display:grid; grid-template-columns:1fr 80px 80px 32px; gap:6px; align-items:center; margin-bottom:8px; }
.lote-row input { margin-bottom:0; }
.btn-add-lote { background:transparent; border:1px dashed var(--borde2); color:var(--texto3); border-radius:8px; padding:8px; font-size:0.75rem; cursor:pointer; width:100%; margin-bottom:12px; }
.btn-add-lote:hover { border-color:var(--verde-vivo); color:var(--verde-vivo); }
.btn-del-lote { background:transparent; border:none; color:var(--rojo); cursor:pointer; font-size:1rem; padding:4px; }
.modal-save { width:100%; padding:14px; background:var(--verde); border:none; border-radius:10px; color:#fff; font-family:'Syne',sans-serif; font-weight:700; font-size:0.9rem; cursor:pointer; margin-top:8px; }
.modal-save:hover { background:var(--verde-vivo); }
.modal-cancel { width:100%; padding:10px; background:transparent; border:1px solid var(--borde2); border-radius:10px; color:var(--texto3); font-size:0.8rem; cursor:pointer; margin-top:6px; }
.action-btn.active.verde { background:rgba(61,139,61,0.1); border-color:var(--verde-vivo); color:var(--verde-vivo); font-weight:600; }

/* MODAL SHEET (bottom sheet style) */
.modal-sheet {
  background: var(--panel);
  border: 1px solid var(--borde2);
  border-radius: 22px 22px 0 0;
  width: 100%;
  max-width: 640px;
  max-height: 90vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 16px 20px 40px;
}
.modal-handle {
  width: 36px; height: 4px;
  background: var(--borde2);
  border-radius: 2px;
  margin: 0 auto 16px;
}
.modal-field-group {
  margin-bottom: 14px;
  display: flex;
  flex-direction: column;
}
.modal-btn-ok {
  flex: 1;
  padding: 13px;
  background: var(--verde-vivo);
  border: none;
  border-radius: 11px;
  color: #fff;
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: 0.9rem;
  cursor: pointer;
  transition: all 0.2s;
}
.modal-btn-ok:hover { opacity: 0.9; transform: translateY(-1px); }
.modal-btn-cancel {
  flex: 0;
  padding: 13px 16px;
  background: transparent;
  border: 1px solid var(--borde2);
  border-radius: 11px;
  color: var(--texto3);
  font-size: 0.85rem;
  cursor: pointer;
}

/* PEDIDO NUEVO BADGE */
.pedido-nuevo { border-color: rgba(59,130,246,0.4); }
.badge-nuevo {
  font-family: 'DM Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.08em;
  padding: 2px 7px;
  border-radius: 20px;
  background: var(--azul-dim);
  border: 1px solid var(--azul);
  color: var(--azul);
  text-transform: uppercase;
  white-space: nowrap;
}

/* CARGA CARD */
.carga-card {
  background: var(--card);
  border: 1px solid var(--borde);
  border-radius: 12px;
  overflow: hidden;
  transition: all 0.2s;
}
.carga-card.cargado { border-color:var(--verde-vivo); opacity:0.65; }
.carga-header { padding:12px 14px; display:flex; align-items:center; gap:10px; cursor:pointer; }
.carga-matricula {
  background: var(--card2);
  border: 1px solid var(--borde2);
  border-radius: 6px;
  padding: 4px 8px;
  font-family: 'DM Mono', monospace;
  font-size: 0.72rem;
  color: var(--amarillo);
  letter-spacing: 0.05em;
  flex-shrink: 0;
  text-align: center;
  min-width: 80px;
}
.carga-main { flex:1; min-width:0; }
.carga-pedido { font-family:'DM Mono',monospace; font-size:0.75rem; color:var(--verde-vivo); }
.carga-mercancia { font-size:0.8rem; font-weight:600; margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.carga-transportista { font-size:0.68rem; color:var(--texto2); margin-top:1px; }
.cargar-btn {
  background: transparent;
  border: 1px solid rgba(61,139,61,0.4);
  border-radius: 8px;
  padding: 6px 12px;
  color: var(--verde-vivo);
  font-family: 'DM Mono', monospace;
  font-size: 0.65rem;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  text-transform: uppercase;
  flex-shrink: 0;
}
.cargar-btn.active { background:rgba(61,139,61,0.15); border-color:var(--verde-vivo); font-weight:600; }

/* PLANIFICACION */
.plan-dia-card {
  background: var(--card);
  border: 1px solid var(--borde);
  border-radius: 12px;
  overflow: hidden;
}
.plan-dia-header {
  padding: 14px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}
.plan-dia-title { font-family:'Syne',sans-serif; font-weight:800; font-size:1rem; }
.plan-dia-hoy { font-family:'DM Mono',monospace; font-size:0.58rem; background:var(--verde-vivo); color:var(--negro); padding:2px 6px; border-radius:3px; margin-left:6px; }
.plan-dia-ayer { font-family:'DM Mono',monospace; font-size:0.58rem; background:var(--borde2); color:var(--texto3); padding:2px 6px; border-radius:3px; margin-left:6px; }
.plan-dia-stats { display:flex; gap:8px; align-items:center; }
.plan-stat-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--card2);
  border: 1px solid var(--borde2);
  border-radius: 8px;
  padding: 6px 10px;
  min-width: 52px;
}
.plan-stat-val { font-family:'Syne',sans-serif; font-weight:800; font-size:1.1rem; color:var(--verde-vivo); line-height:1; }
.plan-stat-lbl { font-family:'DM Mono',monospace; font-size:0.52rem; color:var(--texto3); letter-spacing:0.06em; margin-top:2px; }
.plan-dia-body {
  display: none;
  border-top: 1px solid var(--borde);
  padding: 12px 14px;
  flex-direction: column;
  gap: 8px;
}
.plan-dia-body.open { display:flex; overflow:visible; }
.plan-horario {
  background: rgba(61,139,61,0.08);
  border: 1px solid rgba(61,139,61,0.2);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.plan-horario-label { font-family:'DM Mono',monospace; font-size:0.65rem; color:var(--texto3); }
.plan-horario-value { font-family:'Syne',sans-serif; font-weight:800; font-size:1.05rem; color:var(--verde-vivo); }
.plan-personas {
  background: var(--amarillo-dim);
  border: 1px solid rgba(200,168,75,0.3);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.plan-personas-label { font-family:'DM Mono',monospace; font-size:0.65rem; color:var(--texto3); }
.plan-personas-value { font-family:'Syne',sans-serif; font-weight:800; font-size:1.4rem; color:var(--amarillo); }
.plan-articulo {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid var(--borde);
  font-size: 0.78rem;
}
.plan-articulo:last-child { border-bottom:none; }
.plan-art-nombre { color:var(--texto2); flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-right:8px; }
.plan-art-bultos { font-family:'DM Mono',monospace; font-size:0.72rem; color:var(--texto); }
.plan-art-kg { font-family:'DM Mono',monospace; font-size:0.72rem; color:var(--verde-vivo); margin-left:8px; }
.plan-art-mins { font-family:'DM Mono',monospace; font-size:0.65rem; color:var(--texto3); margin-left:6px; }

/* CHAT */
.chat-messages { flex:1; overflow-y:auto; padding:12px; display:flex; flex-direction:column; gap:10px; }
.chat-messages::-webkit-scrollbar { width:2px; }
.msg { display:flex; flex-direction:column; max-width:88%; animation:fadeUp 0.2s ease; }
@keyframes fadeUp { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
.msg.user { align-self:flex-end; align-items:flex-end; }
.msg.bot { align-self:flex-start; align-items:flex-start; }
.msg-label { font-size:0.58rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--texto3); margin-bottom:3px; font-family:'DM Mono',monospace; }
.msg-bubble { padding:9px 13px; border-radius:10px; font-size:0.84rem; line-height:1.55; white-space:pre-wrap; word-break:break-word; }
.msg.user .msg-bubble { background:var(--verde-vivo); color:#fff; font-weight:500; }
.msg.bot .msg-bubble { background:var(--card); border:1px solid var(--borde); }
.msg.bot .msg-bubble.error { border-color:var(--rojo); color:var(--rojo); }
.typing-bubble { background:var(--card); border:1px solid var(--borde); padding:10px 14px; border-radius:10px; display:flex; gap:5px; align-items:center; }
.typing-dot { width:6px; height:6px; border-radius:50%; background:var(--verde-vivo); animation:bounce 1.2s infinite; }
.typing-dot:nth-child(2) { animation-delay:0.2s; }
.typing-dot:nth-child(3) { animation-delay:0.4s; }
@keyframes bounce { 0%,60%,100% { transform:translateY(0); opacity:0.4; } 30% { transform:translateY(-5px); opacity:1; } }
.chat-input-area { padding:14px 16px; background:var(--panel); border-top:1px solid var(--borde); display:flex; gap:10px; align-items:flex-end; flex-shrink:0; backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
textarea { flex:1; background:var(--card); border:1px solid var(--borde2); color:var(--texto); font-family:'Inter',sans-serif; font-size:0.95rem; font-weight:500; padding:12px 16px; border-radius:12px; resize:none; outline:none; max-height:120px; min-height:48px; line-height:1.4; transition:var(--transicion-base); box-shadow: inset var(--sombra-sm); }
textarea:focus { border-color:var(--verde-vivo); box-shadow: 0 0 0 3px var(--verde-glow); }
textarea::placeholder { color:var(--texto3); }
.send-btn { background:var(--verde-vivo); border:none; border-radius:10px; width:42px; height:42px; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all 0.2s; }
.send-btn:disabled { background:var(--borde2); cursor:not-allowed; }
.send-btn svg { fill:#fff; }
.welcome-chat { text-align:center; padding:30px 16px; display:flex; flex-direction:column; align-items:center; gap:8px; }
.welcome-chat h3 { font-family:'Syne',sans-serif; font-weight:800; font-size:1.1rem; }
.welcome-chat p { font-size:0.78rem; color:var(--texto2); max-width:240px; line-height:1.5; }
.suggestions { display:flex; flex-wrap:wrap; gap:6px; justify-content:center; margin-top:4px; }
.suggestion-btn { background:transparent; border:1px solid var(--borde2); color:var(--texto2); padding:5px 10px; border-radius:20px; font-size:0.72rem; font-family:'DM Sans',sans-serif; cursor:pointer; transition:all 0.15s; }
.suggestion-btn:hover { border-color:var(--verde-vivo); color:var(--verde-vivo); }

/* EMPTY STATE */
.empty-state { text-align:center; padding:40px 20px; color:var(--texto3); }
.empty-state-icon { font-size:2.5rem; margin-bottom:8px; }
.empty-state p { font-size:0.8rem; }

/* LOADING */
.loading-state { text-align:center; padding:40px 20px; color:var(--texto3); }
.spinner { width:24px; height:24px; border:2px solid var(--borde2); border-top-color:var(--verde-vivo); border-radius:50%; animation:spin 0.8s linear infinite; margin:0 auto 12px; }
@keyframes spin { to { transform:rotate(360deg); } }

/* DATE CAROUSEL */
.date-carousel-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; padding:2px 16px 8px; scrollbar-width:none; }
.date-carousel-wrap::-webkit-scrollbar { display:none; }
.date-carousel { display:flex; gap:8px; width:max-content; }
.date-chip { display:flex; flex-direction:column; align-items:center; padding:5px 8px; border-radius:10px; border:1px solid var(--borde2); background:var(--card); cursor:pointer; min-width:46px; transition:all 0.2s; flex-shrink:0; }
.date-chip:active { transform:scale(0.95); }
.date-chip.active { background:var(--verde); border-color:var(--verde-vivo); }
.date-chip.hoy { border-color:var(--verde-vivo); }
.date-chip .chip-dia { font-family:'DM Mono',monospace; font-size:0.52rem; color:var(--texto3); text-transform:uppercase; letter-spacing:0.04em; }
.date-chip.active .chip-dia { color:rgba(255,255,255,0.7); }
.date-chip.hoy .chip-dia { color:var(--verde-vivo); }
.date-chip .chip-num { font-family:'Syne',sans-serif; font-weight:800; font-size:1.05rem; color:var(--texto); line-height:1; }
.date-chip.active .chip-num { color:#fff; }
.date-chip .chip-mes { font-family:'DM Mono',monospace; font-size:0.5rem; color:var(--texto3); margin-top:1px; }
.date-chip.active .chip-mes { color:rgba(255,255,255,0.7); }
.date-chip .chip-count { font-size:0.5rem; font-family:'DM Mono',monospace; color:var(--verde-vivo); margin-top:2px; }
.date-chip.active .chip-count { color:rgba(255,255,255,0.8); }


/* PALET EN CURSO */
.palet-activo-bar { 
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(41,121,255,0.1); border-top:1px solid var(--azul);
  padding:8px 14px; gap:10px;
}
.palet-activo-cronometro {
  font-family:'Syne',sans-serif; font-weight:800; font-size:1.1rem; color:var(--azul);
}
.palet-activo-info {
  font-family:'DM Mono',monospace; font-size:0.6rem; color:var(--texto3);
}
.btn-finalizar-palet {
  background:var(--verde); border:none; border-radius:8px;
  color:#fff; font-family:'Syne',sans-serif; font-weight:700;
  font-size:0.72rem; padding:6px 12px; cursor:pointer; white-space:nowrap;
}


/* ===== DESKTOP LIGHT MODE ENHANCEMENTS ===== */
@media (min-width: 481px) {
  body {
    background: linear-gradient(135deg, #f0f7f0 0%, #e8f4e8 40%, #f5f9f5 100%);
  }
  header {
    background: #ffffff;
    border-bottom: 1px solid #dde7dd;
    box-shadow: 0 2px 12px rgba(46,125,50,0.08);
  }
  .screen {
    background: transparent;
  }
  .pedido-card, .screen-content .card, .plan-dia-card {
    background: #ffffff;
    box-shadow: 0 2px 8px rgba(30,60,30,0.07), 0 1px 2px rgba(30,60,30,0.04);
    border: 1px solid #e2ece2;
    border-radius: 14px;
    transition: box-shadow 0.18s, transform 0.18s;
  }
  .pedido-card:hover, .plan-dia-card:hover {
    box-shadow: 0 6px 20px rgba(46,125,50,0.13), 0 2px 6px rgba(30,60,30,0.06);
    transform: translateY(-1px);
  }
  .stat-card {
    background: #ffffff;
    box-shadow: 0 2px 10px rgba(30,60,30,0.08);
    border: 1px solid #e2ece2;
    border-radius: 14px;
  }
  .stat-card-value {
    color: var(--verde-vivo);
    font-size: 2.2rem;
  }
  .menu-item {
    background: #ffffff;
    box-shadow: 0 1px 6px rgba(30,60,30,0.06);
    border: 1px solid #e8f0e8;
    border-radius: 14px;
    transition: box-shadow 0.15s, transform 0.15s;
  }
  .menu-item:hover {
    box-shadow: 0 4px 16px rgba(46,125,50,0.12);
    transform: translateX(3px);
  }
  .back-header {
    background: #ffffff;
    border-bottom: 1px solid #e2ece2;
    box-shadow: 0 1px 4px rgba(30,60,30,0.05);
  }
  .pedido-num {
    color: var(--verde-vivo) !important;
    font-weight: 800;
  }
  .chip.verde {
    background: #e8f5e9;
    color: #1b5e20;
    border: 1px solid #a5d6a7;
  }
  .chip.amarillo {
    background: #fff3e0;
    color: #e65100;
    border: 1px solid #ffcc80;
  }
  .chip {
    background: #f0f4f0;
    color: #3a5a3a;
    border: 1px solid #d0e0d0;
  }
  .action-btn.azul {
    background: var(--azul);
    color: #fff;
  }
  .action-btn.amarillo {
    background: var(--amarillo);
    color: #fff;
  }
  .action-btn.verde {
    background: var(--verde-vivo);
    color: #fff;
  }
  .modal-box {
    background: #ffffff;
    box-shadow: 0 20px 60px rgba(30,60,30,0.18);
    border: 1px solid #e2ece2;
  }
  .tab-btn {
    color: var(--texto2);
  }
  .tab-btn.active {
    color: var(--verde-vivo);
    border-bottom: 2px solid var(--verde-vivo);
  }
  .home-stats {
    gap: 12px;
  }
  .greeting-card {
    background: linear-gradient(135deg, #2e7d32 0%, #1b5e20 100%);
    color: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(46,125,50,0.25);
  }
  .greeting-card h2, .greeting-card p {
    color: #fff !important;
  }
  .linea-card {
    background: #ffffff;
    border: 1px solid #e2ece2;
    box-shadow: 0 2px 8px rgba(30,60,30,0.06);
    border-radius: 12px;
  }
  .detail-row {
    border-bottom: 1px solid #f0f4f0;
    padding: 8px 0;
  }
  .detail-label {
    color: var(--texto3);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }
  .detail-value {
    color: var(--texto);
    font-weight: 600;
  }
  .menu-section-title {
    color: var(--texto3);
    font-size: 0.65rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin: 16px 0 8px;
  }
}

/* NEW: GRADIENT BUTTONS FOR HOME SCREEN (Replaces inline styles) */
.btn-module {
  border: none;
  cursor: pointer;
  border-radius: 20px;
  padding: 0;
  overflow: hidden;
  transition: var(--transicion-base);
  box-shadow: var(--sombra-md);
  position: relative;
}
.btn-module:hover {
  transform: translateY(-5px);
  box-shadow: var(--sombra-lg);
}
.btn-module:active {
  transform: translateY(-1px);
}
.btn-module-inner {
  padding: 28px 10px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  position: relative;
  z-index: 1;
}
/* Shine effect on hover */
.btn-module::after {
  content: '';
  position: absolute;
  top: 0; left: -100%; width: 50%; height: 100%;
  background: linear-gradient(to right, transparent, rgba(255,255,255,0.4), transparent);
  transform: skewX(-20deg);
  z-index: 2;
  transition: all 0.5s;
}
.btn-module:hover::after {
  left: 150%;
}

.btn-mod-icon {
  font-size: 3.5rem;
  line-height: 1;
  filter: drop-shadow(0 4px 6px rgba(0,0,0,0.2));
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.btn-module:hover .btn-mod-icon {
  transform: scale(1.15) rotate(5deg);
}
.btn-mod-text {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: 1.05rem;
  color: #fff;
  letter-spacing: 0.02em;
  text-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

/* Gradient Classes */
.bg-gradient-blue { background: linear-gradient(135deg, #2563eb, #60a5fa); box-shadow: 0 10px 25px rgba(59, 130, 246, 0.4); }
.bg-gradient-red { background: linear-gradient(135deg, #dc2626, #f87171); box-shadow: 0 10px 25px rgba(239, 68, 68, 0.4); }
.bg-gradient-orange { background: linear-gradient(135deg, #ea580c, #fcd34d); box-shadow: 0 10px 25px rgba(245, 158, 11, 0.4); }
.bg-gradient-pink { background: linear-gradient(135deg, #db2777, #f472b6); box-shadow: 0 10px 25px rgba(236, 72, 153, 0.4); }
.bg-gradient-teal { background: linear-gradient(135deg, #0d9488, #2dd4bf); box-shadow: 0 10px 25px rgba(20, 184, 166, 0.4); }
.bg-gradient-rose { background: linear-gradient(135deg, #e11d48, #fb7185); box-shadow: 0 10px 25px rgba(244, 63, 94, 0.4); }

/* ORGANIZADOR */
.org-columna {
  min-width: 200px;
  width: 200px;
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--borde);
  flex-shrink: 0;
}
.org-col-header {
  padding: 12px 10px;
  background: var(--panel);
  border-bottom: 1px solid var(--borde);
  text-align: center;
  flex-shrink: 0;
}
.org-col-hoy {
  background: var(--verde-vivo);
}
.org-drop-zone {
  flex: 1;
  padding: 8px;
  min-height: 100px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow-y: auto;
  transition: background 0.2s;
}
.org-drop-active {
  background: rgba(0,200,100,0.08);
  border: 2px dashed var(--verde-vivo);
  border-radius: 8px;
}
.org-card {
  background: var(--card);
  border: 1px solid var(--borde2);
  border-radius: 10px;
  padding: 10px;
  cursor: grab;
  transition: transform 0.15s, box-shadow 0.15s;
  user-select: none;
}
.org-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.org-card:active { cursor: grabbing; }
.org-card-modificado {
  border-color: var(--amarillo);
  box-shadow: 0 0 8px rgba(253,203,110,0.3);
}
.org-empty {
  text-align: center;
  padding: 20px 8px;
  font-family: DM Mono, monospace;
  font-size: 0.65rem;
  color: var(--texto3);
}

/* TOGGLE SWITCH */
.switch {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
}
.switch input { 
  opacity: 0;
  width: 0;
  height: 0;
}
.slider {
  position: absolute;
  cursor: pointer;
  top: 0; left: 0; right: 0; bottom: 0;
  background-color: rgba(255,255,255,0.1);
  transition: .4s;
  border: 1px solid var(--border);
}
.slider:before {
  position: absolute;
  content: "";
  height: 18px;
  width: 18px;
  left: 3px;
  bottom: 2px;
  background-color: white;
  transition: .4s;
}
input:checked + .slider {
  background-color: var(--primary);
  border-color: var(--primary);
}
input:focus + .slider {
  box-shadow: 0 0 1px var(--primary);
}
input:checked + .slider:before {
  transform: translateX(20px);
}
.slider.round {
  border-radius: 34px;
}
.slider.round:before {
  border-radius: 50%;
}

/* --- MEJORAS MANIPULADO: SEGUIMIENTO DE LOTES Y COLAS --- */
.line-card-next {
  opacity: 0.65;
  border: 2px dashed var(--borde2) !important;
  box-shadow: none !important;
  transform: scale(0.96);
  margin-top: -8px;
  background: var(--card2) !important;
}

.lot-info-box {
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--card2);
  border-radius: 10px;
  border: 1px solid var(--borde);
}

.progress-bar-container {
  width: 100%;
  height: 8px;
  background: var(--borde);
  border-radius: 4px;
  margin-top: 6px;
  overflow: hidden;
}

.progress-bar-fill {
  height: 100%;
  background: var(--primary);
  transition: width 0.5s ease-out;
}

.progress-bar-fill.warning { background: var(--amarillo); }
.progress-bar-fill.danger { background: var(--rojo); }

.badge-semiconf {
  background: var(--amarillo-dim);
  color: var(--amarillo);
  border: 1px solid var(--amarillo);
  padding: 2px 8px;
  border-radius: 6px;
  font-size: 0.7rem;
  font-weight: 700;
  display: inline-block;
  margin-top: 4px;
}

.btn-man-action {
  padding: 10px;
  border-radius: 8px;
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 0.8rem;
  cursor: pointer;
  border: 1px solid var(--borde);
  background: var(--card);
  color: var(--texto2);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: all 0.2s;
}

.btn-man-action:active { transform: scale(0.95); }
.btn-man-action.primary { background: var(--primary); color: #fff; border: none; }
.btn-man-action.danger { background: var(--rojo-dim); color: var(--rojo); border-color: var(--rojo); }
.btn-man-action.warning { background: var(--amarillo-dim); color: var(--amarillo); border-color: var(--amarillo); }

.log-pallet-box {
  width: 22px;
  height: 22px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  position: relative;
  border: 1px solid rgba(255,255,255,0.1);
}
.log-pallet-box::after {
  content: '';
  position: absolute;
  bottom: 1px;
  left: 2px;
  right: 2px;
  height: 2px;
  background: rgba(0,0,0,0.3);
  border-radius: 1px;
}
.log-pallet-box.pending {
  background: rgba(255,255,255,0.05);
  border: 1px dashed rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.15);
  box-shadow: none;
}
.log-pallet-box.finished {
  background: linear-gradient(135deg, var(--amarillo), #d97706);
  color: #fff;
}
.log-pallet-box.loaded {
  background: linear-gradient(135deg, var(--verde-vivo), var(--verde));
  color: #fff;
}
.log-pallet-box.moving {
  background: linear-gradient(135deg, var(--azul), #2563eb);
  border: 1px solid var(--azul);
  color: #fff;
  animation: pulse-blue 1.5s infinite ease-in-out;
}
@keyframes pulse-blue {
  from { opacity: 0.6; transform: scale(0.9); }
  to { opacity: 1; transform: scale(1.1); }
}

.log-order-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 10px;
  margin-bottom: 8px;
}
.log-order-num {
  font-family: 'DM Mono', monospace;
  font-weight: 800;
  font-size: 0.85rem;
  color: var(--verde-vivo);
  margin-bottom: 6px;
}
.log-pallet-row {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.pulse-warning-btn {
  animation: pulse-red-btn 1s infinite alternate;
}
@keyframes pulse-red-btn {
  from { transform: scale(1); box-shadow: 0 0 0 var(--rojo-dim); }
  to { transform: scale(1.05); box-shadow: 0 0 15px var(--rojo); }
}
@keyframes pulse-yellow-bg {
  0% { background-color: var(--card); }
  50% { background-color: rgba(245, 158, 11, 0.2); }
  100% { background-color: var(--card); }
}
.pulse-yellow {
  animation: pulse-yellow-bg 2s infinite ease-in-out;
  border: 2px solid var(--amarillo) !important;
}

/* Jornada Refactor */
.line-alloc-box {
  background: var(--card2);
  border: 1px solid var(--borde);
  border-radius: 10px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.line-alloc-box span {
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--texto3);
}
.line-alloc-box input {
  background: transparent;
  border: none;
  border-bottom: 2px solid var(--borde2);
  color: var(--texto);
  font-family: 'DM Mono', monospace;
  font-size: 1.1rem;
  font-weight: 700;
  width: 100%;
  outline: none;
  text-align: center;
  padding: 2px 0;
}
.line-alloc-box input:focus {
  border-bottom-color: var(--primary);
}
.pause-box {
  background: var(--card2);
  border: 1px solid var(--borde);
  border-radius: 10px;
  padding: 10px;
}
.pause-box label {
  font-size: 0.58rem;
  font-weight: 700;
  color: var(--texto3);
  display: block;
  margin-bottom: 4px;
}
.pause-box input {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--borde2);
  color: var(--texto);
  font-family: 'DM Mono', monospace;
  font-size: 1rem;
  font-weight: 700;
  width: 40px;
  outline: none;
  text-align: center;
}
.btn-circle-small {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--card);
  border: 1px solid var(--borde2);
  color: var(--texto);
  font-size: 1.2rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s;
}
.btn-circle-small:active { transform: scale(0.9); }

/* ── LOGIN RESPONSIVO (v5.15) ────────────────────────────────────────── */
.login-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: url('/static/img/premium_bg.png') no-repeat center center/cover;
  position: relative;
  overflow: hidden;
}
.login-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(15, 23, 42, 0.4) 0%, rgba(2, 6, 23, 0.85) 100%);
  z-index: 1;
}
.login-card {
  position: relative;
  z-index: 2;
  background: rgba(30, 41, 59, 0.7);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 28px;
  width: 100%;
  max-width: 440px;
  padding: 40px;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
  text-align: center;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (min-width: 1024px) {
  .login-overlay {
    background: radial-gradient(circle at center, rgba(255, 255, 255, 0.1) 0%, rgba(248, 250, 252, 0.75) 100%);
  }
  .login-card {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid var(--borde);
    box-shadow: var(--sombra-lg);
  }
  .login-card label {
    color: var(--texto2) !important;
  }
  .login-card input {
    background: #fff !important;
    border-color: var(--borde) !important;
    color: var(--texto) !important;
  }
  .login-card .modal-title-main {
      color: var(--texto) !important;
  }
}

/* ── CARGAS COMPACT REDESIGN (v3.8) ─────────────────────────────────── */
.header-action-btn {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.05);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}
.header-action-btn:active { transform: scale(0.9); }
.header-action-btn.pdf { background: rgba(59,130,246,0.2); color: var(--azul); border-color: rgba(59,130,246,0.3); }
.header-action-btn.scan { background: rgba(16,185,129,0.2); color: var(--verde-vivo); border-color: rgba(16,185,129,0.3); }
.header-action-btn span { font-size: 1.1rem; }

.filter-tabs-compact {
  padding: 4px 0;
}
.filter-tab-pill {
  padding: 6px 14px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 20px;
  color: var(--texto3);
  font-family: 'DM Mono', monospace;
  font-size: 0.65rem;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
  transition: all 0.2s;
}
.filter-tab-pill.active {
  background: var(--primary);
  color: #000;
  border-color: var(--primary);
  box-shadow: 0 4px 12px var(--primary-dim);
}

/* Date Carousel Compact version */
.date-carousel.compact .date-chip {
  padding: 6px 10px;
  min-width: 48px;
  border-radius: 10px;
}
.date-carousel.compact .chip-num {
  font-size: 1rem;
}
.date-carousel.compact .chip-dia, 
.date-carousel.compact .chip-mes {
  font-size: 0.5rem;
}
.date-carousel.compact .chip-count {
  font-size: 0.45rem;
  margin-top: 0;
}

/* SELECTOR DE PALETS (PEDIDOS) */
.palet-selector-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 8px 12px;
  margin-top: 8px;
}
.palet-selector-label {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--texto3);
  letter-spacing: 0.05em;
}
.palet-counter {
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(0,0,0,0.1);
  padding: 4px;
  border-radius: 10px;
}
.palet-counter-btn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--texto);
  font-size: 1.2rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}
.palet-counter-btn:active { transform: scale(0.9); }
.palet-counter-val {
  font-family: 'DM Mono', monospace;
  font-weight: 800;
  font-size: 1.1rem;
  color: var(--primary);
  min-width: 24px;
  text-align: center;
}
.btn-sync-palets {
  margin-top: 8px;
  width: 100%;
  padding: 14px;
  border-radius: 12px;
  background: var(--amarillo);
  color: #000;
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: 0.9rem;
  border: none;
  cursor: pointer;
  display: none;
  animation: fadeIn 0.3s ease;
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3);
}
@keyframes fadeIn { from { opacity: 0; transform: translateY(-5px); } to { opacity: 1; transform: translateY(0); } }

/* --- Panel Admin Admin (v5.32) --- */
#man-panel-admin { padding: 20px; flex-direction: column; gap: 20px; }
.admin-card { background: var(--card); border: 1px solid var(--borde); border-radius: 20px; padding: 24px; box-shadow: var(--sombra-md); }
.form-group-compact { margin-bottom: 15px; }
.form-group-compact label { display: block; font-size: 0.7rem; font-weight: 800; color: var(--texto3); text-transform: uppercase; margin-bottom: 6px; letter-spacing: 0.5px; }
.form-group-compact input { width: 100%; padding: 12px; background: var(--card2); border: 1px solid var(--borde); border-radius: 12px; color: var(--text); font-family: Outfit, sans-serif; font-size: 0.95rem; outline: none; transition: border-color 0.2s; }
.form-group-compact input:focus { border-color: var(--primary); }
