/* ============================
   DESIGN TOKENS & BASE
============================ */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#0f1117; --bg2:#161826; --bg3:#1e2235;
  --card:#1a1e30; --card2:#222640;
  --primary:#667eea; --primary-dim:rgba(102,126,234,.12);
  --green:#10b981; --green-dim:rgba(16,185,129,.12);
  --warn:#f59e0b; --warn-dim:rgba(245,158,11,.12);
  --danger:#ef4444; --danger-dim:rgba(239,68,68,.12);
  --grad:linear-gradient(135deg,#667eea,#10b981);
  --grad-warm:linear-gradient(135deg,#667eea,#764ba2);
  --text:#e2e8f0; --muted:#64748b; --muted2:#94a3b8;
  --border:rgba(255,255,255,.07); --border2:rgba(255,255,255,.04);
  --rad:16px; --rad-sm:10px; --rad-xs:8px;
}
body.light-theme {
  --bg:#f8fafc; --bg2:#ffffff; --bg3:#f1f5f9;
  --card:#ffffff; --card2:#f8fafc;
  --text:#1e293b; --muted:#64748b; --muted2:#475569;
  --border:rgba(0,0,0,.06); --border2:rgba(0,0,0,.03);
}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;}

/* Role based hiding */
body[data-role="mesero"] .req-admin, body[data-role="mesero"] .req-vendedor { display: none !important; }
body[data-role="vendedor"] .req-admin { display: none !important; }
body[data-role="admin"] .mesero-only { display: none !important; }
body[data-role="vendedor"] .mesero-only { display: none !important; }
body[data-role="mesero"] .caja-only { display: none !important; }

/* ============================
   SCREENS & LAYOUT
============================ */
.screen{display:none;min-height:100vh;flex-direction:column}
.screen.active{display:flex;animation:fadeSlide .28s ease}
@keyframes fadeSlide{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.content{flex:1;overflow-y:auto;background:var(--bg);position:relative;}
.pad{padding:16px}

/* ============================
   HEADER
============================ */
.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;}
.ah-left{display:flex;align-items:center;gap:10px}
.ah-title{font-size:1.05rem;font-weight:700}
.ah-right{display:flex;gap:8px;align-items:center}
.ah-btn{width:36px;height:36px;border-radius:var(--rad-xs);background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;color:var(--text)}
.logo-brand{font-size:1.1rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}

/* ============================
   LOGIN
============================ */
.login-bg{flex:1;display:flex;flex-direction:column;justify-content:center;padding:36px 28px;position:relative;overflow:hidden;align-items:center;}
.login-box{width:100%;max-width:440px;text-align:center;z-index:2;}
.login-bg::before{content:'';position:absolute;width:400px;height:400px;background:var(--primary);opacity:.03;border-radius:50%;top:-100px;right:-100px;}
.login-bg::after{content:'';position:absolute;width:300px;height:300px;background:var(--green);opacity:.03;border-radius:50%;bottom:-100px;left:-100px;}
.brand-icon{width:64px;height:64px;background:var(--grad);border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 20px;box-shadow:0 10px 30px rgba(102,126,234,.3);}
.role-grid{display:flex;flex-direction:column;gap:12px;margin-top:30px;}
.role-btn{padding:16px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rad-sm);color:var(--text);font-family:inherit;font-size:1.05rem;font-weight:700;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;gap:10px;}
.role-btn:active, .role-btn:hover{background:var(--card2);border-color:var(--primary);}
.role-btn.admin{background:var(--grad);color:#fff;border:none;box-shadow:0 8px 24px rgba(102,126,234,.2);}

/* ============================
   DASHBOARD
============================ */
.greeting-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-weight:800;}
.hero-card{background:var(--grad);border-radius:var(--rad);padding:22px;margin-bottom:16px;position:relative;overflow:hidden;}
.hero-card::after{content:'💰';position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:4.5rem;opacity:.15}
.hc-label{font-size:.8rem;opacity:.85;margin-bottom:4px;font-weight:500;text-transform:uppercase}
.hc-amount{font-size:2.6rem;font-weight:900;line-height:1}
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
.sr-card{background:var(--card);border:1px solid var(--border);border-radius:var(--rad-sm);padding:13px 10px;text-align:center}
.sr-val{font-size:1.2rem;font-weight:900;margin-bottom:2px}
.sr-lab{font-size:.7rem;color:var(--muted);font-weight:600;}

