:root{--bg:#0b1220;--card:#111a2e;--muted:#9fb0d0;--text:#e9eefb;--pri:#3b82f6;--pri2:#2563eb;--line:rgba(255,255,255,.08);--ok:#22c55e;--bad:#ef4444;--warn:#f59e0b;}
*{box-sizing:border-box}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;background:radial-gradient(900px 600px at 15% 10%,rgba(59,130,246,.25),transparent 55%),radial-gradient(900px 600px at 90% 20%,rgba(34,197,94,.18),transparent 55%),var(--bg);color:var(--text);}
a{color:var(--text);text-decoration:none}
a:hover{opacity:.9}
.container{max-width:1200px;margin:0 auto;padding:22px}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border:1px solid var(--line);background:rgba(17,26,46,.65);backdrop-filter:blur(10px);border-radius:16px;position:sticky;top:12px;z-index:10}
.brand{display:flex;gap:10px;align-items:center;font-weight:800;letter-spacing:.3px}
.badge{font-size:12px;color:var(--muted);border:1px solid var(--line);padding:4px 10px;border-radius:999px}
.nav{display:flex;flex-wrap:wrap;gap:10px}
.nav a{padding:8px 10px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.03)}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;margin-top:16px}
.card{grid-column:span 12;border:1px solid var(--line);background:rgba(17,26,46,.65);backdrop-filter:blur(10px);border-radius:18px;padding:16px}
.card h3{margin:0 0 10px 0;font-size:16px}
.muted{color:var(--muted)}
.row{display:flex;gap:12px;flex-wrap:wrap}
.field{flex:1;min-width:220px}
label{display:block;font-size:12px;color:var(--muted);margin:10px 0 6px}
input,select,textarea{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text);outline:none}
textarea{min-height:90px;resize:vertical}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid var(--line);background:linear-gradient(180deg,var(--pri),var(--pri2));color:white;font-weight:800;cursor:pointer}
.btn.secondary{background:rgba(255,255,255,.05)}
.btn.danger{background:linear-gradient(180deg,#ef4444,#dc2626)}
.btn.small{padding:8px 10px;font-size:13px}
hr{border:none;border-top:1px solid var(--line);margin:14px 0}
table{width:100%;border-collapse:collapse}
th,td{padding:10px 8px;border-bottom:1px solid var(--line);text-align:left;font-size:14px;vertical-align:top}
th{color:var(--muted);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.flash{padding:10px 12px;border-radius:14px;border:1px solid var(--line);margin-top:14px}
.flash.ok{background:rgba(34,197,94,.12)}
.flash.warn{background:rgba(245,158,11,.12)}
.flash.danger{background:rgba(239,68,68,.12)}
.pill{padding:4px 10px;border-radius:999px;border:1px solid var(--line);font-size:12px;color:var(--muted)}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.sema{display:inline-flex;align-items:center;gap:8px}
.dot{width:10px;height:10px;border-radius:50%}
.dot.green{background:var(--ok)}
.dot.yellow{background:var(--warn)}
.dot.red{background:var(--bad)}
.smallnote{font-size:12px}


@media print{body{background:#fff;color:#000}.topbar,.nav,.flash,.btn,.footer{display:none !important}.card{border:none;background:#fff;box-shadow:none}table{font-size:12px}a{color:#000;text-decoration:none}}


//* =========================
   Mobile / Responsive
   ========================= */

html, body { max-width: 100%; overflow-x: hidden; }

/* Unifica container (no lo redefinas arriba con otro padding si quieres consistencia) */
.container{
  width:100%;
  max-width:1200px;
  margin:0 auto;
  padding:14px;
}

/* Topbar: que no se desborde */
.topbar{
  gap:12px;
  flex-wrap:wrap;
}
.nav a{ white-space:nowrap; }

/* Botones: más tocables */
.btn, button, input[type="submit"]{ min-height:40px; }

/* Inputs: evitar overflow */
input, select, textarea{
  max-width:100%;
}

/* Grid: mantenemos grid siempre; en móvil hacemos 1 columna */
.grid{
  display:grid;
  grid-template-columns:repeat(12, minmax(0, 1fr));
  gap:14px;
  margin-top:16px;
}

.card{ max-width:100%; overflow:hidden; }

/* Wrapper para tablas (recomendado usarlo en HTML) */
.table-wrap{
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.table-wrap table{ min-width:760px; }

/* Fallback si no envuelves tablas: no rompas el layout */
table{ width:100%; }
th, td{ word-break:break-word; }

/* ====== Breakpoints ====== */
@media (max-width:900px){
  .container{ padding:10px; }

  /* Cards con spans inline (ventas/tickets) => full width */
  [style*="grid-column:span"]{ grid-column:span 12 !important; }

  /* row stack */
  .row{ flex-wrap:wrap; gap:10px; }
  .field{ min-width: 100%; }

  /* nav ocupa todo el ancho */
  .nav{ width:100%; }

  /* Tipografía */
  th{ font-size:11px; }
  td{ font-size:13px; }
}

@media (max-width:480px){
  .topbar{ padding:12px 12px; border-radius:14px; top:8px; }
  .nav a{ padding:8px 10px; border-radius:10px; }
  h3{ font-size:18px; }
  .btn.small{ min-height:38px; padding:8px 10px; }
}
/* =========================
   Status pills (Dashboard)
   ========================= */
.pill.status-pill{
  display:inline-block;
  padding:6px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  color:#fff;
  border:none;
  white-space:nowrap;
}

/* Ventas (Clientes) */
.pill.status-pendiente{ background: rgba(148,163,184,.28); }         /* gris/azul tenue */
.pill.status-produccion{ background: rgba(59,130,246,.75); }         /* azul */
.pill.status-listo-entrega{ background: rgba(245,158,11,.78); }      /* ámbar/naranja */
.pill.status-entregado{ background: rgba(34,197,94,.68); }           /* verde */
.pill.status-instalado{ background: rgba(22,163,74,.75); }           /* verde intenso */
.pill.status-completado{ background: rgba(20,83,45,.85); }           /* verde oscuro */
.pill.status-cancelado{ background: rgba(239,68,68,.78); }           /* rojo */

