
:root{--red:#d62828;--dark:#111;--muted:#f0f0f0;--line:#222}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#e9e9e9;color:#111}
.container{max-width:1220px;margin:24px auto;padding:0 16px}
.top{background:#111;color:white;padding:18px 22px;border-radius:12px;margin-bottom:18px;display:flex;justify-content:space-between;align-items:center;gap:12px}
h1{margin:0;font-size:23px}.sub{font-size:12px;color:#ddd;margin-top:5px}
.btn{display:inline-block;padding:10px 14px;border-radius:8px;background:var(--red);color:white;text-decoration:none;border:0;font-weight:bold;cursor:pointer;font-size:14px}
.btn.dark{background:#222}.btn.grey{background:#777}.btn.red{background:#9b111e}.btn.light{background:#ddd;color:#111}
.card{background:white;border-radius:12px;padding:18px;box-shadow:0 4px 16px rgba(0,0,0,.09);margin-bottom:18px}
table.list{width:100%;border-collapse:collapse;background:white}table.list th,table.list td{border-bottom:1px solid #ddd;padding:10px;text-align:left;font-size:14px;vertical-align:middle}
.layout{display:grid;grid-template-columns:430px 1fr;gap:18px;align-items:start}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;margin-bottom:14px}
.step{padding:8px 6px;background:#ddd;border-radius:8px;font-size:11px;text-align:center;font-weight:bold}
.step.active{background:var(--red);color:white}
.question{border:1px solid #ddd;padding:18px;border-radius:12px;background:#fbfbfb}
.hidden{display:none}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
label{font-weight:bold;display:block;margin-bottom:6px;font-size:14px}
input,select,textarea{width:100%;padding:10px;border:1px solid #bbb;border-radius:7px;font-size:14px;background:white}
textarea{min-height:110px;resize:vertical}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px;justify-content:space-between}
.actions-left,.actions-right{display:flex;gap:10px;flex-wrap:wrap}
.note{font-size:12px;color:#666;margin-top:7px}
.preview-card{background:white;border-radius:12px;padding:16px;box-shadow:0 4px 16px rgba(0,0,0,.09)}
.preview-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.preview-head h2{margin:0;font-size:18px}
.sheet{width:210mm;min-height:297mm;background:white;margin:0 auto;padding:12mm;box-sizing:border-box;border:1px solid #bbb;transform-origin:top center;transform:scale(.72);margin-bottom:-82mm}
.header{display:grid;grid-template-columns:1fr 1.2fr;border:2px solid #222;margin-bottom:10px}.header div{padding:14px;text-align:center;font-weight:bold;font-size:18px;background:#eee}.header div+div{border-left:2px solid #222}
.data-table{width:100%;border-collapse:collapse;table-layout:fixed;margin-bottom:12px}.data-table td{border:1.5px solid #222;padding:8px;font-size:12px;height:30px}.label-cell{background:#d62828;color:white;font-weight:bold;text-align:center}.value{background:white;word-wrap:break-word}
.section-title{background:#222;color:white;padding:8px 10px;font-weight:bold;border:1.5px solid #222;margin-top:10px;font-size:13px}.box{border:1.5px solid #222;min-height:70px;padding:10px;font-size:12px;white-space:pre-wrap}
.check-table{width:60%;border-collapse:collapse;margin:14px 0}.check-table td{border:1.5px solid #222;padding:8px;font-size:12px}.check-table .head{background:#222;color:white;font-weight:bold;text-align:center}.checkmark{text-align:center;font-size:16px;font-weight:bold}
.mockup{border:2px solid #222;min-height:105mm;display:flex;align-items:center;justify-content:center;background:#f8f8f8;overflow:hidden;text-align:center;color:#777;font-weight:bold}.mockup img{max-width:100%;max-height:103mm;object-fit:contain}
.badge{display:inline-block;padding:5px 8px;border-radius:6px;background:#eee;font-size:12px;font-weight:bold}
.products-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.product-card{border:1px solid #ddd;border-radius:12px;padding:14px;background:#fff}
.product-card h3{margin:0 0 8px 0}
@media(max-width:1050px){.layout{grid-template-columns:1fr}.sheet{transform:scale(.60);margin-bottom:-118mm}}
@media print{body{background:white}.no-print{display:none!important}.container{margin:0;padding:0;max-width:none}.preview-card{box-shadow:none;padding:0}.sheet{border:0;transform:none;margin:0;width:210mm;min-height:297mm;page-break-after:always}@page{size:A4;margin:0}}

.search-box{display:grid;grid-template-columns:1.8fr 1fr auto;gap:12px;align-items:end}
.search-actions{display:flex;gap:8px;align-items:end}
.table-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.table-head h2{margin:0;font-size:18px}
@media(max-width:800px){.search-box{grid-template-columns:1fr}.search-actions{justify-content:flex-start}}

.estampacion-block{border:1px solid #ddd;border-radius:10px;padding:12px;margin-top:12px;background:white}
.estampacion-block h3{margin:0 0 10px 0;font-size:15px}
.stamp-card{border:1.5px solid #222;display:grid;grid-template-columns:1.2fr .8fr;gap:8px;margin-top:8px;padding:8px;font-size:12px;break-inside:avoid}
.stamp-img{border:1px solid #999;min-height:80px;display:flex;align-items:center;justify-content:center;background:#f8f8f8;color:#777;font-weight:bold}
.stamp-img img{max-width:100%;max-height:120px;object-fit:contain}
.stamp-info{line-height:1.35}

canvas#autoMockupCanvas{display:block;margin-top:8px}

/* V6: canvas más ancho con vista frontal y espalda */
#autoMockupCanvas{max-width:100%;height:auto;}

/* V7: dos siluetas reales para camiseta */
#autoMockupCanvas{max-width:100%;height:auto;}

/* V8 imágenes reales */
#autoMockupCanvas{max-width:100%;height:auto;background:#f7f7f7;}

/* V9 UI más limpia y profesional */
:root{
  --blue:#0f48b5;
  --blue2:#174ea6;
  --bg:#f4f7fb;
  --border:#d8e0ee;
}
body{
  background:var(--bg);
}
.top{
  background:#ffffff;
  color:#111;
  border:1px solid var(--border);
  box-shadow:0 4px 18px rgba(15,72,181,.08);
}
.top h1{
  color:var(--blue);
  letter-spacing:.2px;
}
.sub{color:#5f6b7a}
.btn{
  background:var(--blue);
  box-shadow:0 2px 8px rgba(15,72,181,.18);
}
.btn.dark{background:#123e88}
.btn.grey{background:#eef3fb;color:#123e88;border:1px solid #c7d5ee}
.btn.light{background:#edf2fb;color:#123e88;border:1px solid #c7d5ee}
.card,.preview-card{
  border:1px solid var(--border);
  box-shadow:0 8px 26px rgba(15,72,181,.08);
}
.step{
  background:#eef3fb;
  color:#123e88;
  border:1px solid #d6e2f5;
}
.step.active{
  background:var(--blue);
  color:white;
}
.question{
  background:#ffffff;
  border:1px solid var(--border);
}
label{
  color:#0f3f99;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:.25px;
}
input,select,textarea{
  border:1px solid #c6d3e8;
  background:#fff;
}
input:focus,select:focus,textarea:focus{
  outline:2px solid rgba(15,72,181,.18);
  border-color:var(--blue);
}
.preview-head h2{
  color:var(--blue);
}
.section-title{
  background:#123e88;
}
.label-cell{
  background:#0f48b5;
}
#autoMockupCanvas{
  border:1px solid #c6d3e8 !important;
  box-shadow:inset 0 0 0 1px #eef3fb;
}
.badge{
  background:#eef3fb;
  color:#123e88;
}

.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:#f5f7fb}.sidebar{background:#0f1b2b;color:white;display:flex;flex-direction:column;padding:18px 14px;position:sticky;top:0;height:100vh}.brand{display:flex;gap:12px;align-items:center;margin-bottom:28px}.brand-icon{display:inline-flex;width:42px;height:42px;border-radius:10px;background:#ff7900;align-items:center;justify-content:center;font-weight:bold;font-size:24px}.brand span{color:#ff7900}.brand small{display:block;color:#b7c1d1;margin-top:3px}.sidebar nav{display:flex;flex-direction:column;gap:8px}.sidebar nav a{color:white;text-decoration:none;padding:13px 14px;border-radius:9px}.sidebar nav a.active,.sidebar nav a:hover{background:#ff7900}.sidebar-foot{margin-top:auto;color:#9fb0c5;font-size:12px;padding:14px}.main-panel{padding:22px}.toggle-products{width:32px;height:32px;border-radius:8px;border:1px solid #cbd6e8;background:#eef3fb;color:#0f48b5;font-weight:bold;cursor:pointer}.products-expand{background:#f8fbff;border:1px solid #dbe6f5;border-radius:12px;padding:14px}.mini-list{width:100%;border-collapse:collapse;margin-top:10px;background:white}.mini-list th,.mini-list td{border-bottom:1px solid #e0e6f0;padding:8px;font-size:13px;text-align:left}.hidden{display:none!important}.btn.red{background:#d62828;color:white}@media(max-width:1000px){.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.main-panel{padding:12px}}


/* V12: barra lateral persistente en pantallas principales */
.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:#f5f7fb}
.sidebar{background:#0f1b2b;color:white;display:flex;flex-direction:column;padding:18px 14px;position:sticky;top:0;height:100vh;z-index:5}
.brand{display:flex;gap:12px;align-items:center;margin-bottom:28px}
.brand-icon{display:inline-flex;width:42px;height:42px;border-radius:10px;background:#ff7900;align-items:center;justify-content:center;font-weight:bold;font-size:24px}
.brand span{color:#ff7900}.brand small{display:block;color:#b7c1d1;margin-top:3px}
.sidebar nav{display:flex;flex-direction:column;gap:8px}
.sidebar nav a{color:white;text-decoration:none;padding:13px 14px;border-radius:9px;border:1px solid transparent}
.sidebar nav a.active,.sidebar nav a:hover{background:#ff7900}
.sidebar-foot{margin-top:auto;color:#9fb0c5;font-size:12px;padding:14px}
.main-panel{padding:22px;min-width:0}
.main-panel .container{max-width:1280px}
@media(max-width:1000px){.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.main-panel{padding:12px}}

/* V13 módulo productos */
.thumb{width:58px;height:58px;object-fit:contain;border:1px solid #dbe6f5;border-radius:8px;background:white}.chips{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 18px}.chip{display:inline-flex;align-items:center;gap:5px;padding:8px 10px;border:1px solid #cbd6e8;border-radius:20px;background:#f8fbff;color:#123e88;text-transform:none;font-size:13px;letter-spacing:0}.mockup-row{border:1px solid #e3e9f3;border-radius:10px;padding:10px;background:#fbfdff;margin-bottom:10px}.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:18px}.product-main-img{max-width:100%;max-height:260px;object-fit:contain;background:white;border:1px solid #dbe6f5;border-radius:12px;margin-bottom:15px}.mockup-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.mockup-thumb{border:1px solid #dbe6f5;border-radius:12px;padding:10px;background:#fbfdff;text-align:center}.mockup-thumb img{width:100%;height:160px;object-fit:contain}@media(max-width:900px){.product-detail{grid-template-columns:1fr}}

/* V14 jerarquía sidebar + correcciones producto + clientes */
.side-nav{display:flex;flex-direction:column;gap:14px}
.nav-group{border-top:1px solid rgba(255,255,255,.10);padding-top:10px}
.nav-title{font-weight:800;color:#ff7900;font-size:13px;text-transform:uppercase;letter-spacing:.5px;margin:4px 0 6px}
.nav-group a,.nav-group span,.install-link{display:block;color:white;text-decoration:none;padding:8px 10px;border-radius:8px;font-size:14px}
.nav-group a:hover,.install-link:hover{background:#ff7900}
.nav-group.muted span{color:#8fa0b8}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 20px;clear:both}
.chip{display:inline-flex!important;align-items:center;gap:6px;min-height:34px;padding:8px 12px!important;border:1px solid #cbd6e8;border-radius:20px;background:#f8fbff;color:#123e88;text-transform:none!important;font-size:13px!important;letter-spacing:0!important;width:auto!important}
.chip input{width:auto!important;margin:0!important}
.card h3{margin-top:18px;margin-bottom:6px;color:#123e88}
input[readonly]{background:#eef3fb;color:#526173}

/* V15 sidebar desplegable + logo + proveedores */
.logo-brand{justify-content:center;margin-bottom:22px}
.logo-brand img{max-width:205px;max-height:70px;object-fit:contain;background:white;border-radius:12px;padding:8px}
.side-nav{display:flex;flex-direction:column;gap:8px;overflow:auto;padding-right:2px}
.nav-group{border-top:1px solid rgba(255,255,255,.10);padding-top:8px}
.nav-title{width:100%;background:transparent;border:0;color:#ff7900;font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.5px;padding:8px 4px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left}
.nav-title span{font-size:11px;color:#d8dee8}
.nav-sub{display:flex;flex-direction:column;gap:4px;margin-left:8px;margin-bottom:6px}
.nav-sub.closed{display:none}
.nav-sub a,.install-link{display:block;color:white;text-decoration:none;padding:8px 10px;border-radius:8px;font-size:14px}
.nav-sub a:hover,.install-link:hover{background:#ff7900}
.install-link{margin-top:8px;border-top:1px solid rgba(255,255,255,.10)}
.sidebar-foot{font-size:11px}

/* V16 documentos/inventario + logo ajustado */
.logo-brand{justify-content:flex-start!important;gap:8px!important;margin-bottom:22px!important}
.logo-brand img{max-width:112px!important;max-height:54px!important;object-fit:contain;background:transparent!important;border-radius:0!important;padding:0!important;margin-left:-6px!important}
.logo-brand .brand-text{display:flex;flex-direction:column;line-height:1.05}
.logo-brand .brand-text b{font-size:16px;color:white}
.logo-brand .brand-text span{font-size:13px;color:#ff7900;font-weight:800}
.nav-sub.closed{display:none!important}
.mini-list input{width:100%;box-sizing:border-box;padding:7px;border:1px solid #cbd6e8;border-radius:6px}

/* V17 preview imágenes + selectores + documentos PDF */
.preview-box{margin-top:8px;min-height:90px;border:1px dashed #cbd6e8;border-radius:10px;background:#fbfdff;display:flex;align-items:center;justify-content:center;padding:8px}
.preview-box img{max-width:100%;max-height:120px;object-fit:contain}
.preview-box.mini{min-height:64px}
.preview-box.mini img{max-height:80px}
.inline-pick{display:flex;gap:8px;align-items:center}
.inline-pick input{flex:1}
.picker-modal{position:fixed;inset:0;background:rgba(15,27,43,.55);z-index:9999;display:flex;align-items:center;justify-content:center}
.picker-card{width:min(760px,92vw);max-height:80vh;background:white;border-radius:16px;padding:18px;box-shadow:0 18px 60px rgba(0,0,0,.25);overflow:auto}
.picker-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.picker-results{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.picker-item{border:1px solid #dbe6f5;border-radius:10px;padding:12px;cursor:pointer;background:#fbfdff}
.picker-item:hover{background:#eef3fb}
.picker-item span{display:block;color:#64748b;font-size:13px;margin-top:3px}

/* V18 documentos: descripción corta y PDF mejorado */
.line-desc{font-size:12px;color:#657184;margin-top:4px;line-height:1.25}
.inline-pick{align-items:flex-start}

/* V19 proveedor selector + PDF comercial */
.inline-pick{display:flex;gap:8px;align-items:flex-start}
.inline-pick input{flex:1}
.picker-modal{position:fixed;inset:0;background:rgba(15,27,43,.55);z-index:9999;display:flex;align-items:center;justify-content:center}
.picker-card{width:min(760px,92vw);max-height:80vh;background:white;border-radius:16px;padding:18px;box-shadow:0 18px 60px rgba(0,0,0,.25);overflow:auto}
.picker-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.picker-results{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.picker-item{border:1px solid #dbe6f5;border-radius:10px;padding:12px;cursor:pointer;background:#fbfdff}
.picker-item:hover{background:#eef3fb}
.picker-item span{display:block;color:#64748b;font-size:13px;margin-top:3px}

/* V20 importador Excel */
.import-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.import-card{border:1px solid #dbe6f5;background:#fbfdff;border-radius:14px;padding:16px}
.import-card h3{margin-top:0;color:#0f1b2b}
.table-scroll{overflow:auto;max-height:520px;border:1px solid #e5eaf2;border-radius:10px}
.alert.red{background:#ffecec;border:1px solid #e44;color:#900;border-radius:10px;padding:10px}
pre{background:#0f1b2b;color:white;border-radius:10px;padding:12px;white-space:pre-wrap}

/* V21 pedidos directos + atributos por línea */
.attrs-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;min-width:260px}
.attrs-grid input{width:100%;box-sizing:border-box;padding:7px;border:1px solid #cbd6e8;border-radius:6px}
.attrs-grid .attr-wide{grid-column:1 / -1}
.attr-help{font-size:11px;color:#657184;margin-top:5px;line-height:1.3}
.mini-list td{vertical-align:top}

/* V22 servir pedidos / albaranes parciales */
.badge{white-space:nowrap}
.list input{max-width:120px}

/* V23 servir línea completa + datos pago factura */
.serve-cell{display:flex;flex-direction:column;gap:6px;min-width:170px}
.serve-cell input{max-width:130px}
.serve-cell .btn{font-size:12px;padding:7px 9px}

/* V24 fix botón servir completo */
#btn-servir-todo{font-weight:700}
.servir-linea-completa{white-space:normal}

/* V25 matriz tallas + mapeo Excel */
.talla-matrix-box{grid-column:1 / -1;margin-top:6px}
.matrix-title{font-size:12px;font-weight:700;color:#123e88;margin-bottom:4px}
.size-matrix{display:grid;grid-template-columns:repeat(auto-fit,minmax(62px,1fr));gap:5px;background:#f8fbff;border:1px solid #dbe6f5;border-radius:8px;padding:7px}
.size-matrix label{display:flex;flex-direction:column;gap:3px;font-size:11px;font-weight:700;color:#123e88}
.size-matrix input{padding:5px!important;text-align:center}
.color-select{width:100%;padding:7px;border:1px solid #cbd6e8;border-radius:6px}

/* V27 servicio por tallas */
.serve-line-card{border-left:5px solid #0f48b5}
.serve-line-head{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:12px}
.serve-summary{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.serve-summary span{background:#eef3fb;border:1px solid #dbe6f5;border-radius:8px;padding:8px 10px;color:#123e88}
.serve-size-table input{max-width:110px;padding:8px;border:1px solid #cbd6e8;border-radius:8px}
.serve-size-table .btn{font-size:12px;padding:7px 10px}
@media(max-width:900px){.serve-line-head{flex-direction:column}.serve-summary{justify-content:flex-start}}

/* V28 pedido a orden de trabajo */
.note{color:#657184;font-size:13px;line-height:1.35}
