/* Reset */
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background: #f4f7fb;
  color: #2b2f33;
  font: 14px/1.45 Arial, Helvetica, sans-serif;
}

/* Lienzo */
.sheet {
  max-width: 1200px;
  margin: 18px auto;
  padding: 0 14px;
}

/* Header */
.header { background:#fff; border:1px solid #cfd8dc; border-radius:10px; overflow:hidden; }
.header .row-1 { display:flex; align-items:center; gap:12px; padding:10px 12px; border-bottom:1px solid #e3e8ee; }
.header .logo { width:400px; min-height:176px; display:flex; align-items:center; justify-content:center; }
.header .logo img { max-height:176px; max-width:400px; }
.header .title { flex:1; text-align:center; font-size:18px; font-weight:700; letter-spacing:.3px; }

/* Header row 2 */
.header .row-2 { display:grid; grid-template-columns:repeat(4,1fr); }
.hdr-cell { display:flex; flex-direction:column; border-top:1px solid #edf2f7; border-right:1px solid #edf2f7; }
.hdr-cell:last-child{ border-right:none; }
.hdr-label { background:#eef2f7; color:#4b5563; font-size:12px; padding:6px 10px; border-bottom:1px solid #e3e8ee; }
.hdr-value { padding:8px 10px; }

/* Panels */
.form-sheet { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:12px; }
.panel { background:#fff; border:1px solid #cfd8dc; border-radius:10px; overflow:hidden; }
.panel .row { display:grid; grid-template-columns:230px 1fr; }
.panel .row + .row .cell { border-top:1px solid #e8edf3; }
.panel .cell { min-height:40px; display:flex; align-items:center; }
.panel .cell.label { background:#eef2f7; color:#354052; padding:6px 10px; }
.panel .cell:not(.label){ padding:6px 10px; }

input, select {
  height: 32px;
  border: 1px solid #cfd8dc;
  border-radius: 6px;
  padding: 4px 8px;
  background: #fff;
  width: 100%;
}
input.ro { background:#f2f4f7; }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }

.note { padding:10px; color:#4b5563; font-size:12px; }

/* Tables */
.table-card { background:#fff; border:1px solid #cfd8dc; border-radius:10px; margin-top:12px; overflow:auto; }
.table { border-collapse:collapse; width:100%; min-width:760px; }
.table.table-compact { min-width:680px; }
.table thead th {
  position: sticky;
  top: 0;
  background:#0b7a55;   /* verde similar a tu ejemplo visual */
  color:#fff;
  border-bottom:1px solid #0a6a4a;
  padding:8px 10px;
  font-size:12px;
  text-align:center;
}
.table td {
  border-top:1px solid #e5e7eb;
  border-right:1px solid #eff3f6;
  padding:6px;
}
.table td:last-child { border-right:none; }
.table input {
  width:100%;
  height:28px;
  border:1px solid #cfd8dc;
  border-radius:6px;
  padding:3px 6px;
}
.left { text-align:left; }
.strong { font-weight:700; }

/* Actions + status */
.actions { display:flex; gap:10px; padding:10px; border-top:1px solid #e7edf3; }
.btn { border:1px solid transparent; border-radius:8px; padding:10px 14px; cursor:pointer; font-weight:700; }
.btn.blue { background:#0d6efd; color:#fff; flex:1; }
.btn.gray { background:#e9eef5; color:#111827; }

.status { padding:10px; }
.status .alert { padding:10px; border-radius:8px; }
.alert-info { background:#e7f1ff; border:1px solid #b3d2ff; }
.alert-success { background:#e9f7ef; border:1px solid #c6e6d1; }
.alert-danger { background:#fdeaea; border:1px solid #f3c2c2; }
.alert-warning { background:#fff6e5; border:1px solid #ffe0a3; }

/* Responsive */
@media (max-width: 980px) {
  .form-sheet { grid-template-columns:1fr; }
  .panel .row { grid-template-columns:180px 1fr; }
  .header .row-2 { grid-template-columns:repeat(auto-fit, minmax(180px, 1fr)); }
}
@media (max-width: 560px) {
  .panel .row { grid-template-columns:1fr; }
  .panel .cell.label { border-bottom:1px solid #e8edf3; }
  .actions { flex-direction:column; }
}

.sheet {
  max-width: 100%;
  width: 100%;
}
/* === Responsive overrides (solo estilo; sin cambios de lógica) === */
:root{
  /* Límites y escalas fluidas */
  --sheet-max: 1200px;
  --gap: 12px;

  /* Columna de etiqueta de formulario */
  --label-min: 120px;
  --label-ideal: 24vw; /* proporción relativa al viewport */
  --label-max: 260px;

  /* Logo: mantén el máximo actual, pero permite reducir en móviles */
  --logo-min: 120px;
  --logo-ideal: 28vw;
  --logo-max: 400px;  /* coincide con tu width original */
  --logo-h-min: 64px;
  --logo-h-ideal: 14vw;
  --logo-h-max: 176px; /* coincide con tu min-height y max-height originales */
}

/* Lienzo principal: ancho y padding fluidos + scroll-x seguro */
.sheet{
  max-width: min(var(--sheet-max), 100%);
  width: 100%;
  margin: clamp(10px, 2vw, 18px) auto;
  padding-left: clamp(10px, 2vw, 18px);
  padding-right: clamp(10px, 2vw, 18px);
  overflow-x: auto;
}

/* Header fluido (gap y padding escalan) */
.header .row-1{
  gap: clamp(8px, 2vw, 16px);
  padding: clamp(8px, 1.4vw, 12px) clamp(10px, 2vw, 12px);
}

/* Logo escalable (respeta tus máximos) */
.header .logo{
  width: clamp(var(--logo-min), var(--logo-ideal), var(--logo-max));
  min-height: clamp(var(--logo-h-min), var(--logo-h-ideal), var(--logo-h-max));
}
.header .logo img{
  max-width: 100%;
  max-height: clamp(var(--logo-h-min), var(--logo-h-ideal), var(--logo-h-max));
}

/* Título que ajusta tamaño sin romper en renglones raros */
.header .title{
  font-size: clamp(16px, 2.2vw, 22px);
  line-height: 1.2;
  text-wrap: balance;
}

/* Fila Código/Fecha/Revisión/Pág.: ahora auto-fit por defecto */
.header .row-2{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

/* Paneles: malla fluida a 1 o 2+ columnas según espacio */
.form-sheet{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
  gap: var(--gap);
}

/* Fila del panel: etiqueta con ancho por clamp, contenido líquido */
.panel .row{
  display: grid;
  grid-template-columns: clamp(var(--label-min), var(--label-ideal), var(--label-max)) 1fr;
}

/* Inputs: ancho/alto fluidos y tocabilidad mejorada */
input, select{
  width: 100%;
  max-width: 100%;
  height: clamp(28px, 4.2vw, 32px);
}

/* Tablas: scroll cuando haga falta + ancho mínimo adaptable */
.table-card{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Opción por defecto (compacta y usable en laptop y móvil): */
.table{
  width: 100%;
  min-width: clamp(720px, 95vw, 1100px);
}


/* Cabeceras y paddings fluidos para legibilidad */
.table thead th{
  font-size: clamp(11px, 1.2vw, 12px);
  padding: clamp(6px, 1vw, 10px);
}

/* Acciones: que envuelvan en móviles con buen espacio */
.actions{
  flex-wrap: wrap;
  gap: clamp(8px, 1.2vw, 12px);
}
.btn{
  flex: 1 1 220px;
}
.btn.blue{
  flex: 2 1 260px;
}

/* Refuerzo móvil extremo (puedes conservar tus @media existentes) */
@media (max-width: 560px){
  .panel .row{ grid-template-columns: 1fr; }
  .panel .cell.label{ border-bottom: 1px solid #e8edf3; }
}
/* === Aprovechar todo el ancho de pantalla (full-width) === */
:root{
  /* Ajustes fluidos reutilizables */
  --sheet-max: 100%;         /* queremos pantalla completa */
  --gap: 12px;

  /* Columna etiqueta del formulario */
  --label-min: 120px;
  --label-ideal: 22vw;
  --label-max: 260px;

  /* Logo/header fluidos (respetan tus máximos actuales) */
  --logo-w-min: 120px;
  --logo-w-ideal: 22vw;
  --logo-w-max: 400px;   /* tu width original */
  --logo-h-min: 56px;
  --logo-h-ideal: 10vw;
  --logo-h-max: 176px;   /* tu alto original */
}

/* 1) Lienzo: cancela cualquier max-width anterior y úsalo a pantalla completa */
.sheet{
  max-width: var(--sheet-max) !important;
  width: 100% !important;
  margin: clamp(8px, 2vw, 18px) auto;
  padding-left: clamp(10px, 2vw, 18px);
  padding-right: clamp(10px, 2vw, 18px);
  overflow-x: auto;
}

/* 2) Header fluido */
.header .row-1{
  gap: clamp(8px, 2vw, 16px);
  padding: clamp(8px, 1.4vw, 12px) clamp(10px, 2vw, 12px);
}
.header .logo{
  width: clamp(var(--logo-w-min), var(--logo-w-ideal), var(--logo-w-max));
  min-height: clamp(var(--logo-h-min), var(--logo-h-ideal), var(--logo-h-max));
}
.header .logo img{
  max-width: 100%;
  max-height: clamp(var(--logo-h-min), var(--logo-h-ideal), var(--logo-h-max));
}
.header .title{
  font-size: clamp(16px, 2.2vw, 22px);
  line-height: 1.2;
  text-wrap: balance;
}
/* Metadatos: que se acomoden solos */
.header .row-2{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

/* 3) Formulario: deja que escale a 1, 2 o más columnas según espacio */
.form-sheet{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(320px, 100%), 1fr));
  gap: var(--gap);
}

/* 4) Filas del panel: etiqueta con ancho variable por clamp */
.panel .row{
  display: grid;
  grid-template-columns: clamp(var(--label-min), var(--label-ideal), var(--label-max)) 1fr;
}

/* 5) Inputs 100% y altura tocable según pantalla */
input, select{
  width: 100%;
  max-width: 100%;
  height: clamp(28px, 4.2vw, 32px);
}

/* 6) Tablas: ocupan ancho completo y solo muestran scroll si hace falta */
.table-card{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.table{
  width: 100%;
  min-width: clamp(720px, 95vw, 1100px); /* compacta y usable en laptop/móvil */
  /* Si quieres columnas más holgadas (como el otro formulario), cambia por:
     min-width: clamp(1600px, 200vw, 2600px);
  */
}
.table thead th{
  font-size: clamp(11px, 1.2vw, 12px);
  padding: clamp(6px, 1vw, 10px);
}

/* 7) Acciones: botones que envuelven en pantallas pequeñas */
.actions{
  flex-wrap: wrap;
  gap: clamp(8px, 1.2vw, 12px);
}
.btn{      flex: 1 1 220px; }
.btn.blue{ flex: 2 1 260px; }

/* Refuerzo móvil extremo (puedes conservar tus @media actuales) */
@media (max-width: 560px){
  .panel .row{ grid-template-columns: 1fr; }
  .panel .cell.label{ border-bottom: 1px solid #e8edf3; }
}


.pdf-autofilled { background-color:#fff3b0 !important; }
.massive-upload-shell { margin-top: 22px; }
.massive-header .row-1 { min-height: 112px; }
.massive-header .logo { width: 180px; min-height: 92px; }
.massive-header .logo img { max-width: 150px; max-height: 88px; }
.mass-actions-row { display:flex; gap:10px; flex-wrap:wrap; }
.mass-actions-row .btn { flex:1 1 220px; }
.massive-receipts-container { display:flex; flex-direction:column; gap:16px; margin-top:16px; }
.mass-receipt-card { background:#fff; border:1px solid #cfd8dc; border-radius:12px; padding:14px; box-shadow:0 2px 6px rgba(0,0,0,.05); }
.mass-receipt-top { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:10px; }
.mass-receipt-title { font-size:18px; font-weight:700; color:#0b7a55; }
.mass-receipt-subtitle { color:#4b5563; font-size:12px; word-break:break-all; }
.mass-receipt-badge { background:#eef2f7; border:1px solid #d9e1ea; padding:6px 10px; border-radius:999px; font-size:12px; font-weight:700; }
.mass-mini-card { margin-top:10px; }
.mass-form-grid { margin-top:10px; }
.mass-extra-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:10px; margin-top:10px; }
.mass-extra-grid label { display:flex; flex-direction:column; gap:6px; font-size:12px; color:#374151; }
.mass-extra-grid input { width:100%; }
@media (max-width: 700px) {
  .mass-receipt-top { flex-direction:column; align-items:flex-start; }
  .mass-actions-row { flex-direction:column; }
}


/* Bloque de datos superiores del recibo */
.receipt-meta-card .table td label{
  display:block;
  font-weight:700;
  color:#354052;
  font-size:12px;
}
.receipt-meta-card .table td input{
  margin-top:4px;
}
.mass-details-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap:10px;
  padding:10px;
}
.mass-details-grid label{
  display:flex;
  flex-direction:column;
  gap:4px;
  font-size:12px;
  color:#354052;
  font-weight:700;
}
.mass-details-grid input{ width:100%; }
.massive-upload-shell{ margin-top:20px; }
.massive-receipts-container{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin-top:12px;
}
.mass-receipt-card{
  background:#fff;
  border:1px solid #cfd8dc;
  border-radius:10px;
  padding:12px;
}
.mass-receipt-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.mass-receipt-title{ font-size:18px; font-weight:700; }
.mass-receipt-subtitle{ color:#4b5563; font-size:12px; }
.mass-receipt-badge{
  background:#e7f1ff;
  border:1px solid #b3d2ff;
  color:#0d6efd;
  padding:6px 10px;
  border-radius:20px;
  font-weight:700;
  font-size:12px;
}
.mass-mini-card{ margin-top:12px; }
.mass-form-grid{ margin-top:12px; }
.mass-actions-row{ display:flex; gap:10px; flex-wrap:wrap; }
.hdr-cell-actions .hdr-value{ display:flex; align-items:center; }


.menu-cfe{display:flex;gap:12px;margin:16px 0 20px 0;flex-wrap:wrap;}
.menu-cfe .btn{min-width:220px;}
#barraRegresarCfe{justify-content:flex-start;}
.mass-upload-status{
  margin: 12px 0 16px 0;
  padding: 12px 16px;
  border-radius: 10px;
  font-weight: 600;
  border: 1px solid #cfd8dc;
  background: #eef6ff;
  color: #0b5394;
}

.mass-upload-status.success{
  background: #e9f7ef;
  color: #1e7e34;
  border-color: #b7e1c1;
}

.mass-upload-status.warning{
  background: #fff8e1;
  color: #8a6d3b;
  border-color: #f3df9b;
}

.mass-upload-status.error{
  background: #fdecea;
  color: #a94442;
  border-color: #f5c6cb;
}

.mass-upload-status.info{
  background: #eef6ff;
  color: #0b5394;
  border-color: #bcdcff;
}