/* ============================
   RESTAURANT (MESAS MAP)
============================ */
.map-toolbar{display:flex;gap:10px;padding:10px 16px;background:var(--bg2);border-bottom:1px solid var(--border);overflow-x:auto;}
.map-tool{padding:6px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:50px;font-size:.8rem;color:var(--text);white-space:nowrap;cursor:pointer;}
.map-tool.active{background:var(--primary);border-color:var(--primary);}
.map-container{position:relative;width:100%;height:calc(100vh - 190px);overflow:auto;background:radial-gradient(var(--border) 1px, transparent 1px);background-size:20px 20px;}
.map-canvas{position:relative;width:800px;height:800px;transform-origin:0 0;}
.table-node{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;cursor:pointer;box-shadow:0 4px 10px rgba(0,0,0,.3);transition:.2s;text-align:center;}
.table-node:active{transform:scale(.95);}
.table-node.shape-square{width:80px;height:80px;border-radius:8px;}
.table-node.shape-circle{width:90px;height:90px;border-radius:50%;}
.table-node.status-free{background:var(--card);border:2px solid var(--muted);color:var(--muted);}
.table-node.status-occ{background:var(--primary);border:2px solid #fff;}
.table-node .t-pax{font-size:.65rem;opacity:.8;margin-top:2px;font-weight:400;}

/* Table Panel */
.table-panel{position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-top:1px solid var(--border);border-top-left-radius:24px;border-top-right-radius:24px;padding:20px;transform:translateY(100%);transition:.3s cubic-bezier(.4,0,.2,1);z-index:200;box-shadow:0 -10px 40px rgba(0,0,0,.5);display:flex;flex-direction:column;max-height:80vh;}
.table-panel.open{transform:translateY(0);}
.tp-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.tp-title{font-size:1.3rem;font-weight:800;}
.tp-close{width:32px;height:32px;background:var(--bg3);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.tp-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:20px;}
.tp-btn{padding:10px;border-radius:var(--rad-xs);border:none;font-family:inherit;font-weight:700;font-size:.8rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--card);color:var(--text);border:1px solid var(--border);}
.tp-btn.main{background:var(--grad);color:#fff;border:none;}
.tp-btn.cancel{border-color:var(--danger);color:var(--danger);background:var(--danger-dim);}
.tp-list{flex:1;overflow-y:auto;background:var(--card);border-radius:var(--rad-sm);padding:10px;margin-bottom:16px;}
.tp-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border2);font-size:.9rem;}
.tp-total{display:flex;justify-content:space-between;align-items:center;font-size:1.2rem;font-weight:900;}

/* ============================
   POS (CAJA)
============================ */
.pos-controls{background:var(--bg2);border-bottom:1px solid var(--border);padding:10px 16px;}
.pos-type-toggle{display:flex;background:var(--bg3);border-radius:50px;overflow:hidden;margin-bottom:10px;border:1px solid var(--border);}
.pos-type-btn{flex:1;padding:8px;text-align:center;font-size:.8rem;font-weight:700;cursor:pointer;color:var(--muted);}
.pos-type-btn.active{background:var(--primary);color:#fff;}
.search-input{width:100%;padding:10px 14px 10px 38px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rad-sm);color:var(--text);font-family:inherit;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.867-3.834zm-5.242 1.656a5 5 0 1 1 0-10 5 5 0 0 1 0 10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center; outline:none;}
.search-input:focus{border-color:var(--primary);}

.prod-list{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:8px}
.prod-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--rad-sm);cursor:pointer;}
.prod-row:active{background:var(--primary-dim);border-color:var(--primary);}
.prod-info{flex:1;}
.prod-info .p-name{font-size:.92rem;font-weight:700}
.prod-info .p-dest{font-size:.75rem;color:var(--muted);}
.prod-price{font-size:1rem;font-weight:800;color:var(--primary)}

