/* ═══════════════════════════════════════════════════
   assets/style.css — ParkWash
   Paleta: #0d0d0d · #ffffff · #1a6fff
   ═══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&family=DM+Mono:wght@400;500&display=swap');

/* ── Variables ──────────────────────────────────── */
:root {
  --k:   #0d0d0d;
  --k2:  #1c1c1c;
  --k3:  #2e2e2e;
  --w:   #ffffff;
  --g0:  #f4f4f4;
  --g1:  #e8e8e8;
  --g2:  #9a9a9a;
  --b:   #1a6fff;
  --b2:  #0f56d4;
  --bl:  #e8f0ff;
  --bm:  #ccdeff;
  --red: #d93025;
  --grn: #1e7e34;
  --ora: #d4620a;

  --f:  'DM Sans', sans-serif;
  --fm: 'DM Mono', monospace;
  --r:  8px;
  --rl: 14px;
  --tr: .16s ease;

  --topbar-h: 52px;
  --sidebar-w: 210px;
}

/* ── Reset ──────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; -webkit-font-smoothing:antialiased; }
body { font-family:var(--f); background:var(--g0); color:var(--k); line-height:1.5; }
a { color:var(--b); text-decoration:none; }
a:hover { text-decoration:underline; }
button,input,select,textarea { font-family:var(--f); }
button { cursor:pointer; }

/* ── Grid principal ─────────────────────────────── */
.wrap {
  display:grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  grid-template-rows: auto 1fr;
  min-height:100vh;
  background:var(--g0);
}
.wrap > .topbar  { grid-column:1/-1; grid-row:1; }
.wrap > .sidebar { grid-column:1;    grid-row:2; }
.wrap > .main    { grid-column:2;    grid-row:2; background:var(--g0); }

/* ── Topbar ─────────────────────────────────────── */
.topbar {
  grid-column: 1/-1;
  background:var(--k);
  color:var(--w);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 24px;
  height:var(--topbar-h);
  
}
.brand { display:flex; align-items:center; gap:10px; font-size:15px; font-weight:600; }
.brand-icon {
  width:26px; height:26px;
  background:var(--b); border-radius:6px;
}
.topbar-right { display:flex; align-items:center; gap:14px; font-size:13px; }
.rol-badge {
  background:var(--b); color:var(--w);
  padding:2px 9px; border-radius:100px;
  font-size:11px; font-weight:600;
}
.salir { color:rgba(255,255,255,.45); font-size:13px; }
.salir:hover { color:var(--w); text-decoration:none; }

/* ── Sidebar ─────────────────────────────────────── */
.sidebar {
  background:var(--k2);
  padding:16px 0;
  position:sticky; top:0;
  height:calc(100vh - var(--topbar-h));
  overflow-y:auto;
  display:flex; flex-direction:column; gap:2px;
}
.nav-section {
  padding:14px 18px 4px;
  font-size:10px; font-weight:600;
  letter-spacing:1px; text-transform:uppercase;
  color:rgba(255,255,255,.28);
}
.nav-item {
  display:flex; align-items:center; gap:9px;
  padding:9px 20px;
  color:rgba(255,255,255,.58);
  font-size:14px;
  border-left:3px solid transparent;
  transition:var(--tr);
  text-decoration:none;
}
.nav-item:hover { background:rgba(255,255,255,.06); color:var(--w); text-decoration:none; }
.nav-item.active { background:rgba(26,111,255,.18); color:var(--w); border-left-color:var(--b); }

/* ── Main ────────────────────────────────────────── */
.main { padding:28px 30px; overflow-y:auto; background:var(--g0); color:var(--k); }

