/* ==========================================================================
   Revolver — in-product UI recreations ("screenshots") for feature pages.
   Blue/white app palette, scoped under .au so it never touches marketing CSS.
   Fluid/compact: renders like an app screen inside the browser-frame mock.
   ========================================================================== */
.mock-app .mock-body{ padding:0; height:412px; overflow:hidden; }

.au{
  --t:#0f172a; --m:#64748b; --f:#94a3b8; --ln:#e8edf3; --soft:#f8fafc;
  --blue:#2563eb; --blueS:#eff4ff; --grn:#16a34a; --grnS:#e7f6ec;
  --amb:#b45309; --ambS:#fef3c7; --red:#dc2626; --redS:#fde8e8; --vio:#7c3aed; --violS:#f1ecfe;
  font-family:var(--sans); color:var(--t); background:#fff; font-size:11.5px; line-height:1.45;
  text-align:left; -webkit-font-smoothing:antialiased;
}
.au *{ box-sizing:border-box; }
.au .mono{ font-family:var(--mono); }
.au-pad{ padding:16px 18px; }
.au-top{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:11px 16px; border-bottom:1px solid var(--ln); color:var(--m); font-size:11px; }
.au-h1{ font-size:17px; font-weight:600; letter-spacing:-.01em; color:var(--t); }
.au-h2{ font-size:13px; font-weight:600; color:var(--t); }
.au-sub{ font-size:11px; color:var(--m); }
.au-lbl{ font-size:9.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--f); font-weight:600; }
.au-row{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.au-mut{ color:var(--m); } .au-faint{ color:var(--f); }

.au-btn{ display:inline-flex; align-items:center; gap:6px; padding:7px 12px; border-radius:8px; border:1px solid var(--ln); background:#fff; font-size:11px; font-weight:600; color:var(--t); white-space:nowrap; }
.au-btn-d{ background:#0f172a; color:#fff; border-color:#0f172a; }
.au-btn-b{ background:var(--blue); color:#fff; border-color:var(--blue); }
.au-btn-block{ width:100%; justify-content:center; padding:10px; }
.au-btn-dis{ background:#e9eef4; color:#94a3b8; border-color:#e9eef4; }

.au-pill{ display:inline-flex; align-items:center; gap:5px; padding:2px 8px; border-radius:999px; font-size:9.5px; font-weight:600; }
.au-g{ background:var(--grnS); color:var(--grn); } .au-a{ background:var(--ambS); color:var(--amb); }
.au-b{ background:var(--blueS); color:var(--blue); } .au-r{ background:var(--redS); color:var(--red); }
.au-n{ background:#eef2f7; color:var(--m); } .au-v{ background:var(--violS); color:var(--vio); }
.au-dot{ width:6px; height:6px; border-radius:999px; background:currentColor; }

.au-card{ border:1px solid var(--ln); border-radius:12px; background:#fff; }
.au-soft{ background:var(--soft); }
.au-sep{ height:1px; background:var(--ln); }

.au-table{ width:100%; border-collapse:collapse; }
.au-table th{ text-align:left; font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--f); font-weight:600; padding:8px 10px; border-bottom:1px solid var(--ln); }
.au-table td{ padding:9px 10px; border-bottom:1px solid var(--ln); font-size:11px; vertical-align:middle; }
.au-table tr:last-child td{ border-bottom:0; }
.au-table .num{ text-align:right; }

.au-search{ display:flex; align-items:center; gap:8px; border:1px solid var(--ln); border-radius:8px; padding:8px 11px; color:var(--f); background:#fff; }
.au-tabs{ display:flex; gap:6px; flex-wrap:wrap; }
.au-tab{ padding:5px 10px; border-radius:7px; font-size:10.5px; font-weight:600; color:var(--m); background:#fff; border:1px solid transparent; }
.au-tab.on{ background:#0f172a; color:#fff; }

.au-grid{ display:grid; gap:10px; }
.au-stat{ border:1px solid var(--ln); border-radius:10px; padding:11px 12px; }
.au-stat .v{ font-size:17px; font-weight:600; letter-spacing:-.02em; }
.au-stat .k{ font-size:9.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--f); margin-bottom:3px; }

/* kanban */
.au-kanban{ display:grid; grid-template-columns:repeat(5,1fr); gap:8px; }
.au-col{ background:var(--soft); border-radius:10px; padding:8px; }
.au-colh{ display:flex; align-items:center; justify-content:space-between; font-size:9px; letter-spacing:.06em; text-transform:uppercase; color:var(--m); font-weight:600; margin-bottom:8px; padding:0 2px; }
.au-ticket{ background:#fff; border:1px solid var(--ln); border-radius:8px; padding:8px; margin-bottom:7px; }
.au-ticket.acc{ border-left:2px solid var(--blue); }
.au-tk-code{ font-family:var(--mono); font-size:8.5px; color:var(--f); }
.au-tk-co{ font-size:11px; font-weight:600; margin:4px 0 3px; line-height:1.25; }
.au-tk-d{ font-size:10px; color:var(--m); line-height:1.3; }
.au-tk-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:7px; font-size:9.5px; color:var(--m); }
.au-av{ width:16px; height:16px; border-radius:999px; background:var(--blueS); color:var(--blue); display:inline-grid; place-items:center; font-size:8px; font-weight:700; }

/* stepper */
.au-step{ display:flex; align-items:center; }
.au-step .node{ display:flex; flex-direction:column; align-items:center; gap:5px; text-align:center; }
.au-step .nc{ width:26px; height:26px; border-radius:999px; border:1.5px solid var(--ln); display:grid; place-items:center; color:var(--f); font-size:11px; }
.au-step .nc.on{ border-color:#0f172a; color:#0f172a; background:#f1f5f9; }
.au-step .nc.done{ background:#0f172a; border-color:#0f172a; color:#fff; }
.au-step .nl{ font-size:9px; color:var(--m); }
.au-step .nt{ font-size:7.5px; color:var(--f); margin-top:1px; font-family:var(--mono); }
.au-step .bar{ flex:1; height:1.5px; background:var(--ln); margin:0 4px 16px; }
.au-step .bar.done{ background:#0f172a; }
.au-chatbar{ display:flex; align-items:center; gap:8px; border:1px solid var(--ln); border-radius:10px; padding:8px 10px; margin-top:10px; background:#fff; }
.au-chatbar .ci{ flex:1; color:var(--f); font-size:11px; }
.au-chatbar .cs{ width:24px; height:24px; border-radius:7px; background:#0f172a; color:#fff; display:grid; place-items:center; font-size:11px; flex:none; }

/* product grid + cart (store checkout) */
.au-prods{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.au-prod{ border:1px solid var(--ln); border-radius:9px; padding:9px; }
.au-prod.sel{ border-color:var(--blue); background:var(--blueS); }
.au-boxico{ width:22px; height:22px; border-radius:6px; background:#eef2f7; color:var(--f); display:grid; place-items:center; }
.au-pn{ font-size:11px; font-weight:600; margin-top:7px; line-height:1.2; }
.au-psku{ font-size:9px; color:var(--f); font-family:var(--mono); line-height:1.35; margin-top:2px; }
.au-pp{ font-size:12px; font-weight:600; margin-top:3px; }
.au-cart-row{ display:flex; align-items:flex-start; justify-content:space-between; padding:8px 0; border-bottom:1px solid var(--ln); gap:8px; }
.au-cart-row > div:first-child{ line-height:1.25; }
.au-qty{ display:inline-flex; align-items:center; gap:7px; border:1px solid var(--ln); border-radius:7px; padding:2px 7px; font-size:10px; }

/* chat / conversación */
.au-vis{ font-size:10px; color:var(--m); padding-bottom:11px; border-bottom:1px solid var(--ln); margin-bottom:12px; }
.au-chat{ display:flex; flex-direction:column; gap:11px; }
.au-msg{ display:flex; align-items:flex-end; gap:7px; }
.au-msg.out{ justify-content:flex-end; }
.au-bub{ max-width:80%; border-radius:12px; padding:8px 10px; }
.au-msg.out .au-bub{ background:#0f172a; color:#fff; border-bottom-right-radius:4px; }
.au-msg.in .au-bub{ background:#fff; color:var(--t); border:1px solid var(--ln); border-bottom-left-radius:4px; }
.au-bn{ font-size:9.5px; font-weight:700; margin-bottom:2px; line-height:1.2; }
.au-msg.out .au-bn{ color:#cbd5e1; }
.au-msg.in .au-bn{ color:var(--m); }
.au-bm{ font-size:11px; line-height:1.3; }
.au-bt{ font-size:9px; margin-top:3px; }
.au-msg.out .au-bt{ color:#94a3b8; }
.au-msg.in .au-bt{ color:var(--f); }
.au-cav{ width:22px; height:22px; border-radius:999px; flex:none; display:grid; place-items:center; font-size:8px; font-weight:700; }
.au-msg.out .au-cav{ background:#e2e8f0; color:#475569; }
.au-msg.in .au-cav{ background:#eef2f7; color:#64748b; }
.au-date{ align-self:center; background:#e7ecf2; color:#64748b; font-size:9.5px; font-weight:600; padding:3px 11px; border-radius:999px; }
.au-sys{ align-self:center; display:inline-flex; align-items:center; gap:7px; background:#eef2f7; color:#64748b; font-size:9.5px; padding:4px 11px; border-radius:999px; }
.au-sys .ic{ width:12px; height:12px; border-radius:3px; background:#9fb3cd; color:#fff; display:grid; place-items:center; font-size:8px; font-weight:700; font-style:normal; }
.au-sys .tm{ color:#94a3b8; }
.au-closed{ text-align:center; color:var(--m); font-size:10px; border-top:1px solid var(--ln); padding-top:11px; margin-top:13px; }

@media (max-width:560px){
  .au{ font-size:11px; }
  .au-kanban{ grid-template-columns:repeat(3,1fr); }
}

/* ---- CFDI emitir screen ---- */
.au-numbadge{ width:21px; height:21px; border-radius:6px; background:#eef2f7; color:var(--m); display:inline-grid; place-items:center; font-size:10px; font-weight:700; flex:none; }
.au-seccard{ border:1px solid var(--ln); border-radius:12px; padding:14px 15px; margin-bottom:11px; }
.au-sechead{ display:flex; align-items:center; justify-content:space-between; margin-bottom:13px; }
.au-fld{ margin-bottom:13px; }
.au-val{ font-size:12px; font-weight:500; color:var(--t); display:flex; align-items:center; gap:6px; flex-wrap:wrap; margin-top:4px; }
.au-blk{ display:inline-flex; align-items:center; gap:4px; padding:2px 7px; border-radius:6px; font-size:8.5px; font-weight:600; letter-spacing:.05em; background:#eef2f7; color:#94a3b8; font-family:var(--mono); }
.au-sel{ display:flex; align-items:center; justify-content:space-between; border:1px solid var(--ln); border-radius:8px; padding:9px 11px; font-size:11px; color:var(--m); background:#fff; margin-top:4px; }
.au-sel.amber{ border-color:#ecc673; background:#fffbf2; color:#b07d18; font-style:italic; }
.au-input2{ border:1px solid var(--ln); border-radius:8px; padding:9px 11px; font-size:11px; color:var(--t); background:#fff; margin-top:4px; }
.au-prog{ height:5px; border-radius:999px; background:#eef2f7; overflow:hidden; margin:2px 0 13px; }
.au-prog i{ display:block; height:100%; width:0%; background:var(--blue); }
.au-warn{ display:flex; align-items:center; gap:10px; padding:6px 0; font-size:11.5px; color:var(--t); }
.au-warn .wi{ width:17px; height:17px; flex:none; color:#d9a23a; }
.au-verify{ color:#b07d18; font-size:10px; font-weight:600; }
.au-conf{ display:flex; gap:10px; padding:11px; border-radius:9px; background:#fffbf2; border:1px solid #f0dcab; }
.au-check{ width:15px; height:15px; border:1.5px solid #cbd5e1; border-radius:4px; flex:none; }
.au-tot-row{ display:flex; align-items:center; justify-content:space-between; padding:7px 0; font-size:12px; }