.cart-footer{background:var(--bg2);border-top:1px solid var(--border);padding:16px;display:flex;flex-direction:column;gap:12px}
.cf-btn{width:100%;padding:16px 22px;background:var(--grad);color:#fff;border:none;border-radius:var(--rad-sm);font-weight:800;cursor:pointer;font-size:1.1rem;transition:.2s;}
.cf-btn:active{transform:scale(0.98);opacity:0.9;}

/* Payment Modal */
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.7);z-index:300;display:none;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);}
.modal-overlay.active{display:flex;}
.pay-modal{background:var(--bg2);width:90%;max-width:400px;border-radius:24px;border:1px solid var(--border);overflow:hidden;}
.pm-head{background:var(--card);padding:24px;text-align:center;border-bottom:1px solid var(--border);}
.pm-val{font-size:3rem;font-weight:900;color:var(--green);line-height:1;}
.pm-bs{font-size:.95rem;color:var(--muted);margin-top:6px;}
.pm-body{padding:20px;}
.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.pay-btn{padding:14px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rad-sm);color:var(--text);font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;}
.pay-btn:active{background:var(--primary);color:#fff;}
.pm-close{width:100%;padding:14px;background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:var(--rad-sm);font-weight:700;cursor:pointer;}

/* Expanded Payment Modal */
.pay-modal-expanded{max-width:460px;max-height:95vh;}
.max-h-70v{max-height:70vh;overflow-y:auto;padding-bottom:10px;}
.pm-section{padding:12px 0;border-bottom:1px solid var(--border);}
.pm-section:last-child{border-bottom:none;}
.pm-summary-row{display:flex;justify-content:space-between;padding:4px 0;font-size:.92rem;color:var(--muted2);}
.pm-input-row{display:flex;gap:8px;align-items:center;margin-top:6px;}
.pm-pct-btn{padding:6px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rad-xs);color:var(--text);font-weight:600;cursor:pointer;font-size:.85rem;font-family:inherit;white-space:nowrap;}
.pm-pct-btn:active{background:var(--primary);color:#fff;}
.pm-toggle-row{margin-top:10px;}
.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.93rem;}
.toggle-label input[type="checkbox"]{width:20px;height:20px;accent-color:var(--primary);}
.pm-client-results{background:var(--bg3);border:1px solid var(--border);border-radius:var(--rad-xs);max-height:150px;overflow-y:auto;margin-top:4px;}
.pm-client-item{padding:10px 14px;cursor:pointer;font-size:.9rem;border-bottom:1px solid var(--border);}
.pm-client-item:hover{background:var(--primary-dim);}
.pm-client-item:last-child{border-bottom:none;}
.pm-client-selected{display:flex;align-items:center;justify-content:space-between;background:var(--green-dim);padding:8px 14px;border-radius:var(--rad-xs);margin-top:6px;font-weight:600;color:var(--green);}
.pm-mixto-row{display:flex;gap:6px;align-items:center;margin-bottom:6px;}
.pm-mixto-row select, .pm-mixto-row input{font-size:.85rem !important;padding:8px !important;}
.pay-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);}
.pm-confirm-btn{margin-top:16px;margin-bottom:10px;width:100%;padding:16px;font-size:1.1rem !important;}
.pm-confirm-btn:disabled{opacity:.4;cursor:not-allowed;}
.sb-label{display:block;font-size:.82rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;}
.mb-10{margin-bottom:10px;}
.flex-1{flex:1;}
.pm-mixto-row .date-input[style*="width:100px"]{width:100px;}
.pm-mixto-row .date-input[style*="width:80px"]{width:80px;}
.pm-add-mixto-btn{width:100%;margin-top:8px;}

/* ============================
   VISOR DE PRECIOS
============================ */
.visor-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 140px);padding:20px;}
.v-search{width:100%;max-width:400px;margin-bottom:30px;position:relative;}
.v-search input{width:100%;padding:18px 24px;font-size:1.2rem;background:var(--card);border:2px solid var(--primary);border-radius:50px;color:var(--text);outline:none;text-align:center;box-shadow:0 8px 30px rgba(102,126,234,.15);}
.v-card{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:30px;width:100%;max-width:400px;text-align:center;box-shadow:0 10px 40px rgba(0,0,0,.3);display:none;animation:fadeSlide .3s ease;}
.v-img{font-size:4rem;margin-bottom:10px;}
.v-code{font-size:.8rem;color:var(--primary);font-weight:700;letter-spacing:1px;margin-bottom:4px;}
.v-name{font-size:1.4rem;font-weight:800;margin-bottom:24px;line-height:1.2;}
.v-prices{display:grid;grid-template-columns:1fr;gap:12px;text-align:left;}
.v-price-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg2);border-radius:var(--rad-sm);border:1px solid var(--border);}
.v-price-label{font-size:.8rem;color:var(--muted);font-weight:600;text-transform:uppercase;}
.v-price-val{font-size:1.3rem;font-weight:900;color:var(--green);}
.v-price-bs{font-size:.75rem;color:var(--muted2);text-align:right;}
.v-stock{margin-top:20px;display:inline-block;padding:6px 16px;background:rgba(16,185,129,.1);color:var(--green);border-radius:50px;font-weight:700;font-size:.85rem;border:1px solid rgba(16,185,129,.3);}