/* ── Encabezado de página ───────────────────────── */
.ph { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.ph h1 { font-size:21px; font-weight:600; letter-spacing:-.4px; }
.ph small { font-size:13px; font-weight:400; color:var(--g2); margin-left:8px; }

/* ── Cards ──────────────────────────────────────── */
.card {
  background:var(--w);
  border:1px solid var(--g1);
  border-radius:var(--rl);
  padding:22px;
}
.card-hd {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid var(--g1);
}
.card-hd h2 { font-size:15px; font-weight:600; }

/* ── Stats ──────────────────────────────────────── */
.stats {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
  gap:14px;
  margin-bottom:24px;
}
.stat {
  background:var(--w);
  border:1px solid var(--g1);
  border-radius:var(--rl);
  padding:18px 20px;
}
.stat-lbl { font-size:11px; font-weight:600; letter-spacing:.6px; text-transform:uppercase; color:var(--g2); margin-bottom:6px; }
.stat-val { font-size:26px; font-weight:700; letter-spacing:-.5px; }
.stat-sub { font-size:12px; color:var(--g2); margin-top:3px; }
.stat.azul   { border-top:3px solid var(--b); }
.stat.negro  { border-top:3px solid var(--k); }
.stat.verde  { border-top:3px solid var(--grn); }
.stat.naranja{ border-top:3px solid var(--ora); }

/* ── Botones ─────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:5px;
  padding:8px 16px; border-radius:var(--r);
  font-size:14px; font-weight:500;
  border:1px solid transparent;
  transition:var(--tr); line-height:1; cursor:pointer;
}
.btn-primary { background:var(--b); color:var(--w); border-color:var(--b); }
.btn-primary:hover { background:var(--b2); }
.btn-dark { background:var(--k); color:var(--w); border-color:var(--k); }
.btn-dark:hover { background:var(--k3); }
.btn-outline { background:transparent; color:var(--k); border-color:var(--g1); }
.btn-outline:hover { background:var(--g0); }
.btn-danger { background:var(--red); color:var(--w); }
.btn-sm { padding:6px 12px; font-size:13px; }
.btn-full { width:100%; justify-content:center; }
.btn:disabled { opacity:.5; cursor:not-allowed; }

/* ── Formularios ─────────────────────────────────── */
.fg { margin-bottom:14px; }
.fg label { display:block; font-size:13px; font-weight:500; margin-bottom:5px; }
.fg label .req { color:var(--red); margin-left:2px; }
.fc {
  width:100%; padding:8px 11px;
  border:1px solid var(--g1); border-radius:var(--r);
  font-size:14px; background:var(--w); color:var(--k);
  transition:border-color var(--tr), box-shadow var(--tr);
}
.fc:focus { outline:none; border-color:var(--b); box-shadow:0 0 0 3px var(--bm); }
.fc-hint { font-size:12px; color:var(--g2); margin-top:3px; }
.fr   { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.fr3  { display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }

/* ── Tabs de módulo (POS) ────────────────────────── */
.mod-tabs { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:24px; }
.mod-tab {
  border:1.5px solid var(--g1); border-radius:var(--rl);
  padding:18px 14px; text-align:center; cursor:pointer;
  background:var(--w); transition:var(--tr);
}
.mod-tab:hover { border-color:var(--b); background:var(--bl); }
.mod-tab.active { border-color:var(--b); background:var(--bl); box-shadow:0 0 0 3px var(--bm); }
.mod-tab .ti { font-size:26px; margin-bottom:6px; }
.mod-tab .tn { font-size:14px; font-weight:600; }
.mod-tab .ts { font-size:12px; color:var(--g2); }

/* ── POS layout ──────────────────────────────────── */
.pos-grid {
  display:grid;
  grid-template-columns:1fr 320px;
  gap:20px;
  align-items:start;
}
.pos-panel { display:none; }
.pos-panel.visible { display:block; }

/* ── Tablas ──────────────────────────────────────── */
.tbl-wrap { overflow-x:auto; }
table.tbl { width:100%; border-collapse:collapse; font-size:14px; }
.tbl th {
  text-align:left; padding:9px 13px;
  font-size:11px; font-weight:600; letter-spacing:.6px;
  text-transform:uppercase; color:var(--g2);
  background:var(--g0); border-bottom:1px solid var(--g1);
}
.tbl td { padding:11px 13px; border-bottom:1px solid var(--g1); vertical-align:middle; }
.tbl tr:last-child td { border-bottom:none; }
.tbl tr:hover td { background:var(--bl); }

/* ── Badges ──────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:2px 9px; border-radius:100px;
  font-size:12px; font-weight:500;
}
.b-pendiente  { background:#fff3e0; color:#bf360c; }
.b-en_proceso { background:#e3f2fd; color:#0d47a1; }
.b-listo      { background:#e8f5e9; color:#1b5e20; }
.b-parqueadero{ background:#f3e5f5; color:#4a148c; }
.b-lavadero   { background:#e1f5fe; color:#01579b; }
.b-tienda     { background:var(--bl); color:var(--b2); }

/* ── Carrito ─────────────────────────────────────── */
.cart-item {
  display:flex; align-items:center;
  justify-content:space-between; gap:10px;
  padding:9px 0; border-bottom:1px solid var(--g1); font-size:14px;
}
.cart-item:last-child { border-bottom:none; }
.cart-qty { display:inline-flex; align-items:center; gap:6px; }
.cart-qty button {
  width:24px; height:24px; border:1px solid var(--g1);
  border-radius:6px; background:var(--g0); font-size:14px;
  display:flex; align-items:center; justify-content:center;
}
.cart-qty button:hover { background:var(--bl); border-color:var(--b); }
.cart-total { font-size:20px; font-weight:700; }

/* ── Toasts ──────────────────────────────────────── */
#toasts {
  position:fixed; bottom:22px; right:22px;
  z-index:9999; display:flex; flex-direction:column; gap:8px;
}
.toast {
  background:var(--k); color:var(--w);
  padding:11px 16px; border-radius:var(--r);
  font-size:14px; max-width:300px;
  display:flex; align-items:center; gap:8px;
  animation:tin .2s ease;
}
.toast.ok  { border-left:4px solid var(--grn); }
.toast.err { border-left:4px solid var(--red); }
.toast.inf { border-left:4px solid var(--b); }
@keyframes tin { from{opacity:0;transform:translateX(10px)} to{opacity:1;transform:none} }

/* ── Login ───────────────────────────────────────── */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--k); }
.login-box { background:var(--w); border-radius:var(--rl); padding:38px 34px; width:100%; max-width:370px; }
.login-brand { display:flex; align-items:center; gap:10px; margin-bottom:26px; }
.login-brand .bi { width:32px; height:32px; background:var(--b); border-radius:7px; }
.login-brand span { font-size:18px; font-weight:700; }

