:root{
  --bg:#f6f3ef;
  --panel:#fffdfb;
  --text:#2d221b;
  --muted:#7a6a5d;
  --line:#eadfd3;
  --primary:#6f4e37;
  --primary-2:#b08968;
  --accent:#c98b4a;
  --ok:#1f8f4e;
  --danger:#b91c1c;
  --shadow:0 14px 32px rgba(74,50,33,.10);
  --radius:20px;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;background:linear-gradient(180deg,#f9f6f2 0%,#f3ece5 100%);color:var(--text)}
.app{display:grid;grid-template-columns:290px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#2f2119 0%,#5d4030 100%);color:#fff;padding:24px 18px;position:sticky;top:0;height:100vh;overflow:auto}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.logo{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:rgba(255,255,255,.14);font-size:26px}.brand h1{margin:0;font-size:21px}.brand p{margin:4px 0 0;color:rgba(255,255,255,.75);font-size:13px}
.menu-title{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.6);margin:22px 10px 10px}.nav a{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;padding:12px 14px;border-radius:14px;margin-bottom:8px;background:transparent;transition:.2s ease;font-size:14px}.nav a:hover{background:rgba(255,255,255,.14);transform:translateX(2px)}
.content{padding:22px}.topbar{background:rgba(255,253,251,.88);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.7);box-shadow:var(--shadow);border-radius:24px;padding:18px 22px;display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px}.topbar h2{margin:0;font-size:25px}.topbar p{margin:6px 0 0;color:var(--muted);font-size:14px}.user-box{background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px 14px;min-width:220px}.user-box strong{display:block;font-size:14px}.user-box span{font-size:13px;color:var(--muted)}
.grid{display:grid;gap:18px}.grid.cards{grid-template-columns:repeat(4,1fr);margin-bottom:24px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.kpi-title{color:var(--muted);font-size:13px;margin-bottom:10px}.kpi-value{font-size:30px;font-weight:800}.money:before{content:'$';margin-right:2px}.kpi-foot{margin-top:8px;font-size:13px;color:var(--muted)}
.layout-main{display:grid;grid-template-columns:1.25fr .75fr;gap:18px;margin-bottom:24px}.section-title{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.section-title h3{margin:0;font-size:18px}.section-title span{color:var(--muted);font-size:13px}.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.input,.select,.btn{border-radius:14px;border:1px solid var(--line);padding:12px 14px;font-size:14px;background:#fff}.input,.select{width:100%}.btn{cursor:pointer;font-weight:700;transition:.2s ease}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.soft{background:#fff5ea;border-color:#f0d4b2;color:#9a3412}.btn.success{background:var(--ok);border-color:var(--ok);color:#fff}.btn:hover{transform:translateY(-1px)}
.pos-body{display:grid;grid-template-columns:1fr 360px;gap:18px}.pos-tablet-horizontal{align-items:start}.cart-panel{padding:16px;background:linear-gradient(180deg,#fffdfb 0%,#fff6ec 100%)}
.menu-shell{display:grid;grid-template-columns:180px 1fr;gap:18px;align-items:start}.category-rail{display:flex;flex-direction:column;gap:12px;position:sticky;top:12px}.category-pill{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);background:linear-gradient(180deg,#fffdfc 0%, #fff7ef 100%);border-radius:18px;box-shadow:0 8px 18px rgba(102,72,45,.06);cursor:pointer}.category-pill.active{outline:2px solid rgba(201,139,74,.25);background:linear-gradient(180deg,#fffaf4 0%, #fff0df 100%)}.category-info strong{display:block;font-size:14px}.category-info span{font-size:12px;color:var(--muted)}
.circle-photo{width:58px;height:58px;border-radius:50%;flex:0 0 58px;overflow:hidden;box-shadow:0 8px 18px rgba(91,61,37,.2)}.circle-photo img,.product-photo img{width:100%;height:100%;object-fit:cover}
.subcats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.chip{padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:#fff;font-size:13px;font-weight:700;color:var(--text)}
.products{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.product{border:1px solid var(--line);border-radius:18px;padding:14px;background:linear-gradient(180deg,#fffefc 0%,#fbf5ee 100%);display:flex;flex-direction:column;gap:10px}.product-photo{width:82px;height:82px;border-radius:50%;margin:0 auto 4px;overflow:hidden;box-shadow:0 10px 20px rgba(87,59,38,.18)}.tag{display:inline-block;font-size:11px;padding:6px 8px;border-radius:999px;background:#f8efe6;color:#6d4c34;margin:0 auto}.product h4{text-align:center;margin:0;font-size:15px}.product .price{font-size:22px;font-weight:800;text-align:center;color:var(--primary)}.product .meta{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);gap:8px;flex-wrap:wrap}
.cart-item{display:flex;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px dashed var(--line);font-size:14px}.cart-item small{display:block;color:var(--muted);margin-top:4px}.summary{margin-top:12px;padding-top:12px}.summary-row{display:flex;justify-content:space-between;margin-bottom:10px;color:var(--muted);font-size:14px}.summary-row.total{color:var(--text);font-size:20px;font-weight:800;border-top:1px solid var(--line);padding-top:12px;margin-top:12px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:24px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.form-grid .full{grid-column:1/-1}
table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line);font-size:14px}th{color:var(--muted);font-weight:600}
.chart{height:260px;border-radius:18px;background:linear-gradient(180deg, rgba(176,137,104,.12), rgba(176,137,104,.02)), repeating-linear-gradient(to top, #f3ece4 0, #f3ece4 1px, transparent 1px, transparent 52px), repeating-linear-gradient(to right, #fcfaf8 0, #fcfaf8 1px, transparent 1px, transparent 72px);border:1px solid var(--line);position:relative;overflow:hidden}.bars{position:absolute;inset:16px;display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.bar{flex:1;border-radius:14px 14px 6px 6px;background:linear-gradient(180deg,var(--accent),var(--primary));position:relative;min-width:28px}.bar::after{content:attr(data-label);position:absolute;bottom:-28px;left:50%;transform:translateX(-50%);font-size:12px;color:var(--muted)}
.tablet-note{margin-top:10px;padding:10px 12px;border:1px dashed #dfc29d;border-radius:14px;background:#fff8ef;color:#8a5a22;font-size:13px}
@media (max-width:1240px){.grid.cards{grid-template-columns:repeat(2,1fr)}.layout-main,.two-col,.pos-body{grid-template-columns:1fr}.products{grid-template-columns:repeat(2,1fr)}.menu-shell{grid-template-columns:1fr}.category-rail{position:relative;display:grid;grid-template-columns:repeat(2,1fr)}}
@media (max-width:860px){.app{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.products,.form-grid,.grid.cards,.category-rail{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start}}

/* === Comunicación rápida en sidebar === */
.quick-shortcuts{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:8px 0 18px}
.quick-shortcut{text-decoration:none;color:#fff;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.08);border-radius:16px;padding:10px 10px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;transition:.2s ease}
.quick-shortcut:hover{background:rgba(255,255,255,.14);transform:translateY(-1px)}
.quick-shortcut.active{background:rgba(255,255,255,.18);outline:2px solid rgba(255,255,255,.18)}
.quick-shortcut.has-alert{box-shadow:0 0 0 1px rgba(248,113,113,.25),0 0 22px rgba(248,113,113,.18)}
.quick-shortcut.has-info{box-shadow:0 0 0 1px rgba(125,211,252,.18)}
.quick-icon{font-size:20px;line-height:1}
.quick-label{font-size:12px;font-weight:700;text-align:center}
.quick-badge{position:absolute;top:6px;right:6px;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#fff;color:#5d4030;display:grid;place-items:center;font-size:11px;font-weight:800}
.quick-shortcut.has-alert .quick-badge{background:#ef4444;color:#fff}

/* === Módulo comunicación === */
.comunicacion-grid{grid-template-columns:minmax(320px,.9fr) minmax(280px,.7fr)}
.compact-title{margin-bottom:12px}.compact-title h3{font-size:17px}
.timeline-list{display:grid;gap:14px}.timeline-item{border:1px solid var(--line);border-radius:18px;padding:16px;background:linear-gradient(180deg,#fffefc 0%,#faf5ee 100%)}
.timeline-item.is-danger{border-color:#fca5a5;box-shadow:0 0 0 1px rgba(239,68,68,.08)}
.timeline-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:10px}.timeline-head h4{margin:0 0 6px;font-size:16px}.timeline-meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted);font-size:12px}.timeline-badges{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.timeline-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:10px}.timeline-item p{margin:0;color:var(--text);line-height:1.45}
.empty-state{padding:24px;border:1px dashed var(--line);border-radius:16px;background:#fffaf4;color:var(--muted);text-align:center}
.badge-good,.badge-warn,.badge-soft,.badge-dark,.badge-danger{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;line-height:1}
.badge-good{background:#e8f7ee;color:#166534}.badge-warn{background:#fff7e6;color:#92400e}.badge-soft{background:#f5efe7;color:#6f4e37}.badge-dark{background:#ece8e4;color:#4b5563}.badge-danger{background:#fee2e2;color:#991b1b}
.btn.btn-xs,.btn-xs{padding:8px 10px;border-radius:12px;font-size:12px;font-weight:700;text-decoration:none;background:#fff;border:1px solid var(--line);color:var(--text)}
.messages-columns{display:grid;grid-template-columns:1fr 1fr;gap:14px}.message-list{display:grid;gap:12px;max-height:560px;overflow:auto;padding-right:2px}.message-card{border:1px solid var(--line);border-radius:16px;padding:14px;background:linear-gradient(180deg,#fffefc 0%,#fbf6f0 100%)}.message-card.is-pending{border-color:#fcd34d;box-shadow:0 0 0 1px rgba(245,158,11,.1)}.message-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:8px}.message-card p{margin:8px 0 0;line-height:1.45}.mini-heading{margin:0 0 10px;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
@media (max-width:1240px){.quick-shortcuts{grid-template-columns:repeat(3,1fr)}.comunicacion-grid,.messages-columns{grid-template-columns:1fr}}
@media (max-width:860px){.quick-shortcuts{grid-template-columns:1fr}.timeline-head{flex-direction:column}.quick-badge{top:10px;right:10px}}


/* === Tablet S6 / táctil general === */
.content{min-width:0}
.topbar,.card,.form-card{min-width:0}
.app-nav-toggle,.app-sidebar-backdrop,.sidebar-close{display:none}
.sidebar-head{display:block}
body.app-nav-open{overflow:hidden}

@media (max-width:1366px){
  .app{grid-template-columns:248px minmax(0,1fr)}
  .sidebar{padding:22px 16px}
  .content{padding:18px}
  .topbar{padding:16px 18px}
  .topbar h2{font-size:22px}
  .grid.cards{gap:14px}
  .kpi-value{font-size:26px}
  .pos-body{grid-template-columns:minmax(0,1fr) 320px}
  .menu-shell{grid-template-columns:160px minmax(0,1fr)}
  .products{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:1024px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;top:0;left:0;bottom:0;width:min(320px,84vw);height:100vh;z-index:80;transform:translateX(-105%);transition:transform .28s ease, box-shadow .28s ease;padding-top:22px;box-shadow:none}
  body.app-nav-open .sidebar{transform:translateX(0);box-shadow:0 20px 60px rgba(15,23,42,.34)}
  .app-sidebar-backdrop{display:block;position:fixed;inset:0;background:rgba(31,23,20,.42);backdrop-filter:blur(2px);opacity:0;pointer-events:none;z-index:70;transition:opacity .2s ease}
  body.app-nav-open .app-sidebar-backdrop{opacity:1;pointer-events:auto}
  .app-nav-toggle{display:inline-flex;align-items:center;gap:8px;position:fixed;top:12px;left:12px;z-index:85;border:1px solid rgba(111,78,55,.16);background:rgba(255,255,255,.96);color:#3d2b20;border-radius:999px;padding:10px 14px;box-shadow:0 10px 28px rgba(74,50,33,.18);font-weight:800}
  .app-nav-toggle-icon{font-size:18px;line-height:1}
  .app-nav-toggle-text{font-size:13px;line-height:1}
  .sidebar-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}
  .sidebar-close{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);color:#fff;font-size:26px;line-height:1;cursor:pointer;flex:0 0 auto}
  .brand{margin-bottom:0}
  .content{padding:72px 14px 18px}
  .topbar{padding:16px}
  .topbar,.layout-main,.two-col,.form-page-grid,.pos-body,.menu-shell{grid-template-columns:1fr}
  .grid.cards{grid-template-columns:repeat(2,minmax(0,1fr))}
  .category-rail{position:relative;display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:720px){
  .grid.cards,.products,.form-grid,.category-rail{grid-template-columns:1fr}
  .topbar{flex-direction:column;align-items:flex-start}
  .topbar .user-box{width:100%;min-width:0}
  .app-nav-toggle-text{display:none}
}

.is-hidden{display:none !important;}


/* ===== SAFE PATCH · SIDEBAR CARAMEL PREMIUM =====
   Parche solo visual. No altera estructura HTML, IDs ni clases existentes.
   Objetivo: mejorar el lateral sin romper menú, JS o permisos.
*/
.sidebar{
  background:linear-gradient(180deg,#9a6b43 0%,#c79a6b 56%,#dfbe93 100%) !important;
  color:#fff;
}
.sidebar::before{
  content:'';
  position:sticky;
  top:0;
  display:block;
  height:0;
}
.sidebar .sidebar-head{
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.16);
}
.sidebar .brand{
  gap:14px;
  margin-bottom:0;
}
.sidebar .logo{
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 10px 24px rgba(76,48,25,.18);
}
.sidebar .brand h1{
  font-size:22px;
  line-height:1.05;
  letter-spacing:.01em;
  color:#fff9f1;
  text-shadow:0 1px 1px rgba(70,40,15,.12);
}
.sidebar .brand p{
  color:rgba(255,248,238,.82);
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.sidebar .user-mini{
  background:rgba(255,255,255,.11);
  border:1px solid rgba(255,255,255,.15);
  border-radius:16px;
  padding:12px 14px;
  margin:0 4px 18px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.sidebar .user-mini strong{color:#fffaf4}
.sidebar .user-mini span,
.sidebar .user-mini small{color:rgba(255,248,238,.82)}
.sidebar .menu-title{
  color:rgba(255,245,232,.72);
  margin:18px 10px 10px;
}
.sidebar .nav a{
  border:1px solid transparent;
  color:#fffaf5;
  margin-bottom:8px;
}
.sidebar .nav a:hover{
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.12);
  transform:translateX(3px);
}
.sidebar .nav a:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(255,245,230,.28);
}
.sidebar .nav a.active,
.sidebar .nav a[aria-current='page']{
  background:rgba(255,255,255,.22);
  border-color:rgba(255,255,255,.18);
  box-shadow:inset 3px 0 0 #fff1dc;
}
@media (max-width:1024px){
  .sidebar{
    box-shadow:20px 0 40px rgba(43,24,10,.22);
  }
}