/* ============================
   COMANDAS (From Combined)
============================ */
.k-card{background:var(--card);border:1px solid var(--border);border-radius:var(--rad);margin-bottom:12px;overflow:hidden}
.k-head{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;border-bottom:1px solid var(--border2)}
.k-body{padding:10px 15px}
.ki{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border2);font-size:.88rem}

/* Nuevas clases globales B */
.k-head-row{display:flex;gap:8px;font-weight:700}
.k-dot{width:10px;height:10px;border-radius:50%;margin-top:4px}
.k-dot.danger{background:var(--danger)}
.k-dot.warn{background:var(--warn)}
.k-time{font-size:.75rem;color:var(--muted)}
.ki .k-qty{color:var(--primary);font-weight:900;}
.ki .k-name{flex:1}
.ki .k-badge{font-size:.7rem;padding:3px 8px;background:var(--primary-dim);color:var(--primary);border-radius:50px;font-weight:700;}
.k-foot-box{padding:10px 15px; border-top:1px solid var(--border2); display:flex; gap:8px;}
.k-btn-green{flex:1;padding:12px;border:none;background:var(--green);color:#fff;border-radius:8px;font-weight:700;cursor:pointer;}

.tf-option{display:flex;flex-direction:column;align-items:center;padding:15px 5px;background:var(--bg3);border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:.2s;}
.tf-option.selected{border-color:var(--primary);background:var(--primary-dim);}
.tf-icon{font-size:1.5rem}
.tf-name{font-size:0.72rem;font-weight:700;margin-top:5px;text-align:center}
.tf-status{font-size:.6rem;color:var(--green);margin-top:2px}

/* ============================
   BOTTOM NAV
============================ */
.bottom-nav{display:flex;background:var(--bg2);border-top:1px solid var(--border);padding:8px 0;position:sticky;bottom:0;z-index:100;justify-content:center;min-height:70px;}
.nav-item{flex:1; max-width: 90px; display:flex;flex-direction:column;align-items:center;padding:10px 4px;color:var(--muted);transition:.2s;position:relative;cursor:pointer;}
.nav-item.active{color:var(--primary)}
.nav-item .ni-icon{font-size:1.5rem}
.nav-item .ni-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;}

/* ============================
   TABLET & DESKTOP (RESPONSIVE)
============================ */
@media (min-width: 768px) {
  .pad { max-width: 1100px; margin: 0 auto; padding: 24px; }
  .bottom-nav { gap: 40px; justify-content:center; padding: 12px 0; }
  .nav-item { flex:none; padding: 8px 16px; flex-direction:row; max-width:none; gap:8px;}
  .nav-item .ni-label { font-size: .85rem; }
  .app-header { padding: 18px 24px; }
  
  .stats-row { grid-template-columns: repeat(3, 1fr); margin-bottom:24px;}
  
  /* POS Grid Design V2: 4 rows (header, controls, list/cart, nav) */
  #s-pos { 
    display: grid; 
    grid-template-columns: 1fr 320px; 
    grid-template-rows: 70px auto 1fr 70px; 
    grid-template-areas: 
      "header header"
      "controls cart"
      "list cart"
      "nav nav";
    height: 100vh; 
    overflow: hidden; 
    background: var(--bg);
  }

  /* Area Assignments */
  #s-pos .app-header { grid-area: header; border-bottom: 2px solid var(--border); z-index: 10; }
  #s-pos .pos-controls { grid-area: controls; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 12px 20px; z-index: 5; }
  #s-pos .prod-list { 
    grid-area: list; 
    display: grid; 
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); 
    gap: 16px; 
    align-content: start; 
    padding: 20px; 
    border-right: 1px solid var(--border);
    overflow-y: auto;
  }
  #s-pos .cart-footer { 
    grid-area: cart; 
    border-top: none; 
    border-left: 1px solid var(--border); 
    display: flex;
    flex-direction: column; 
    padding: 24px; 
    background: var(--bg3); 
    overflow-y: auto;
    max-height: 100%;
  }
  #s-pos .bottom-nav { grid-area: nav; border-top: 2px solid var(--border); z-index: 10; }

  #s-comandas .pad { display: grid; grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: 20px; align-content: start; }
  .table-panel { 
    top: 70px; bottom: 70px; left: auto; right: 0; width: 440px; 
    border-radius: 0; transform: translateX(100%); 
    border-left: 2px solid var(--border); 
    box-shadow:-15px 0 40px rgba(0,0,0,.4); 
    max-height:none;
  }
  .table-panel.open{transform:translateX(0);}
}