/* ── Mono / placas ───────────────────────────────── */
.mono,.placa {
  font-family:var(--fm);
  font-size:13px;
  background:var(--g0);
  padding: 8px 11px;
  border-radius:4px;
  border:1px solid var(--g1);
}

/* ── Alerta inline ───────────────────────────────── */
.alerta { padding:10px 14px; border-radius:var(--r); font-size:14px; margin-bottom:14px; }
.alerta-err { background:#fdecea; border:1px solid #f5c6cb; color:#b71c1c; }
.alerta-ok  { background:#e8f5e9; border:1px solid #c8e6c9; color:#1b5e20; }

/* ── Modal ───────────────────────────────────────── */
.modal-bg {
  position:fixed; inset:0; background:rgba(0,0,0,.5);
  z-index:200; display:flex; align-items:center; justify-content:center; padding:20px;
}
.modal {
  background:var(--w); border-radius:var(--rl);
  width:100%; max-width:500px; max-height:90vh; overflow-y:auto;
  animation:min .18s ease;
}
.modal-hd {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 22px; border-bottom:1px solid var(--g1);
}
.modal-hd h3 { font-size:15px; font-weight:600; }
.modal-bd { padding:22px; }
.modal-ft {
  padding:14px 22px; border-top:1px solid var(--g1);
  display:flex; justify-content:flex-end; gap:10px;
}
@keyframes min { from{opacity:0;transform:scale(.97)} to{opacity:1;transform:scale(1)} }

/* ── Ticket impresión ────────────────────────────── */
@media print {
  body * { visibility:hidden; }
  .ticket,.ticket * { visibility:visible; }
  .ticket { position:fixed; inset:0; padding:10mm; font-family:var(--fm); font-size:12px; }
}

/* ── Responsivo ──────────────────────────────────── */
@media(max-width:768px) {
  .wrap { grid-template-columns:1fr; }
  .sidebar { display:none; }
  .main { padding:16px; }
  .fr,.fr3,.mod-tabs,.pos-grid { grid-template-columns:1fr; }
}