/**
 * ═══════════════════════════════════════════════════════════════════════
 * ECOSMART RESTOBAR — App overrides & Responsive fixes
 * ═══════════════════════════════════════════════════════════════════════
 *
 * Se carga DESPUÉS de theme-light.css.
 * Contiene:
 *   1. Overrides de main.css para tema light (scrollbar, inputs, etc.)
 *   2. Responsive: tablas con scroll, sidebar colapsable, mobile-first
 *   3. Componentes compartidos entre módulos de restobar
 *   4. Animaciones
 *   5. Print styles
 */

/* ═══════════════════════════════════════
   1. OVERRIDES LIGHT
   ═══════════════════════════════════════ */

/* Body */
body { background: var(--void); }

/* Scrollbar light */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background: var(--dark-3); }
::-webkit-scrollbar-thumb { background: var(--dark-5); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background: var(--dark-6); }

/* Sidebar light */
.eco-sidebar { background: #ffffff; border-right: 1px solid var(--border-2); }
.eco-sidebar-logo { color: var(--txt-1); border-bottom-color: var(--border-2); }
.eco-sidebar-logo em { color: var(--orange); }
.eco-sidebar-link { color: var(--txt-3); }
.eco-sidebar-link:hover { background: var(--dark-3); color: var(--txt-1); }
.eco-sidebar-link.active { background: var(--orange-10); color: var(--orange); }
.eco-sidebar-footer { border-top-color: var(--border-2); }

/* Header light */
.eco-header { background: #ffffff; border-bottom: 1px solid var(--border-2); }

/* Cards light — sombra sutil en vez de borde */
.eco-card, .s-card {
  background: #ffffff;
  border: 1px solid var(--border-2);
  box-shadow: var(--sh-xs);
}
.eco-card-hover:hover, .s-card:hover {
  box-shadow: var(--sh-md);
}

/* Inputs light */
.eco-input, .eco-textarea, .eco-select {
  background: #ffffff;
  border-color: var(--border-3);
  color: var(--txt-1);
}
.eco-input:focus, .eco-textarea:focus, .eco-select:focus {
  border-color: var(--orange);
  box-shadow: 0 0 0 3px var(--orange-10);
}
.eco-input::placeholder, .eco-textarea::placeholder { color: var(--txt-4); }

/* Buttons — ajustar para contraste light */
.btn-orange { background: var(--orange); color: #ffffff; }
.btn-orange:hover { background: var(--orange-light); }
.btn-ghost { background: #ffffff; color: var(--txt-2); border-color: var(--border-3); }
.btn-ghost:hover { border-color: var(--orange); color: var(--orange); }

/* Bottom nav original (mesero, cajero) — override para light + full width */
.eco-bottom-nav {
  background: #ffffff;
  border-top: 1px solid var(--border-2);
  box-shadow: 0 -2px 10px rgba(0,0,0,.06);
  max-width: none;
  left: 0;
  transform: none;
}
.eco-nav-item { color: var(--txt-4); }
.eco-nav-item.active { color: var(--orange); }

/* Badges — más contraste en light */
.badge-grey { background: var(--dark-3); color: var(--txt-3); border-color: var(--border-2); }

/* Toggle light */
.toggle { background: var(--dark-4); border-color: var(--border-3); }
.toggle.on { background: var(--orange); border-color: var(--orange); }

/* Eco-modal (mesero, cajero) — light override */
.eco-modal-overlay { background: rgba(0,0,0,.35); backdrop-filter: blur(8px); }
.eco-modal { background: #ffffff; border-color: var(--border-2); box-shadow: var(--sh-xl); }
.eco-modal-handle { background: var(--dark-5); }
.eco-modal h3 { color: var(--txt-1); }

/* KDS cards light (cocina) */
.kds-header { background: #ffffff; border-bottom-color: var(--border-2); }
.kds-metric { background: var(--dark-3); border-color: var(--border-2); }

/* WhatsApp chat area — leve gris para contraste con cards blancas */
.chat-messages { background: #f0f2f5 !important; }
.msg-in { background: #ffffff; border: 1px solid var(--border-2); }
.msg-out { background: #dcf8c6; color: #111827; }
.msg-admin { background: #fff3e0; color: #111827; border-color: var(--warning-10); }

/* Log areas (carga PDF, etc.) */
.log-area { background: var(--dark-3); }

/* Modal overlay */
.modal-overlay { background: rgba(0,0,0,.4); backdrop-filter: blur(8px); }
.modal-box { background: #ffffff; border-color: var(--border-2); box-shadow: var(--sh-xl); }
.modal-hd { border-bottom-color: var(--border-2); }
.modal-close { background: var(--dark-3); color: var(--txt-3); }
.modal-close:hover { background: var(--danger-10); color: var(--danger); }

/* Toast light */
.toast { background: #ffffff; border-color: var(--border-2); box-shadow: var(--sh-lg); color: var(--txt-1); }

/* ═══════════════════════════════════════
   2. RESPONSIVE — MOBILE FIRST
   ═══════════════════════════════════════ */

/* Sidebar: oculta en mobile, muestra en desktop */
.eco-sidebar {
  display: none;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--sidebar-w);
  z-index: 200;
  overflow-y: auto;
}

/* Mobile: bottom nav en vez de sidebar */
.eco-bottom-nav-rb {
  display: flex;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: 56px;
  background: #ffffff;
  border-top: 1px solid var(--border-2);
  box-shadow: 0 -2px 10px rgba(0,0,0,.06);
  justify-content: space-around;
  align-items: center;
  z-index: 200;
  padding-bottom: env(safe-area-inset-bottom);
}
.eco-bottom-nav-rb .bnav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  font-size: .58rem;
  font-weight: 600;
  color: var(--txt-4);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: var(--r8);
  transition: var(--tr-fast);
  border: none;
  background: none;
  text-transform: uppercase;
  letter-spacing: .3px;
  font-family: var(--font-body);
}
.eco-bottom-nav-rb .bnav-item i { font-size: 1.1rem; }
.eco-bottom-nav-rb .bnav-item.active { color: var(--orange); }
.eco-bottom-nav-rb .bnav-item:hover { color: var(--orange); }

/* Desktop: sidebar visible */
@media (min-width: 900px) {
  .eco-sidebar { display: flex !important; flex-direction: column; position: sticky; top: 0; height: 100vh; }
  .eco-page { flex-direction: row; }
  .eco-main { flex: 1; max-height: 100vh; overflow-y: auto; }
  .eco-bottom-nav-rb { display: none !important; }
}

/* Mobile: padding inferior para bottom nav */
@media (max-width: 899px) {
  .eco-page { padding-bottom: 64px; }
  .eco-main { width: 100%; }
}

/* ── TABLAS RESPONSIVE ── */
.table-responsive {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--r10);
}
.table-responsive table { min-width: 600px; }

/* Cualquier tabla dentro de s-card-bd que desborde */
.s-card-bd { overflow-x: auto; }

/* ── GRIDS RESPONSIVE ── */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: .8rem; }
.grid-auto { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: .8rem; }

@media (max-width: 768px) {
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
}

/* ── KPI ROW responsive ── */
.kpi-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(155px, 1fr)); gap: .6rem; margin-bottom: 1.2rem; }
@media (max-width: 400px) { .kpi-row { grid-template-columns: repeat(2, 1fr); } }

/* ═══════════════════════════════════════
   3. COMPONENTES COMPARTIDOS RESTOBAR
   ═══════════════════════════════════════ */

/* Section card — usado en todos los módulos nuevos */
.s-card { background: #ffffff; border: 1px solid var(--border-2); border-radius: var(--r16); margin-bottom: 1rem; overflow: hidden; box-shadow: var(--sh-xs); }
.s-card-hd { padding: .9rem 1.1rem; display: flex; align-items: center; gap: .6rem; border-bottom: 1px solid var(--border-2); background: var(--dark-3); }
.s-card-hd h3 { font-family: var(--font-display); font-size: .9rem; font-weight: 700; color: var(--txt-1); flex: 1; }
.s-card-hd h3 i { color: var(--orange); margin-right: .3rem; }
.s-card-bd { padding: 1rem; }

/* KPI card */
.kpi-card {
  background: #ffffff;
  border: 1px solid var(--border-2);
  border-radius: var(--r14);
  padding: .85rem;
  display: flex;
  align-items: center;
  gap: .7rem;
  transition: var(--tr-slow);
  box-shadow: var(--sh-xs);
}
.kpi-card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }
.kpi-icon {
  width: 40px; height: 40px; border-radius: var(--r10);
  display: flex; align-items: center; justify-content: center;
  font-size: .95rem; flex-shrink: 0;
}
.kpi-label { font-size: .62rem; text-transform: uppercase; letter-spacing: .5px; color: var(--txt-4); font-weight: 700; }
.kpi-value { font-family: var(--font-display); font-size: 1.25rem; font-weight: 900; color: var(--txt-1); }

/* Period bar */
.period-bar {
  display: flex; align-items: center; gap: .5rem; flex-wrap: wrap;
  margin-bottom: 1rem; padding: .7rem .9rem;
  background: #ffffff; border: 1px solid var(--border-2);
  border-radius: var(--r14); box-shadow: var(--sh-xs);
}
.p-btn {
  background: #ffffff; border: 1px solid var(--border-2); color: var(--txt-3);
  padding: .35rem .85rem; border-radius: var(--r8); font-size: .75rem; font-weight: 700;
  cursor: pointer; transition: var(--tr-fast); font-family: inherit;
}
.p-btn.active, .p-btn:hover { background: var(--orange); color: #fff; border-color: var(--orange); }
.p-date {
  background: #ffffff; color: var(--txt-2); border: 1px solid var(--border-2);
  border-radius: var(--r8); padding: .35rem .6rem; font-size: .75rem; font-family: inherit;
}

/* Empty state */
.empty-state { text-align: center; padding: 2.5rem 1rem; }
.empty-state i { font-size: 2.5rem; color: var(--txt-5); display: block; margin-bottom: .6rem; }
.empty-state .empty-title { font-size: .95rem; font-weight: 700; color: var(--txt-3); }
.empty-state .empty-desc { font-size: .8rem; color: var(--txt-4); margin-top: .2rem; }

/* ═══════════════════════════════════════
   4. ANIMACIONES
   ═══════════════════════════════════════ */
@keyframes fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes slideIn { from { opacity: 0; transform: translateX(-8px); } to { opacity: 1; transform: translateX(0); } }
@keyframes modalPop { from { opacity: 0; transform: scale(.95) translateY(8px); } to { opacity: 1; transform: scale(1) translateY(0); } }
@keyframes toastIn { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: translateX(0); } }
@keyframes toastOut { to { opacity: 0; transform: translateX(40px); } }
@keyframes pulseGreen { 0%,100% { box-shadow: 0 0 0 0 rgba(22,163,74,.3); } 70% { box-shadow: 0 0 0 6px rgba(22,163,74,0); } }
@keyframes spin { to { transform: rotate(360deg); } }

.anim-fadeup { animation: fadeUp .4s ease both; }
.anim-slidein { animation: slideIn .3s ease both; }

/* Stagger delays (hasta 20 items) */
.anim-d1 { animation-delay: .05s; }
.anim-d2 { animation-delay: .1s; }
.anim-d3 { animation-delay: .15s; }
.anim-d4 { animation-delay: .2s; }
.anim-d5 { animation-delay: .25s; }

/* ═══════════════════════════════════════
   5. PRINT
   ═══════════════════════════════════════ */
@media print {
  .eco-sidebar, .eco-bottom-nav-rb, .eco-header, .toast-container, .modal-overlay { display: none !important; }
  body { background: #fff; }
  .eco-page { display: block; padding: 0; }
  .eco-main { max-height: none; overflow: visible; }
}