/* ============================
   UTILITY CLASSES (Reemplazo Inline Styles)
============================ */
.login-title{font-size:2rem;font-weight:900;margin-bottom:8px;}
.login-subtitle{color:var(--muted);margin-bottom:40px;}
.role-icon{font-size:1.4rem}
.hc-sub{font-size:.8rem;opacity:.8;margin-top:4px}
.profit-box{background:var(--card);border:1px solid var(--border);border-radius:var(--rad-sm);padding:24px;margin-bottom:20px;}
.profit-title{font-size:1rem;font-weight:800;margin-bottom:16px}
.profit-icon{color:var(--warn)}
.profit-row{display:flex;justify-content:space-between;align-items:flex-end;}
.profit-label{font-size:.75rem;color:var(--muted);font-weight:700;margin-bottom:4px}
.profit-val{font-size:1.6rem;font-weight:800;color:var(--primary)}
.profit-val.green{color:var(--green)}
.profit-val.text{font-size:1.3rem;color:var(--text)}
.text-right{text-align:right}
.text-center{text-align:center}
.opacity-5{opacity:0.5}
.font-800{font-weight:800}
.grid-full{grid-column: 1 / -1}

/* Empty States */
.empty-msg-full {
  width: 100%;
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}
.empty-icon-lg {
  font-size: 3rem;
  margin-bottom: 15px;
}
.empty-msg-centered {
  text-align: center;
  padding: 40px;
  opacity: 0.5;
}

/* Specific Component Styles */
.header-table-number { color: var(--primary); font-weight: 800; }

.tp-available-msg {
  text-align: center;
  color: var(--muted);
  padding: 30px;
  font-size: 0.9rem;
  font-weight: 700;
}
.tp-available-icon {
  font-size: 3rem;
  margin-top: 10px;
  display: block;
  opacity: 0.2;
}

.prod-row-more {
  justify-content: center;
  background: var(--bg3);
  border: 2px dashed var(--primary);
  cursor: pointer;
  flex-direction: row !important;
  color: var(--primary);
  font-weight: 800;
  font-size: 1.1rem;
  padding: 20px !important;
}
.me-avatar{background:var(--card2);font-size:1rem;margin-right:4px;}
.tp-primary-text{color:var(--primary)}
.tp-icon{font-size:1.3rem}
.tp-val-green{color:var(--green)}
.btn-cobrar{width:100%;padding:16px;background:var(--bg3);border:1px solid var(--border);color:#fff;border-radius:var(--rad-xs);margin-top:14px;font-weight:800;cursor:pointer;}
.pos-filters{display:flex;gap:8px;margin-top:12px;overflow-x:auto;}
.pos-filters::-webkit-scrollbar{display:none;}
.pf-badge{font-size:.7rem;padding:6px 12px;background:var(--bg3);color:var(--muted);border-radius:6px;font-weight:800;letter-spacing:1px;cursor:pointer}
.pf-badge.active{background:var(--primary);color:#fff;}
.pf-badge.blue{background:#3b82f6;color:#fff;}
.spacer{margin-left:auto;}
.cart-head{display:flex;justify-content:space-between;width:100%;margin-bottom:6px;}
.cart-count{color:var(--muted);font-weight:700}
.cart-clear{color:var(--danger);cursor:pointer;font-weight:700}
.cart-summary{background:var(--bg);border-radius:var(--rad-sm);padding:16px;width:100%;}
.cs-row{display:flex;justify-content:space-between;color:var(--muted);font-size:.85rem;margin-bottom:8px}
.cs-total-row{display:flex;justify-content:space-between;align-items:center;}
.cs-label{font-weight:900;font-size:1.2rem}
.cs-val{font-weight:900;font-size:1.8rem;color:var(--primary)}
.cs-equiv{display:flex;justify-content:space-between;color:var(--muted);font-size:.7rem;margin-top:4px;font-weight:600}
.cart-actions{display:flex;gap:10px;margin-top:4px;}
.flex-1{flex:1;}
.txt-lg{font-size:1.1rem}
.green-btn{background:var(--green)}
.pm-title{font-size:.8rem;color:var(--muted);margin-bottom:8px;text-transform:uppercase;font-weight:800;}
.v-icon{position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:1.5rem;opacity:.5;}
.max-w-500{max-width:500px;}
.p-16{padding:16px;}
.p-15{padding:15px;}
.tm-title{font-size:1.1rem;font-weight:800;}
.tm-sub{font-size:.85rem;color:var(--muted);margin-top:4px;}
.tm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-height:350px;overflow-y:auto;padding:5px;}
.tm-actions{margin-top:20px;display:flex;gap:10px;}
.tm-confirm{flex:2;margin:0;}
.sr-val-cyan{color:#00e5ff}
.sr-val-purple{color:#e040fb}
.sr-val-warn{color:var(--warn)}
.d-none{display:none;}
.mt-10{margin-top:10px}
.k-head-row{display:flex;gap:8px;font-weight:700}
.k-dot{width:10px;height:10px;border-radius:50%;background:var(--warn);margin-top:4px}
.k-qty{color:var(--primary);font-weight:900;}
.k-name{flex:1}
.k-foot-box{padding:10px 15px; border-top:1px solid var(--border2); display:flex;}
.k-btn-green{flex:1;padding:12px;border:none;background:var(--green);color:#fff;border-radius:8px;font-weight:800;cursor:pointer}
.k-dot.danger{background:var(--danger);}
.k-badge.danger{background:var(--danger-dim);color:var(--danger);}
.gap-8{gap:8px;}

/* Toast System */
#toast-container { position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%); z-index: 9999; display: flex; flex-direction: column-reverse; gap: 10px; pointer-events: none; }
.toast { background: var(--card); color: var(--text); padding: 12px 24px; border-radius: 50px; box-shadow: 0 10px 30px rgba(0,0,0,0.3); border: 1px solid var(--border); font-weight: 700; font-size: 0.9rem; animation: toastIn 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards; white-space: pre-wrap; text-align: center; }
.toast.error { border-color: var(--danger); }
.toast.success { border-color: var(--green); }
.toast.warn { border-color: var(--warn); }
@keyframes toastIn { from { opacity: 0; transform: translateY(20px) scale(0.9); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes toastOut { to { opacity: 0; transform: translateY(-20px) scale(0.9); } }

/* ============================
   DASHBOARD V2 (Blueprint /app/)
============================ */
.hero-card-v2 { background: linear-gradient(135deg, #3b82f6, #06b6d4); border-radius: 20px; padding: 28px; color: #fff; position: relative; overflow: hidden; margin-bottom: 20px; box-shadow: 0 10px 25px rgba(59, 130, 246, 0.2); }
.hero-card-v2::after { content: '💰'; position: absolute; right: -20px; top: 10px; font-size: 8rem; opacity: 0.1; transform: rotate(-15deg); }
.dash-grid-mini { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 20px; }
.dm-card { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 18px 12px; text-align: center; cursor: pointer; transition: .2s; }
.dm-card:active { transform: scale(0.96); background: var(--bg3); }
.dm-icon { font-size: 1.6rem; margin-bottom: 8px; }
.dm-label { font-size: 0.75rem; color: var(--muted); font-weight: 700; text-transform: uppercase; margin-bottom: 4px; }
.dm-val { font-size: 1.1rem; font-weight: 900; color: var(--text); }
.section-box { background: var(--card); border: 1px solid var(--border); border-radius: 18px; padding: 20px; margin-bottom: 20px; }
.sb-title { font-size: 0.95rem; font-weight: 800; margin-bottom: 18px; display: flex; align-items: center; gap: 8px; }
.sb-row { display: flex; justify-content: space-between; align-items: flex-end; }
.sb-label { font-size: 0.7rem; color: var(--muted); font-weight: 800; text-transform: uppercase; margin-bottom: 4px; }
.sb-val { font-size: 1.6rem; font-weight: 900; color: var(--primary); line-height: 1; }
.sb-val.green { color: var(--green); }
.date-range { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 18px; }
.date-input { width: 100%; padding: 12px; border: 1px solid var(--border); border-radius: 10px; background: var(--bg3); color: var(--text); font-family: inherit; font-size: 0.9rem; }
.export-grid { display: flex; flex-direction: column; gap: 10px; }
.exp-btn { width: 100%; padding: 14px; background: var(--bg3); border: 1px solid var(--border); border-radius: 12px; color: var(--text); font-weight: 800; font-family: inherit; cursor: pointer; text-align: left; display: flex; align-items: center; gap: 12px; transition: .2s; font-size: 0.88rem; }
.exp-btn:active { background: var(--primary-dim); border-color: var(--primary); }

/* inventory Table */
.inv-table { width: 100%; border-collapse: collapse; margin-top: 10px; }
.inv-table th { text-align: left; padding: 12px; font-size: 0.75rem; color: var(--muted); text-transform: uppercase; border-bottom: 1px solid var(--border); }
.inv-table td { padding: 14px 12px; border-bottom: 1px solid var(--border2); font-size: 0.9rem; }
.inv-badge { padding: 4px 10px; border-radius: 50px; font-size: 0.75rem; font-weight: 800; }
.inv-badge.in { background: var(--green-dim); color: var(--green); }
.inv-badge.low { background: var(--warn-dim); color: var(--warn); }
.inv-badge.out { background: var(--danger-dim); color: var(--danger); }
.inv-actions { display: flex; gap: 10px; }
.ia-btn { width: 34px; height: 34px; border-radius: 8px; border: 1px solid var(--border); background: var(--bg3); display: flex; align-items: center; justify-content: center; cursor: pointer; }
.user-block { display: flex; align-items: center; gap: 10px; }
.theme-toggle { background: var(--bg-card); border: 1px solid var(--border); color: var(--text-main); cursor: pointer; padding: 5px 10px; border-radius: 8px; font-size: 1.2rem; transition: all 0.2s; }
.theme-toggle:hover { transform: scale(1.1); background: var(--primary-dim); }
.user-avatar { width: 36px; height: 36px; background: var(--primary); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: .8rem; cursor: pointer; }
.ia-btn:active { background: var(--primary); color: #fff; }

/* Utility Classes for Inline Style migration */
.w-auto { width: auto !important; }
.p-10-20 { padding: 10px 20px !important; }
.center-msg { text-align: center; padding: 30px; opacity: 0.6; font-weight: 600; }
.mh-400-scroll { max-height: 400px; overflow-y: auto; }
.max-h-70v { max-height: 70vh; overflow-y: auto; }
.flex-gap-10 { display: flex; gap: 10px; }
.mb-10 { margin-bottom: 10px !important; }
.mb-20 { margin-bottom: 20px !important; }
.br-12 { border-radius: 12px !important; }
.p-0-ov-h { padding: 0 !important; overflow: hidden !important; }
.p-name { font-weight: 700; }
.p-code { font-size: 0.7rem; color: var(--muted); }
.text-right { text-align: right; }
.text-danger { color: var(--danger); }
.g-item { margin-bottom: 10px; padding: 15px; }
.g-row { display: flex; justify-content: space-between; align-items: center; }
.g-desc { font-weight: 800; font-size: 1.1rem; }
.g-time { font-size: 0.75rem; color: var(--muted); }
.g-amt { font-weight: 900; color: var(--danger); font-size: 1.2rem; }

/* Cart Items List */
.cart-items-list { max-height: 220px; overflow-y: auto; margin-bottom: 8px; display: flex; flex-direction: column; gap: 4px; }
.ci-row { display: flex; align-items: center; gap: 8px; padding: 8px 10px; background: var(--bg); border-radius: 8px; position: relative; }
.ci-qty { font-weight: 900; color: var(--primary); min-width: 28px; font-size: .85rem; }
.ci-info { flex: 1; min-width: 0; }
.ci-name { font-weight: 700; font-size: .85rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ci-note { font-size: .7rem; color: var(--warn); font-style: italic; margin-top: 2px; }
.ci-note.mesero { color: var(--primary); }
.ci-price { font-weight: 800; font-size: .85rem; color: var(--green); white-space: nowrap; }
.ci-actions { display: flex; gap: 4px; }
.ci-btn { width: 26px; height: 26px; border-radius: 6px; border: 1px solid var(--border); background: var(--card); display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: .75rem; color: var(--text); }
.ci-btn:active { background: var(--primary); color: #fff; }
.ci-btn.del { color: var(--danger); }
.mesero-banner { display: flex; align-items: center; gap: 8px; padding: 6px 12px; background: var(--primary-dim); border: 1px solid var(--primary); border-radius: 8px; margin-bottom: 8px; font-size: .8rem; font-weight: 700; cursor: pointer; }
.mesero-modal, .note-modal { width: 100%; max-width: 400px; background: var(--card); border-radius: 20px; overflow: hidden; }
.mm-head, .nm-head { padding: 20px; background: var(--primary); color: #fff; text-align: center; }
.mm-title, .nm-title { font-weight: 800; font-size: 1.1rem; }
.mm-body, .nm-body { padding: 15px; }
.mm-item { padding: 15px; background: var(--bg); border: 1px solid var(--border); border-radius: 12px; font-weight: 700; cursor: pointer; display: flex; align-items: center; gap: 12px; transition: .2s; }
.mm-item:active { transform: scale(0.97); background: var(--primary-dim); border-color: var(--primary); }
.mm-icon { font-size: 1.2rem; }
.mm-close { width: 100%; padding: 15px; background: none; border: none; font-weight: 800; color: var(--muted); cursor: pointer; }
.nm-input { width: 100%; padding: 15px; border: 1px solid var(--border); border-radius: 12px; background: var(--bg3); color: var(--text); font-family: inherit; font-size: 1rem; margin-bottom: 15px; }
.nm-foot { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.nm-btn { padding: 14px; border-radius: 12px; border: none; font-weight: 800; cursor: pointer; font-family: inherit; }
.nm-btn.save { background: var(--primary); color: #fff; }
.nm-btn.cancel { background: var(--bg3); color: var(--text); }

/* Added classes to replace inline styles */
/* landing Editor Modal */
.le-modal-content { max-width: 500px; }
.le-row { display: flex; gap: 10px; margin-bottom: 15px; }
.le-input { width: 100%; padding: 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--bg3); color: var(--text); font-family: inherit; }
.le-color-input { width: 100%; height: 45px; cursor: pointer; border: 1px solid var(--border); border-radius: 8px; background: var(--bg3); }
.le-alert { font-size: 0.8rem; background: var(--primary-dim); padding: 12px; border-radius: 10px; color: var(--primary); border: 1px solid var(--border); }
.le-footer { margin-top: 20px; display: flex; justify-content: flex-end; gap: 10px; }

.btn-dash { border: 1px dashed var(--primary) !important; background: transparent !important; color: var(--primary) !important; }
.btn-dash:hover { background: var(--primary-dim) !important; }

.tp-btn-confirm {
  background-color: #f39c12 !important;
  color: #fff !important;
  border-color: #e67e22 !important;
}

/* ============================
   PIN PAD & LOGIN MODAL
   ============================ */
.pin-pad-mini { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 15px; }
.pin-btn {
  padding: 18px; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--rad-sm);
  color: var(--text); font-size: 1.4rem; font-weight: 800; cursor: pointer; transition: .15s;
  display: flex; align-items: center; justify-content: center;
}
.pin-btn:active { background: var(--primary); transform: scale(.95); color: #fff; }
.pin-btn.bg-red { background: var(--danger-dim); color: var(--danger); border-color: var(--danger); }
.pin-btn.bg-green { background: var(--green-dim); color: var(--green); border-color: var(--green); }
.pin-btn.bg-red:active { background: var(--danger); color: #fff; }
.pin-btn.bg-green:active { background: var(--green); color: #fff; }
.txt-lg { font-size: 1.4rem; font-weight: 800; }
