/**
 * COFIEL v2 Design System — Bootstrap 5.3 base
 * Active when <body class="cofiel-v2"> (CP1+). Tokens available globally via :root.
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root,
[data-bs-theme="light"] {
  /* COFIEL brand tokens */
  --cofiel-primary: #2B59C3;
  --cofiel-primary-hover: #2349A8;
  --cofiel-primary-active: #1D3D8C;
  --cofiel-primary-light: #EBF0FA;
  --cofiel-primary-muted: #D6E2F7;

  --cofiel-bg-page: #F3F4F6;
  --cofiel-bg-card: #FFFFFF;
  --cofiel-bg-sidebar: #FFFFFF;
  --cofiel-bg-topbar: #FFFFFF;
  --cofiel-bg-input: #FFFFFF;
  --cofiel-bg-hover: #F9FAFB;
  --cofiel-bg-active: #EBF0FA;

  --cofiel-border: #D1D5DB;
  --cofiel-border-light: #E5E7EB;
  --cofiel-border-focus: #2B59C3;

  --cofiel-text: #111827;
  --cofiel-text-secondary: #4B5563;
  --cofiel-text-muted: #6B7280;
  --cofiel-text-placeholder: #9CA3AF;
  --cofiel-text-inverse: #FFFFFF;
  --cofiel-text-link: #2B59C3;

  --cofiel-success: #16A34A;
  --cofiel-success-hover: #15803D;
  --cofiel-success-active: #166534;
  --cofiel-success-bg: #DCFCE7;
  --cofiel-success-light: #F0FDF4;
  --cofiel-success-muted: #BBF7D0;
  --cofiel-warning: #D97706;
  --cofiel-warning-bg: #FEF3C7;
  --cofiel-danger: #DC2626;
  --cofiel-danger-bg: #FEE2E2;
  --cofiel-info: #0284C7;
  --cofiel-info-bg: #E0F2FE;

  --cofiel-font: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --cofiel-font-size-xs: 11px;
  --cofiel-font-size-sm: 13px;
  --cofiel-font-size-base: 14px;
  --cofiel-font-size-md: 16px;
  --cofiel-font-size-lg: 18px;
  --cofiel-font-size-xl: 24px;
  --cofiel-font-size-2xl: 30px;

  --cofiel-space-1: 4px;
  --cofiel-space-2: 8px;
  --cofiel-space-3: 12px;
  --cofiel-space-4: 16px;
  --cofiel-space-5: 20px;
  --cofiel-space-6: 24px;
  --cofiel-space-8: 32px;
  --cofiel-space-10: 40px;

  --cofiel-radius-sm: 6px;
  --cofiel-radius: 8px;
  --cofiel-radius-lg: 12px;
  --cofiel-radius-full: 9999px;

  --cofiel-shadow-xs: 0 1px 2px rgba(17, 24, 39, 0.05);
  --cofiel-shadow-sm: 0 1px 3px rgba(17, 24, 39, 0.08), 0 1px 2px rgba(17, 24, 39, 0.04);
  --cofiel-shadow: 0 4px 6px -1px rgba(17, 24, 39, 0.08), 0 2px 4px -2px rgba(17, 24, 39, 0.04);
  --cofiel-shadow-md: 0 10px 15px -3px rgba(17, 24, 39, 0.08), 0 4px 6px -4px rgba(17, 24, 39, 0.04);

  --cofiel-topbar-height: 64px;
  --cofiel-sidebar-width: 240px;
  --cofiel-content-max-width: 1280px;
  --cofiel-transition: 150ms ease;

  /* Bootstrap 5 variable overrides (applied in v2 shell) */
  --bs-body-font-family: var(--cofiel-font);
  --bs-body-font-size: var(--cofiel-font-size-base);
  --bs-body-color: var(--cofiel-text);
  --bs-body-bg: var(--cofiel-bg-page);
  --bs-primary: var(--cofiel-primary);
  --bs-primary-rgb: 43, 89, 195;
  --bs-link-color: var(--cofiel-text-link);
  --bs-link-hover-color: var(--cofiel-primary-hover);
  --bs-border-color: var(--cofiel-border-light);
  --bs-border-radius: var(--cofiel-radius);
  --bs-border-radius-sm: var(--cofiel-radius-sm);
  --bs-border-radius-lg: var(--cofiel-radius-lg);
}

/* ------------------------------------------------------------------ */
/* v2 shell — Bootstrap 5 component harmonization                     */
/* ------------------------------------------------------------------ */

.cofiel-v2 {
  font-family: var(--cofiel-font);
  font-size: var(--cofiel-font-size-base);
  line-height: 1.5;
  color: var(--cofiel-text);
  background-color: var(--cofiel-bg-page);
  margin-top: 0 !important;
  -webkit-font-smoothing: antialiased;
}

.cofiel-v2 .btn {
  border-radius: var(--cofiel-radius);
  font-weight: 500;
  font-size: var(--cofiel-font-size-sm);
  padding: var(--cofiel-space-2) var(--cofiel-space-4);
}

.cofiel-v2 .btn-primary {
  --bs-btn-bg: var(--cofiel-primary);
  --bs-btn-border-color: var(--cofiel-primary);
  --bs-btn-hover-bg: var(--cofiel-primary-hover);
  --bs-btn-hover-border-color: var(--cofiel-primary-hover);
  --bs-btn-active-bg: var(--cofiel-primary-active);
  --bs-btn-active-border-color: var(--cofiel-primary-active);
}

.cofiel-v2 .btn-success,
.cofiel-v2 .cofiel-auth__submit,
.cofiel-v2 .cofiel-emision-actions .btn-primary,
.cofiel-v2 .cofiel-tienda-checkout__cta,
.cofiel-v2 .cofiel-tienda-card__cta,
.cofiel-v2 .cofiel-report-action__btn {
  --bs-btn-color: var(--cofiel-text-inverse);
  --bs-btn-bg: var(--cofiel-success);
  --bs-btn-border-color: var(--cofiel-success);
  --bs-btn-hover-bg: var(--cofiel-success-hover);
  --bs-btn-hover-border-color: var(--cofiel-success-hover);
  --bs-btn-active-bg: var(--cofiel-success-active);
  --bs-btn-active-border-color: var(--cofiel-success-active);
}

.cofiel-v2 .btn-secondary,
.cofiel-v2 .btn-default {
  --bs-btn-bg: var(--cofiel-bg-card);
  --bs-btn-border-color: var(--cofiel-border);
  --bs-btn-color: var(--cofiel-text-secondary);
  --bs-btn-hover-bg: var(--cofiel-bg-hover);
  --bs-btn-hover-border-color: var(--cofiel-border);
  --bs-btn-hover-color: var(--cofiel-text);
}

.cofiel-v2 .form-control,
.cofiel-v2 .form-select {
  border-radius: var(--cofiel-radius);
  border-color: var(--cofiel-border);
  font-size: var(--cofiel-font-size-sm);
  box-shadow: none;
}

.cofiel-v2 .form-control:focus,
.cofiel-v2 .form-select:focus {
  border-color: var(--cofiel-border-focus);
  box-shadow: 0 0 0 3px var(--cofiel-primary-muted);
}

.cofiel-v2 label,
.cofiel-v2 .form-label,
.cofiel-v2 .control-label {
  font-weight: 500;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .dropdown-menu {
  border-radius: var(--cofiel-radius-lg);
  border: 1px solid var(--cofiel-border-light);
  box-shadow: var(--cofiel-shadow-md);
  padding: var(--cofiel-space-2);
}

.cofiel-v2 .dropdown-menu > li > a {
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  color: var(--cofiel-text-secondary);
  border-radius: var(--cofiel-radius-sm);
  text-decoration: none !important;
}

.cofiel-v2 .dropdown-menu > li > a:hover,
.cofiel-v2 .dropdown-menu > li > a:focus {
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  text-decoration: none !important;
}

.cofiel-v2 .dropdown-menu > .active > a,
.cofiel-v2 .dropdown-menu > .active > a:hover,
.cofiel-v2 .dropdown-menu > .active > a:focus {
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  text-decoration: none !important;
}

.cofiel-v2 .table > :not(caption) > * > * {
  border-color: var(--cofiel-border-light);
}

.cofiel-v2 .table thead th {
  color: var(--cofiel-text-muted);
  font-weight: 500;
  font-size: var(--cofiel-font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.cofiel-v2 .chosen-container-single .chosen-single,
.cofiel-v2 .bootstrap-select .btn {
  border-radius: var(--cofiel-radius) !important;
  border-color: var(--cofiel-border) !important;
  background: var(--cofiel-bg-input) !important;
  box-shadow: none !important;
}

/* bootstrap-select — filtros y selects homogéneos */
.cofiel-v2 .bootstrap-select.btn-group,
.cofiel-v2 .bootstrap-select.btn-group[class*="span"] {
  margin-bottom: 0 !important;
}

.cofiel-v2 .bootstrap-select > .dropdown-toggle,
.cofiel-v2 .bootstrap-select > .btn.dropdown-toggle {
  display: inline-flex !important;
  align-items: center;
  justify-content: space-between;
  gap: var(--cofiel-space-2);
  min-height: 38px;
  padding: 0 var(--cofiel-space-4) !important;
  font-size: var(--cofiel-font-size-sm) !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  color: var(--cofiel-text-secondary) !important;
  background: var(--cofiel-bg-card) !important;
  border: 1px solid var(--cofiel-border) !important;
  border-radius: var(--cofiel-radius) !important;
  box-shadow: var(--cofiel-shadow-xs) !important;
  transition: background-color var(--cofiel-transition), border-color var(--cofiel-transition), color var(--cofiel-transition), box-shadow var(--cofiel-transition);
}

.cofiel-v2 .bootstrap-select > .dropdown-toggle:hover,
.cofiel-v2 .bootstrap-select > .dropdown-toggle:focus,
.cofiel-v2 .bootstrap-select > .dropdown-toggle:focus-visible,
.cofiel-v2 .bootstrap-select.open > .dropdown-toggle {
  color: var(--cofiel-text) !important;
  background: var(--cofiel-bg-hover) !important;
  border-color: var(--cofiel-primary-muted) !important;
  box-shadow: 0 0 0 3px var(--cofiel-primary-light) !important;
}

.cofiel-v2 .bootstrap-select.btn-group .btn .filter-option {
  position: static !important;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
  flex: 1 1 auto;
  min-width: 0;
}

.cofiel-v2 .bootstrap-select.btn-group .btn .caret {
  position: static !important;
  flex: 0 0 auto;
  margin: 0 !important;
  border-top-color: var(--cofiel-text-muted) !important;
}

.cofiel-v2 .bootstrap-select > .dropdown-toggle::after {
  display: none !important;
  content: none !important;
  border: 0 !important;
  margin: 0 !important;
}

.cofiel-v2 .bootstrap-select .dropdown-menu {
  min-width: 100%;
  margin-top: var(--cofiel-space-1) !important;
  padding: var(--cofiel-space-2) !important;
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg) !important;
  box-shadow: var(--cofiel-shadow-md) !important;
}

.cofiel-v2 .bootstrap-select .dropdown-menu.inner {
  position: static !important;
  float: none !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.cofiel-v2 .bootstrap-select .dropdown-menu > li > a,
.cofiel-v2 .bootstrap-select .dropdown-menu li a {
  display: block;
  padding: var(--cofiel-space-2) var(--cofiel-space-3) !important;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  line-height: 1.4;
  color: var(--cofiel-text-secondary) !important;
  text-decoration: none !important;
  border-radius: var(--cofiel-radius-sm);
  white-space: nowrap;
  background: transparent !important;
}

.cofiel-v2 .bootstrap-select .dropdown-menu > li > a:hover,
.cofiel-v2 .bootstrap-select .dropdown-menu > li > a:focus,
.cofiel-v2 .bootstrap-select .dropdown-menu li:not(.disabled) > a:hover,
.cofiel-v2 .bootstrap-select .dropdown-menu li:not(.disabled) > a:focus {
  color: var(--cofiel-primary) !important;
  background: var(--cofiel-primary-light) !important;
  text-decoration: none !important;
}

.cofiel-v2 .bootstrap-select .dropdown-menu > .active > a,
.cofiel-v2 .bootstrap-select .dropdown-menu > .active > a:hover,
.cofiel-v2 .bootstrap-select .dropdown-menu > .active > a:focus,
.cofiel-v2 .bootstrap-select .dropdown-menu li.selected > a {
  color: var(--cofiel-primary) !important;
  background: var(--cofiel-primary-light) !important;
  text-decoration: none !important;
}

.cofiel-v2 .bootstrap-select .dropdown-menu > .disabled > a,
.cofiel-v2 .bootstrap-select .dropdown-menu li.disabled > a {
  color: var(--cofiel-text-placeholder) !important;
  text-decoration: none !important;
  cursor: not-allowed;
}

.cofiel-v2 .bootstrap-select.show-tick .dropdown-menu li.selected a i.check-mark {
  color: var(--cofiel-success);
}

.cofiel-v2 .cofiel-list-toolbar .bootstrap-select {
  flex: 0 0 auto;
  min-width: 168px;
}

.cofiel-v2 .cofiel-list-toolbar .bootstrap-select > .dropdown-toggle {
  min-width: 168px;
}

.cofiel-v2 .cofiel-sidebar__filter .bootstrap-select {
  width: 100% !important;
}

.cofiel-v2 .cofiel-sidebar__filter .bootstrap-select > .dropdown-toggle {
  width: 100%;
  min-height: 40px;
  color: var(--cofiel-text) !important;
  background: var(--cofiel-bg-hover) !important;
  border-color: var(--cofiel-border-light) !important;
}

.cofiel-v2 .chosen-container-single .chosen-single {
  display: flex !important;
  align-items: center;
  min-height: 38px;
  padding: 0 var(--cofiel-space-4) !important;
  font-size: var(--cofiel-font-size-sm) !important;
  font-weight: 500 !important;
  color: var(--cofiel-text-secondary) !important;
  background: var(--cofiel-bg-card) !important;
  border: 1px solid var(--cofiel-border) !important;
  border-radius: var(--cofiel-radius) !important;
  box-shadow: var(--cofiel-shadow-xs) !important;
}

.cofiel-v2 .chosen-container-active.chosen-with-drop .chosen-single {
  border-color: var(--cofiel-primary-muted) !important;
  box-shadow: 0 0 0 3px var(--cofiel-primary-light) !important;
}

.cofiel-v2 .chosen-container .chosen-drop {
  margin-top: var(--cofiel-space-1);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-md);
}

.cofiel-v2 .chosen-container .chosen-results li {
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .chosen-container .chosen-results li.highlighted {
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
}

.cofiel-v2 .chosen-container .chosen-results li.result-selected {
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
}

/* ------------------------------------------------------------------ */
/* v2 component primitives                                            */
/* ------------------------------------------------------------------ */

.cofiel-card {
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
  margin-bottom: var(--cofiel-space-6);
  overflow: hidden;
}

.cofiel-card__header {
  padding: var(--cofiel-space-5) var(--cofiel-space-6);
  border-bottom: 1px solid var(--cofiel-border-light);
}

.cofiel-card__title {
  margin: 0;
  font-size: var(--cofiel-font-size-md);
  font-weight: 600;
  color: var(--cofiel-text);
}

.cofiel-card__body {
  padding: var(--cofiel-space-6);
}

.cofiel-page-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--cofiel-space-3);
  margin-bottom: var(--cofiel-space-4);
}

.cofiel-page-header__title {
  margin: 0 0 var(--cofiel-space-1);
  font-size: var(--cofiel-font-size-2xl);
  font-weight: 700;
  color: var(--cofiel-text);
}

.cofiel-page-header__subtitle {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-muted);
}

.cofiel-page-header__timbres {
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-muted);
}

.cofiel-page-header__timbres a {
  color: var(--cofiel-text-link);
  font-weight: 500;
  margin-left: var(--cofiel-space-1);
}

.cofiel-page-header__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cofiel-space-2);
}

.cofiel-form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--cofiel-space-4) var(--cofiel-space-5);
}

.cofiel-form-grid--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cofiel-v2 .cofiel-form-grid .form-group {
  margin-left: 0;
  margin-right: 0;
  min-width: 0;
}

.cofiel-v2 .cofiel-form-grid .form-group > div {
  min-width: 0;
}

.cofiel-form-grid__item--full {
  grid-column: 1 / -1;
}

.cofiel-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--cofiel-space-10) var(--cofiel-space-6);
  text-align: center;
  color: var(--cofiel-text-muted);
}

.cofiel-empty-state__icon {
  width: 64px;
  height: 64px;
  margin-bottom: var(--cofiel-space-4);
  opacity: 0.45;
}

.cofiel-totals {
  background: var(--cofiel-bg-hover);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius);
  padding: var(--cofiel-space-4);
}

.cofiel-totals__row {
  display: flex;
  justify-content: space-between;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-secondary);
}

.cofiel-totals__row--total {
  margin-top: var(--cofiel-space-2);
  padding-top: var(--cofiel-space-3);
  border-top: 1px solid var(--cofiel-border-light);
  font-size: var(--cofiel-font-size-lg);
  font-weight: 700;
  color: var(--cofiel-primary);
}

.cofiel-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--cofiel-radius-full);
  background: var(--cofiel-primary-light);
  color: var(--cofiel-primary);
  font-size: var(--cofiel-font-size-xs);
  font-weight: 600;
  text-transform: uppercase;
}

.cofiel-sidebar-promo {
  padding: var(--cofiel-space-4);
  background: var(--cofiel-primary-light);
  border-radius: var(--cofiel-radius);
  border: 1px solid var(--cofiel-primary-muted);
}

.cofiel-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

/* ------------------------------------------------------------------ */
/* App shell layout (CP1)                                             */
/* ------------------------------------------------------------------ */

.cofiel-app {
  min-height: 100vh;
  background: var(--cofiel-bg-page);
}

.cofiel-topbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1040;
  height: var(--cofiel-topbar-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--cofiel-space-4);
  padding: 0 var(--cofiel-space-6);
  background: var(--cofiel-bg-topbar);
  border-bottom: 1px solid var(--cofiel-border-light);
  box-shadow: var(--cofiel-shadow-xs);
}

.cofiel-topbar__left {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-3);
  min-width: 0;
}

.cofiel-topbar__menu-btn {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius);
  background: var(--cofiel-bg-card);
  cursor: pointer;
}

.cofiel-topbar__menu-btn .icon-bar {
  display: block;
  width: 18px;
  height: 2px;
  margin: 0 auto;
  background: var(--cofiel-text-secondary);
  border-radius: 1px;
}

.cofiel-topbar__brand {
  display: flex;
  align-items: center;
  text-decoration: none;
}

.cofiel-topbar__logo {
  height: 40px;
  width: auto;
}

.cofiel-topbar__nav {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-6);
}

/* Oculto temporalmente: Paquetes, Beneficios, Soluciones, Contacto */
.cofiel-topbar__nav--hidden {
  display: none !important;
}

.cofiel-topbar__nav a {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  color: var(--cofiel-text-secondary);
  text-decoration: none;
  transition: color var(--cofiel-transition);
}

.cofiel-topbar__nav a:hover {
  color: var(--cofiel-primary);
}

.cofiel-topbar__actions {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  flex-shrink: 0;
}

.cofiel-topbar__timbres {
  display: inline-flex;
  align-items: center;
  gap: var(--cofiel-space-3);
  margin-right: var(--cofiel-space-1);
  padding-right: var(--cofiel-space-3);
  border-right: 1px solid var(--cofiel-border-light);
}

.cofiel-v2 .cofiel-topbar__timbres.mostrarTimbres {
  position: static !important;
  top: auto !important;
  right: auto !important;
  color: inherit;
  font-size: inherit;
}

.cofiel-btn-promo__label--short {
  display: none;
}

.cofiel-topbar__timbres-label {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  line-height: 1;
  color: var(--cofiel-text-secondary);
  white-space: nowrap;
}

.cofiel-topbar__icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: var(--cofiel-radius);
  background: transparent;
  color: var(--cofiel-text-muted);
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--cofiel-transition), color var(--cofiel-transition);
}

.cofiel-topbar__icon-btn:hover {
  background: var(--cofiel-bg-hover);
  color: var(--cofiel-primary);
}

.cofiel-topbar__user-toggle {
  display: inline-flex !important;
  align-items: center;
  gap: var(--cofiel-space-2);
  padding: var(--cofiel-space-1) var(--cofiel-space-2) !important;
  text-decoration: none !important;
  color: var(--cofiel-text) !important;
}

.cofiel-topbar__user-rfc {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cofiel-topbar__user .dropdown-menu {
  right: 0;
  left: auto;
  min-width: 200px;
  padding: var(--cofiel-space-2);
}

.cofiel-v2 .cofiel-topbar__user .dropdown-menu > li > a {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  border-radius: var(--cofiel-radius-sm);
  color: var(--cofiel-text-secondary);
  text-decoration: none !important;
}

.cofiel-v2 .cofiel-topbar__user .dropdown-menu > li > a:hover,
.cofiel-v2 .cofiel-topbar__user .dropdown-menu > li > a:focus {
  color: var(--cofiel-primary);
  background: var(--cofiel-bg-hover);
  text-decoration: none !important;
}

.cofiel-layout {
  display: flex;
  padding-top: var(--cofiel-topbar-height);
  min-height: 100vh;
}

.cofiel-sidebar {
  position: fixed;
  top: var(--cofiel-topbar-height);
  left: 0;
  bottom: 0;
  width: var(--cofiel-sidebar-width);
  background: var(--cofiel-bg-sidebar);
  border-right: 1px solid var(--cofiel-border-light);
  z-index: 1030;
  overflow: hidden;
}

.cofiel-sidebar__inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: var(--cofiel-space-4) var(--cofiel-space-3);
  overflow-y: auto;
}

.cofiel-sidebar__filter {
  margin-bottom: var(--cofiel-space-3);
  padding: 0;
  list-style: none;
}

.cofiel-sidebar__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
}

.cofiel-sidebar__menu > li {
  margin-bottom: var(--cofiel-space-1);
}

.cofiel-sidebar__link {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-3);
  padding: var(--cofiel-space-3) var(--cofiel-space-4);
  border-radius: var(--cofiel-radius);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  color: var(--cofiel-text-secondary);
  text-decoration: none;
  transition: background-color var(--cofiel-transition), color var(--cofiel-transition);
}

.cofiel-sidebar__link:hover,
.cofiel-sidebar__link:focus {
  background: var(--cofiel-bg-hover);
  color: var(--cofiel-text);
  text-decoration: none;
}

.cofiel-sidebar__link--active {
  background: var(--cofiel-bg-active);
  color: var(--cofiel-primary);
}

.cofiel-sidebar__link--active .cofiel-icon {
  color: var(--cofiel-primary);
}

.cofiel-sidebar__chevron {
  margin-left: auto;
  font-size: 10px;
  opacity: 0.6;
}

.cofiel-topbar__chevron {
  font-size: 10px;
  opacity: 0.6;
  flex-shrink: 0;
}

/* Bootstrap 5 adds a ::after caret on .dropdown-toggle — keep only our chevron */
.cofiel-v2 .cofiel-sidebar__link.dropdown-toggle::after,
.cofiel-v2 .cofiel-topbar__user-toggle.dropdown-toggle::after {
  display: none !important;
  content: none !important;
  border: 0 !important;
  margin: 0 !important;
}

.cofiel-v2 .cofiel-sidebar__link.dropdown-toggle .caret,
.cofiel-v2 .cofiel-topbar__user-toggle.dropdown-toggle .caret {
  display: none !important;
}

.cofiel-v2 .avatar-dropdown .fa-chevron-down,
.cofiel-v2 .avatar-dropdown .fa-caret-down {
  float: none !important;
  margin-top: 0 !important;
  font-size: 10px !important;
  vertical-align: middle !important;
}

.cofiel-sidebar__item--sub {
  position: relative;
}

.cofiel-sidebar__submenu {
  position: static !important;
  float: none !important;
  display: none;
  min-width: 0;
  width: 100%;
  margin: var(--cofiel-space-1) 0 0;
  padding: var(--cofiel-space-1) 0 var(--cofiel-space-2);
  border: none;
  border-radius: var(--cofiel-radius);
  box-shadow: none;
  background: transparent;
}

.cofiel-sidebar__submenu > li > a {
  display: block;
  padding: var(--cofiel-space-2) var(--cofiel-space-4) var(--cofiel-space-2) calc(var(--cofiel-space-4) + 32px);
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-muted);
  text-decoration: none;
}

.cofiel-sidebar__submenu > li > a:hover {
  color: var(--cofiel-primary);
  background: transparent;
}

.cofiel-sidebar__item--sub.open > .cofiel-sidebar__submenu,
.cofiel-sidebar__item--sub:hover > .cofiel-sidebar__submenu {
  display: block;
}

.cofiel-sidebar-promo {
  margin-top: var(--cofiel-space-4);
}

.cofiel-sidebar-promo__icon {
  width: 24px;
  height: 24px;
  color: var(--cofiel-primary);
  margin-bottom: var(--cofiel-space-2);
}

.cofiel-sidebar-promo__title {
  margin: 0 0 var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-md);
  font-weight: 600;
  color: var(--cofiel-text);
}

.cofiel-sidebar-promo__text {
  margin: 0 0 var(--cofiel-space-4);
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-muted);
  line-height: 1.45;
}

.cofiel-main {
  flex: 1;
  min-width: 0;
  margin-left: var(--cofiel-sidebar-width);
  display: flex;
  flex-direction: column;
}

.cofiel-main__inner {
  flex: 1;
  padding: var(--cofiel-space-4) var(--cofiel-space-6) var(--cofiel-space-6);
}

.cofiel-v2 a.cofiel-btn-promo,
.cofiel-v2 button.cofiel-btn-promo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cofiel-space-2);
  min-height: 36px;
  padding: 0 var(--cofiel-space-4);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: #fff !important;
  text-decoration: none !important;
  white-space: nowrap;
  background: linear-gradient(135deg, #fb923c 0%, #f97316 45%, #ea580c 100%);
  border: 2px solid #c2410c;
  border-radius: var(--cofiel-radius);
  box-shadow: 0 4px 16px rgba(234, 88, 12, 0.45);
  transition: transform 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease;
}

.cofiel-v2 a.cofiel-btn-promo:hover,
.cofiel-v2 a.cofiel-btn-promo:focus,
.cofiel-v2 button.cofiel-btn-promo:hover,
.cofiel-v2 button.cofiel-btn-promo:focus {
  color: #fff !important;
  filter: brightness(1.05);
  transform: translateY(-1px);
  box-shadow: 0 6px 22px rgba(234, 88, 12, 0.55);
}

.cofiel-btn-promo--block {
  width: 100%;
  min-height: 40px;
  margin-top: var(--cofiel-space-1);
  font-size: var(--cofiel-font-size-md);
  padding: 0 var(--cofiel-space-5);
}

/* Legacy module layout overrides inside v2 shell */
.cofiel-v2 section,
.cofiel-v2 section.catalogo-generico {
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  margin: 0 !important;
  height: auto !important;
  min-height: 0;
  background: transparent !important;
  box-shadow: none;
}

.cofiel-v2 section .content {
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  height: auto !important;
  min-height: 0 !important;
  overflow: visible;
}

.cofiel-v2 section .content .body-form:not(.cofiel-report-panel):not(.cofiel-detalle-body):not(.cofiel-tienda-body),
.cofiel-v2 .catalogo-emision .body-form,
.cofiel-v2 #opcionListado .body-form:not(.cofiel-report-panel):not(.cofiel-detalle-body):not(.cofiel-tienda-body),
.cofiel-v2 #listadoSeries .body-form:not(.cofiel-report-panel):not(.cofiel-detalle-body):not(.cofiel-tienda-body),
.cofiel-v2 #opcionNuevo .body-form,
.cofiel-v2 #opcionModificar .body-form,
.cofiel-v2 #opcionMostrar .body-form,
.cofiel-v2 #opcionTerminar .body-form,
.cofiel-v2 #opcionCancelados .body-form,
.cofiel-v2 #opcionDatosFiscales .body-form,
.cofiel-v2 #opcionPerfil .body-form,
.cofiel-v2 #opcionAccesos .body-form,
.cofiel-v2 #nuevaSucursal .body-form,
.cofiel-v2 #nuevaSerie .body-form,
.cofiel-v2 #modificarSerie .body-form,
.cofiel-v2 .detalle-emision .body-form:not(.cofiel-detalle-body) {
  position: relative !important;
  top: auto !important;
  bottom: auto !important;
  float: none !important;
  width: 100% !important;
  overflow: visible !important;
  padding-right: 0 !important;
}

.cofiel-v2 #opcionNuevo .body-form,
.cofiel-v2 #opcionModificar .body-form,
.cofiel-v2 #opcionMostrar .body-form,
.cofiel-v2 #opcionDatosFiscales .body-form,
.cofiel-v2 #opcionPerfil .body-form,
.cofiel-v2 #opcionAccesos .body-form,
.cofiel-v2 #nuevaSucursal .body-form,
.cofiel-v2 #nuevaSerie .body-form,
.cofiel-v2 #modificarSerie .body-form {
  padding: var(--cofiel-space-5) var(--cofiel-space-6) !important;
}

.cofiel-v2 .catalogo-emision .panel-heading,
.cofiel-v2 .catalogo-emision .panel-collapse {
  float: none !important;
  width: 100%;
}

.cofiel-v2 .catalogo-emision .content {
  margin-left: 0 !important;
}

.cofiel-v2 .catalogo-emision .content.emitir-factura {
  padding-bottom: 5.75rem;
}

.cofiel-v2 .cofiel-toasts {
  position: fixed;
  top: calc(var(--cofiel-topbar-height) + var(--cofiel-space-4));
  right: var(--cofiel-space-4);
  z-index: 1100;
  width: min(420px, calc(100vw - var(--cofiel-space-4) * 2));
  flex-direction: column;
  gap: var(--cofiel-space-2);
  pointer-events: none;
}

.cofiel-v2 .cofiel-toasts:not(:empty) {
  display: flex;
}

.cofiel-v2 .cofiel-toasts:empty {
  display: none;
}

.cofiel-v2 .cofiel-toasts .alert {
  pointer-events: auto;
  margin: 0;
  box-shadow: var(--cofiel-shadow-md);
  border-radius: var(--cofiel-radius-md);
}

.cofiel-v2 section.catalogo-generico .header-toolbar .left,
.cofiel-v2 #nuevaSerie .left,
.cofiel-v2 #modificarSerie .left,
.cofiel-v2 #nuevaSucursal .left,
.cofiel-v2 .emitir-factura .header-toolbar .left {
  display: none !important;
}

.cofiel-v2 .cofiel-emision-actions {
  position: fixed;
  bottom: 0;
  left: var(--cofiel-sidebar-width);
  right: 0;
  z-index: 1030;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: var(--cofiel-space-3);
  padding: var(--cofiel-space-4) var(--cofiel-space-6);
  background: rgba(255, 255, 255, 0.98);
  border-top: 1px solid var(--cofiel-border);
  backdrop-filter: blur(10px);
  box-shadow: 0 -4px 20px rgba(15, 23, 42, 0.1);
}

.cofiel-v2 .cofiel-emision-actions .btn {
  min-height: 44px;
  margin: 0;
  padding: var(--cofiel-space-2) var(--cofiel-space-5);
  font-size: var(--cofiel-font-size-base);
  font-weight: 500;
  border-width: 1.5px;
  white-space: nowrap;
}

.cofiel-v2 .cofiel-emision-actions .btn-default,
.cofiel-v2 .cofiel-emision-actions .btn-secondary {
  --bs-btn-bg: var(--cofiel-bg-card);
  --bs-btn-border-color: var(--cofiel-border);
  --bs-btn-color: var(--cofiel-text);
  --bs-btn-hover-bg: var(--cofiel-bg-hover);
  --bs-btn-hover-border-color: var(--cofiel-text-muted);
  --bs-btn-hover-color: var(--cofiel-text);
  --bs-btn-active-bg: var(--cofiel-bg-active);
  --bs-btn-active-border-color: var(--cofiel-primary-muted);
  --bs-btn-active-color: var(--cofiel-text);
  background-color: var(--cofiel-bg-card);
  border-color: var(--cofiel-border);
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-emision-actions .btn-primary {
  min-height: 48px;
  padding: var(--cofiel-space-3) var(--cofiel-space-6);
  font-size: var(--cofiel-font-size-md);
  font-weight: 600;
  letter-spacing: 0.01em;
  box-shadow: 0 2px 8px rgba(22, 163, 74, 0.35);
  --bs-btn-color: var(--cofiel-text-inverse);
  --bs-btn-bg: var(--cofiel-success);
  --bs-btn-border-color: var(--cofiel-success);
  --bs-btn-hover-bg: var(--cofiel-success-hover);
  --bs-btn-hover-border-color: var(--cofiel-success-hover);
  --bs-btn-active-bg: var(--cofiel-success-active);
  --bs-btn-active-border-color: var(--cofiel-success-active);
}

.cofiel-v2 .cofiel-emision-actions .btn-primary:hover,
.cofiel-v2 .cofiel-emision-actions .btn-primary:focus-visible {
  box-shadow: 0 4px 14px rgba(22, 163, 74, 0.45);
}

.cofiel-v2 section .content .header-toolbar {
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
  height: auto;
  min-height: 56px;
  margin-bottom: var(--cofiel-space-4);
}

.cofiel-v2 .avatar-dropdown {
  position: relative !important;
  top: auto !important;
  right: auto !important;
  width: auto !important;
}

.cofiel-v2 .avatar-dropdown a {
  float: none !important;
  width: auto !important;
}

.cofiel-v2 .avatar-dropdown img.img-avatar {
  display: none;
}

@media (max-width: 991px) {
  .cofiel-topbar {
    gap: var(--cofiel-space-2);
    padding: 0 var(--cofiel-space-4);
  }

  .cofiel-topbar__left {
    flex: 1 1 0;
    min-width: 0;
    overflow: hidden;
  }

  .cofiel-topbar__brand {
    min-width: 0;
    max-width: 100%;
  }

  .cofiel-topbar__logo {
    height: 32px;
    max-width: min(140px, 42vw);
    object-fit: contain;
    object-position: left center;
  }

  .cofiel-topbar__nav {
    display: none;
  }

  .cofiel-topbar__icon-btn {
    display: none;
  }

  .cofiel-topbar__menu-btn {
    display: inline-flex;
    flex-shrink: 0;
  }

  .cofiel-topbar__actions {
    flex: 0 0 auto;
    gap: var(--cofiel-space-1);
  }

  .cofiel-topbar__timbres .cofiel-btn-promo {
    min-height: 32px;
    padding: 0 var(--cofiel-space-3);
    font-size: var(--cofiel-font-size-xs);
    letter-spacing: 0.02em;
  }

  .cofiel-sidebar {
    transform: translateX(-100%);
    transition: transform var(--cofiel-transition);
    box-shadow: var(--cofiel-shadow-md);
  }

  .cofiel-sidebar.cofiel-sidebar--open {
    transform: translateX(0);
  }

  .cofiel-main {
    margin-left: 0;
  }

  .cofiel-v2 .cofiel-emision-actions {
    left: 0;
    padding-left: var(--cofiel-space-4);
    padding-right: var(--cofiel-space-4);
  }
}

@media (max-width: 767px) {
  .cofiel-topbar {
    padding-left: max(var(--cofiel-space-3), env(safe-area-inset-left));
    padding-right: max(var(--cofiel-space-3), env(safe-area-inset-right));
  }

  .cofiel-topbar__logo {
    height: 28px;
    max-width: min(118px, 38vw);
  }

  .cofiel-topbar__user-rfc {
    display: none;
  }

  .cofiel-topbar__user-toggle {
    padding: var(--cofiel-space-1) !important;
  }

  .cofiel-topbar__timbres .cofiel-btn-promo {
    min-height: 30px;
    padding: 0 var(--cofiel-space-2);
    box-shadow: 0 2px 10px rgba(234, 88, 12, 0.35);
  }

  .cofiel-main__inner {
    padding-left: var(--cofiel-space-4);
    padding-right: var(--cofiel-space-4);
  }
}

/* iPhone Pro / similar (~390–430px logical width) */
@media (max-width: 430px) {
  .cofiel-topbar__logo {
    height: 24px;
    max-width: min(96px, 34vw);
  }

  .cofiel-btn-promo__label--full {
    display: none;
  }

  .cofiel-btn-promo__label--short {
    display: inline;
  }

  .cofiel-topbar__timbres .cofiel-btn-promo {
    min-height: 28px;
    padding: 0 10px;
    font-size: 0.625rem;
  }
}

@media (max-width: 991px) {
  .cofiel-form-grid,
  .cofiel-form-grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .cofiel-form-grid,
  .cofiel-form-grid--2 {
    grid-template-columns: 1fr;
  }

  .cofiel-page-header__title {
    font-size: var(--cofiel-font-size-xl);
  }
}

/* ------------------------------------------------------------------ */
/* Global module content redesign                                     */
/* ------------------------------------------------------------------ */

.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) {
  min-height: 520px;
  position: relative !important;
}

.cofiel-v2 .cofiel-main:has(.cofiel-page-header) {
  position: relative;
}

.cofiel-v2 .cofiel-page-header {
  margin-bottom: var(--cofiel-space-3);
}

.cofiel-v2 .cofiel-page-header__actions {
  flex-shrink: 0;
}

.cofiel-v2 .cofiel-page-header__actions .btn-primary {
  order: 2;
}

.cofiel-v2 .cofiel-panel-card {
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light) !important;
  border-radius: var(--cofiel-radius-lg) !important;
  box-shadow: var(--cofiel-shadow-xs);
  margin-bottom: var(--cofiel-space-6) !important;
  overflow: hidden;
}

.cofiel-v2 .cofiel-panel-card:has(.cofiel-list-body),
.cofiel-v2 .cofiel-panel-card:has(.cofiel-list-toolbar),
.cofiel-v2 .cofiel-panel-card:has(.cofiel-detalle-body) {
  overflow: visible;
}

.cofiel-v2 .cofiel-panel-card--continued {
  margin-top: calc(var(--cofiel-space-6) * -1 + 1px) !important;
  border-top: none !important;
  border-radius: 0 0 var(--cofiel-radius-lg) var(--cofiel-radius-lg) !important;
  box-shadow: none;
}

.cofiel-v2 .cofiel-panel-card > .cofiel-card__header {
  padding: var(--cofiel-space-5) var(--cofiel-space-6);
  border-bottom: 1px solid var(--cofiel-border-light);
  background: var(--cofiel-bg-card);
}

.cofiel-v2 .cofiel-panel-card .panel-body {
  padding: var(--cofiel-space-6) !important;
  background: var(--cofiel-bg-card) !important;
  border: none !important;
}

.cofiel-v2 .cofiel-panel-card .panel-collapse,
.cofiel-v2 .cofiel-panel-card .panel-heading {
  border: none !important;
  background: transparent !important;
}

.cofiel-v2 .catalogo-emision .panel-group {
  margin-bottom: 0;
}

.cofiel-v2 .catalogo-emision #datosGenerales .panel-body > .row > .col-md-12,
.cofiel-v2 .catalogo-emision #rowDatosPagos > .col-md-12 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--cofiel-space-4) var(--cofiel-space-5);
}

.cofiel-v2 .catalogo-emision #rowDatosCliente {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--cofiel-space-4) var(--cofiel-space-5);
  align-items: start;
}

.cofiel-v2 .catalogo-emision #rowDatosCliente > .col-md-6 {
  display: flex;
  flex-direction: column;
  gap: var(--cofiel-space-4);
  min-width: 0;
  float: none !important;
  width: auto !important;
}

.cofiel-v2 .catalogo-emision #datosGenerales .clearfix.space,
.cofiel-v2 .catalogo-emision #rowDatosPagos .clearfix.space,
.cofiel-v2 .catalogo-emision #rowDatosCliente .clearfix.space {
  display: none !important;
}

.cofiel-v2 .catalogo-emision .cofiel-product-add {
  margin-bottom: var(--cofiel-space-5);
}

.cofiel-v2 .catalogo-emision .cofiel-field-qty {
  display: grid !important;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  gap: var(--cofiel-space-2);
}

.cofiel-v2 .catalogo-emision .cofiel-field-qty > .input-group-addon:first-child {
  grid-column: 1 / -1;
}

.cofiel-v2 .catalogo-emision .cofiel-field-qty > .form-control {
  grid-column: 1;
}

.cofiel-v2 .catalogo-emision .cofiel-field-qty > .cofiel-field-suffix {
  grid-column: 2;
  align-self: end;
  width: auto !important;
  padding: 10px var(--cofiel-space-3) !important;
  background: var(--cofiel-bg-hover) !important;
  border: 1px solid var(--cofiel-border) !important;
  border-radius: var(--cofiel-radius) !important;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .catalogo-emision .cofiel-products-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: var(--cofiel-space-6);
  align-items: start;
}

.cofiel-v2 .catalogo-emision .cofiel-products-table-wrap {
  min-width: 0;
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius);
  overflow: hidden;
}

.cofiel-v2 .catalogo-emision .cofiel-products-table-wrap #tablaProductos {
  margin: 0;
  border: none;
  border-radius: 0;
}

.cofiel-v2 .catalogo-emision .cofiel-empty-state--table {
  border-top: 1px solid var(--cofiel-border-light);
  padding: var(--cofiel-space-8) var(--cofiel-space-4);
}

.cofiel-v2 .catalogo-emision .cofiel-products-table-wrap:has(#tablaProductos tbody tr) .cofiel-empty-state--table {
  display: none;
}

.cofiel-v2 .catalogo-emision .cofiel-products-table-wrap:has(#tablaProductos tbody tr) #tablaProductos {
  border-bottom: none;
}

.cofiel-v2 .catalogo-emision .cofiel-totals-wrap {
  width: 100%;
  max-width: 300px;
  justify-self: end;
}

.cofiel-v2 .catalogo-emision #datosGenerales .input-group,
.cofiel-v2 .catalogo-emision #rowDatosPagos .input-group,
.cofiel-v2 .catalogo-emision #rowDatosCliente .input-group,
.cofiel-v2 .catalogo-emision .datosConceptos .input-group {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
}

.cofiel-v2 .catalogo-emision .input-group-addon {
  display: block;
  width: 100% !important;
  padding: 0 0 var(--cofiel-space-2);
  margin: 0;
  text-align: left;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  color: var(--cofiel-text-secondary);
  white-space: normal;
}

.cofiel-v2 .catalogo-emision .input-group .form-control,
.cofiel-v2 .catalogo-emision .input-group select.form-control,
.cofiel-v2 .catalogo-emision .input-group textarea.form-control {
  display: block;
  width: 100% !important;
  min-height: 40px;
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  border: 1px solid var(--cofiel-border) !important;
  border-radius: var(--cofiel-radius) !important;
  background: var(--cofiel-bg-input);
  box-shadow: none;
}

.cofiel-v2 .catalogo-emision .input-group .form-control:focus,
.cofiel-v2 .catalogo-emision .input-group select.form-control:focus,
.cofiel-v2 .catalogo-emision .input-group textarea.form-control:focus {
  border-color: var(--cofiel-border-focus) !important;
  box-shadow: 0 0 0 3px var(--cofiel-primary-muted);
}

.cofiel-v2 .catalogo-emision .input-group .form-control[disabled],
.cofiel-v2 .catalogo-emision .input-group textarea.form-control[disabled] {
  background: var(--cofiel-bg-hover);
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .catalogo-emision .chosen-container {
  width: 100% !important;
  max-width: none !important;
}

.cofiel-v2 .catalogo-emision .chosen-container-single .chosen-single,
.cofiel-v2 .catalogo-emision .chosen-container-multi .chosen-choices {
  min-height: 40px !important;
  height: auto !important;
  padding: var(--cofiel-space-2) var(--cofiel-space-3) !important;
  border: 1px solid var(--cofiel-border) !important;
  border-radius: var(--cofiel-radius) !important;
  background: var(--cofiel-bg-input) !important;
  box-shadow: none !important;
  line-height: 1.4 !important;
}

.cofiel-v2 .catalogo-emision .chosen-container-single .chosen-single span {
  margin-top: 0 !important;
}

.cofiel-v2 .catalogo-emision #miCliente_chosen.chosen-container-single .chosen-single {
  max-width: none !important;
}

.cofiel-v2 .catalogo-emision .datosConceptos .input-group[style*="margin-top"] {
  display: grid !important;
  grid-template-columns: 1fr 100px 36px;
  gap: var(--cofiel-space-3);
  align-items: end;
}

.cofiel-v2 .catalogo-emision .datosConceptos .input-group[style*="margin-top"] .input-group-addon:first-child {
  grid-column: 1 / -1;
}

.cofiel-v2 .catalogo-emision .datosConceptos .input-group[style*="margin-top"] .form-control {
  grid-column: auto;
}

.cofiel-v2 .catalogo-emision .datosConceptos .input-group[style*="margin-top"] .input-group-addon:last-child {
  grid-column: 3;
  text-align: center;
  padding-bottom: 10px;
}

.cofiel-v2 .cofiel-totals__value {
  margin: 0;
  font-weight: 600;
  color: var(--cofiel-text);
}

.cofiel-v2 #conceptosImpuestos .input-group {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--cofiel-space-2) !important;
  padding: var(--cofiel-space-1) 0;
}

.cofiel-v2 #conceptosImpuestos .input-group-addon {
  width: auto !important;
  padding: 0 !important;
  flex: 1;
}

.cofiel-v2 #conceptosImpuestos .form-control {
  width: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  text-align: right;
  font-weight: 600;
}

.cofiel-v2 .catalogo-emision #tablaProductos thead th {
  background: var(--cofiel-bg-hover);
  border-bottom: 1px solid var(--cofiel-border-light);
  padding: var(--cofiel-space-3) var(--cofiel-space-4);
}

.cofiel-v2 .catalogo-emision #tablaProductos tbody td {
  padding: var(--cofiel-space-3) var(--cofiel-space-4);
  vertical-align: middle;
}

.cofiel-v2 .clearfix.space {
  height: 0;
  margin: 0;
}

/* Catalog modules — forms & side nav */
.cofiel-v2 section.catalogo-generico:has(.sidebar_left:not(.no-display)) {
  display: flex;
  align-items: stretch;
  min-height: 0;
}

.cofiel-v2 section .sidebar_left:not(.no-display) {
  position: relative !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  flex: 0 0 280px;
  width: 280px !important;
  height: auto !important;
  align-self: stretch;
  background: var(--cofiel-bg-card) !important;
  border-right: 1px solid var(--cofiel-border-light);
  box-shadow: none !important;
  border-radius: var(--cofiel-radius-lg) 0 0 var(--cofiel-radius-lg);
  overflow: hidden;
}

.cofiel-v2 section .sidebar_left:not(.no-display) .menu-options {
  position: relative;
  top: auto;
  bottom: auto;
  width: 100%;
  border-bottom: none;
}

.cofiel-v2 section .sidebar_left:not(.no-display) + .content {
  flex: 1 1 auto;
  margin-left: 0 !important;
  min-height: 0 !important;
  height: auto !important;
  align-self: stretch;
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-left: none;
  border-radius: 0 var(--cofiel-radius-lg) var(--cofiel-radius-lg) 0;
}

.cofiel-v2 section.catalogo-generico:has(.sidebar_left:not(.no-display)) .content .tab-content,
.cofiel-v2 section.catalogo-generico:has(.sidebar_left:not(.no-display)) .content .tab-pane,
.cofiel-v2 section.catalogo-generico:has(.sidebar_left:not(.no-display)) .content .cofiel-panel-card {
  height: 100%;
}

.cofiel-v2 section.catalogo-generico:has(.sidebar_left:not(.no-display)) .content .cofiel-panel-card {
  margin-bottom: 0 !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.cofiel-v2 ul.menu-options li {
  padding: var(--cofiel-space-4) calc(var(--cofiel-space-4) + 18px) var(--cofiel-space-4) var(--cofiel-space-4) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--cofiel-border-light) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
  overflow: hidden;
}

.cofiel-v2 ul.menu-options li:hover,
.cofiel-v2 ul.menu-options li.active {
  background: var(--cofiel-bg-hover) !important;
}

.cofiel-v2 ul.menu-options li h4 {
  display: block !important;
  font-size: var(--cofiel-font-size-sm) !important;
  font-weight: 600 !important;
  color: var(--cofiel-text) !important;
  margin: 0 0 var(--cofiel-space-1) !important;
  overflow: hidden;
}

.cofiel-v2 ul.menu-options li span {
  display: block;
  font-size: var(--cofiel-font-size-xs) !important;
  color: var(--cofiel-text-muted) !important;
  text-shadow: none !important;
  width: auto !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: break-word;
  word-wrap: break-word;
  line-height: 1.45;
  margin-top: var(--cofiel-space-1);
}

.cofiel-v2 ul.menu-options .module .icon-left {
  font-size: 18px !important;
  color: var(--cofiel-primary);
  margin-right: var(--cofiel-space-3) !important;
  float: left;
  width: 22px;
  text-align: center;
}

.cofiel-v2 ul.menu-options .module .icon-right {
  font-size: 14px !important;
  color: var(--cofiel-primary);
  position: absolute !important;
  top: 50%;
  right: var(--cofiel-space-3);
  transform: translateY(-50%);
  float: none !important;
  padding: 0 !important;
}

.cofiel-v2 section .content .header-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--cofiel-space-3);
  padding: var(--cofiel-space-4) var(--cofiel-space-5) !important;
  border-bottom: 1px solid var(--cofiel-border-light) !important;
  background: var(--cofiel-bg-card) !important;
  border-radius: var(--cofiel-radius-lg) var(--cofiel-radius-lg) 0 0 !important;
  margin-bottom: 0 !important;
  float: none !important;
  width: 100%;
  height: auto !important;
  min-height: 56px;
}

.cofiel-v2 section .content .header-toolbar .left,
.cofiel-v2 section .content .header-toolbar .right {
  float: none !important;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--cofiel-space-2);
}

.cofiel-v2 section .content .header-toolbar .right {
  margin-left: auto;
}

.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .body-form .input-group,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .input-group,
.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group,
.cofiel-v2 .form-horizontal .form-group {
  margin-bottom: var(--cofiel-space-4);
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--cofiel-space-1);
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group::before,
.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group::after,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group::before,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group::after {
  display: none !important;
  content: none !important;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group > label,
.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group > .control-label,
.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group > [class*="col-"],
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group > label,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group > .control-label,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group > [class*="col-"] {
  width: 100% !important;
  max-width: 100% !important;
  flex: 0 0 auto !important;
  float: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .body-form .input-group,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .input-group {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100% !important;
  float: none !important;
}

.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .body-form .input-group-addon,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .input-group-addon {
  display: block;
  width: 100% !important;
  padding: 0 0 var(--cofiel-space-2);
  text-align: left;
  background: transparent !important;
  border: none !important;
  font-weight: 500;
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .body-form .input-group .form-control,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .body-form .input-group select,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .body-form .input-group textarea,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .input-group .form-control,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .input-group select,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .input-group textarea {
  width: 100% !important;
  min-height: 40px;
  border-radius: var(--cofiel-radius) !important;
}

.cofiel-v2 .form-horizontal .control-label {
  text-align: left !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-bottom: var(--cofiel-space-2);
}

/* Legacy forms put input-lg on labels — must not inherit input sizing */
.cofiel-v2 .form-horizontal label.control-label.input-lg,
.cofiel-v2 .form-horizontal .control-label.input-lg {
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  line-height: 1.35;
  border-radius: 0;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-control,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-control,
.cofiel-v2 section.catalogo-configuracion .form-horizontal .bootstrap-select,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .bootstrap-select,
.cofiel-v2 section.catalogo-configuracion .form-horizontal .chosen-container,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .chosen-container {
  width: 100% !important;
  max-width: 100% !important;
}

.cofiel-v2 .form-horizontal .form-control.input-lg,
.cofiel-v2 .form-control.input-lg {
  min-height: 44px;
  font-size: var(--cofiel-font-size-base) !important;
  border-radius: var(--cofiel-radius) !important;
}

/* Catalog forms — compact grid layout (exclude reportes — uses cofiel-form-grid) */
.cofiel-v2 section.catalogo-configuracion .form-horizontal,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision):not(.catalogo-reportes) .form-horizontal {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: var(--cofiel-space-3) var(--cofiel-space-4);
  align-items: start;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal > .form-group,
.cofiel-v2 section.catalogo-configuracion .form-horizontal > hr,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision):not(.catalogo-reportes) .form-horizontal > .form-group,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision):not(.catalogo-reportes) .form-horizontal > hr {
  grid-column: 1 / -1;
  margin-bottom: 0 !important;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .control-label,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .control-label {
  margin-bottom: 0;
  font-size: var(--cofiel-font-size-xs);
  letter-spacing: 0.01em;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-control,
.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-control.input-lg,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-control,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-control.input-lg {
  min-height: 38px;
  padding: 0.45rem 0.75rem;
  font-size: var(--cofiel-font-size-sm) !important;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal textarea.form-control,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal textarea.form-control {
  min-height: 88px;
  resize: vertical;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .chosen-container-single .chosen-single,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .chosen-container-single .chosen-single {
  min-height: 38px;
  line-height: 36px;
  padding: 0 0.75rem;
  font-size: var(--cofiel-font-size-sm);
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .bootstrap-select > .dropdown-toggle,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .bootstrap-select > .dropdown-toggle {
  min-height: 38px;
  padding: 0.45rem 0.75rem;
  font-size: var(--cofiel-font-size-sm);
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group .input-group:has(.input-group-addon:last-child),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group .input-group:has(.input-group-addon:last-child) {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch;
  width: 100% !important;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group .input-group:has(.input-group-addon:last-child) .form-control,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group .input-group:has(.input-group-addon:last-child) .form-control {
  flex: 1 1 auto;
  width: 1% !important;
  min-width: 0;
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group .input-group:has(.input-group-addon:last-child) .input-group-addon,
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group .input-group:has(.input-group-addon:last-child) .input-group-addon {
  display: flex !important;
  align-items: center;
  width: auto !important;
  padding: 0 0.75rem !important;
  background: var(--cofiel-bg-hover) !important;
  border: 1px solid var(--cofiel-border) !important;
  border-left: 0 !important;
  border-radius: 0 var(--cofiel-radius) var(--cofiel-radius) 0 !important;
  color: var(--cofiel-text-muted);
  font-size: var(--cofiel-font-size-sm);
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-miRFC"], [id$="-miCP"], [id$="-miPrecio"], [id$="-miCodigo"], [id$="-miExtension"], [id$="-miPredial"], [id$="-miIEPS"], [id$="-miRIVA"], [id$="-miTipoCambio"], [id$="-miDescripcionCorta"]),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-miRFC"], [id$="-miCP"], [id$="-miPrecio"], [id$="-miCodigo"], [id$="-miExtension"], [id$="-miPredial"], [id$="-miIEPS"], [id$="-miRIVA"], [id$="-miTipoCambio"], [id$="-miDescripcionCorta"]) {
  grid-column: span 4;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-miRegimenFiscal"], [id$="-listaSucursales"]),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-miRegimenFiscal"], [id$="-listaSucursales"]) {
  grid-column: span 8;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-miTelefono"], [id$="-miNombreContacto"], [id$="-miEstadoSel"], [id$="-miPaisSel"], [id$="-idIVAGravado"], [id$="-miNombre"], [id$="-miPassword"], [id$="-numExterior"], [id$="-numInterior"]),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-miTelefono"], [id$="-miNombreContacto"], [id$="-miEstadoSel"], [id$="-miPaisSel"], [id$="-idIVAGravado"], [id$="-miNombre"], [id$="-miPassword"], [id$="-numExterior"], [id$="-numInterior"]) {
  grid-column: span 6;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-miClaveUnidad"]),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-miClaveUnidad"]) {
  grid-column: span 8;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-miUnidad"]),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-miUnidad"]) {
  grid-column: span 4;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: var(--cofiel-space-3);
  align-items: end;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > label:nth-of-type(1),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > label:nth-of-type(1) {
  grid-column: 1 / span 3;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > div:has([id$="-numExterior"]),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > div:has([id$="-numExterior"]) {
  grid-column: 4 / span 2;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > label:nth-of-type(2),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > label:nth-of-type(2) {
  grid-column: 7 / span 3;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > div:has([id$="-numInterior"]),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > div:has([id$="-numInterior"]) {
  grid-column: 10 / span 2;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has(textarea),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has(textarea) {
  grid-column: 1 / -1;
}

/* Productos — filas compactas sin huecos */
.cofiel-v2 section.catalogo-generico.catalogo-productos .form-horizontal {
  gap: var(--cofiel-space-2) var(--cofiel-space-3);
}

.cofiel-v2 section.catalogo-generico.catalogo-productos .form-horizontal textarea.form-control {
  min-height: 72px;
}

.cofiel-v2 section.catalogo-generico.catalogo-productos .form-horizontal .form-group:has([id$="-idIVAGravado"]) {
  grid-column: span 4;
}

.cofiel-v2 section.catalogo-generico.catalogo-productos .form-horizontal .form-group:has([id$="-miClaveProdServ"]) {
  grid-column: 1 / -1;
}

.cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-tmpNameCer"], [id$="-tmpNameKey"]),
.cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-tmpNameCer"], [id$="-tmpNameKey"]) {
  grid-column: span 6;
}

@media (max-width: 991px) {
  .cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group,
  .cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group {
    grid-column: 1 / -1 !important;
  }

  .cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]),
  .cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  .cofiel-v2 section.catalogo-configuracion .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > *,
  .cofiel-v2 section.catalogo-generico:not(.catalogo-emision) .form-horizontal .form-group:has([id$="-numExterior"]):has([id$="-numInterior"]) > * {
    grid-column: auto !important;
  }
}

.cofiel-v2 .chosen-container {
  width: 100% !important;
}

.cofiel-v2 .pagination > li > a,
.cofiel-v2 .pagination > li > span {
  border-radius: var(--cofiel-radius-sm);
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .pagination > .active > a {
  background: var(--cofiel-primary);
  border-color: var(--cofiel-primary);
}

.cofiel-v2 .alert {
  border-radius: var(--cofiel-radius);
  border: none;
}

@media (max-width: 1199px) {
  .cofiel-v2 .catalogo-emision #datosGenerales .panel-body > .row > .col-md-12,
  .cofiel-v2 .catalogo-emision #rowDatosPagos > .col-md-12 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  .cofiel-v2 .cofiel-page-header {
    padding-right: 0;
  }

  .cofiel-topbar__timbres-label {
    display: none;
  }

  .cofiel-topbar__timbres {
    margin-right: 0;
    padding-right: 0;
    border-right: none;
  }

  .cofiel-v2 .catalogo-emision #datosGenerales .panel-body > .row > .col-md-12,
  .cofiel-v2 .catalogo-emision #rowDatosPagos > .col-md-12,
  .cofiel-v2 .catalogo-emision #rowDatosCliente {
    grid-template-columns: 1fr;
  }

  .cofiel-v2 .catalogo-emision .cofiel-products-layout {
    grid-template-columns: 1fr;
  }

  .cofiel-v2 .catalogo-emision .cofiel-totals-wrap {
    max-width: none;
    justify-self: stretch;
  }

  .cofiel-v2 section .sidebar_left:not(.no-display) {
    position: relative !important;
    width: 100% !important;
    height: auto !important;
  }

  .cofiel-v2 section .sidebar_left:not(.no-display) + .content {
    margin-left: 0 !important;
    border-radius: 0 0 var(--cofiel-radius-lg) var(--cofiel-radius-lg);
    border-top: none;
  }

  .cofiel-v2 section.catalogo-generico:has(.sidebar_left:not(.no-display)) {
    flex-direction: column;
  }

  .cofiel-v2 section.catalogo-generico:has(.sidebar_left:not(.no-display)) .sidebar_left:not(.no-display) {
    flex: 0 0 auto;
    width: 100% !important;
    border-radius: var(--cofiel-radius-lg) var(--cofiel-radius-lg) 0 0;
  }

  .cofiel-v2 section.catalogo-generico:has(.sidebar_left:not(.no-display)) .sidebar_left:not(.no-display) + .content {
    border-radius: 0 0 var(--cofiel-radius-lg) var(--cofiel-radius-lg);
    border-top: none;
  }
}

/* CP2 — standalone shared components */
.cofiel-v2 .cofiel-card > .cofiel-card__body,
.cofiel-v2 .cofiel-card > .panel-body,
.cofiel-v2 .cofiel-card > form {
  padding: var(--cofiel-space-6);
}

.cofiel-v2 .cofiel-card .cofiel-form-grid {
  margin-bottom: 0;
}

.cofiel-v2 .cofiel-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--cofiel-space-3);
  padding: var(--cofiel-space-4) var(--cofiel-space-5);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
  margin-bottom: var(--cofiel-space-4);
}

.cofiel-v2 .cofiel-toolbar__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cofiel-space-2);
  margin-left: auto;
}

/* CP4 — list/table modules */
/* fe_certificados — formulario nuevo certificado */
.cofiel-v2 section.catalogo-certificados #opcionNuevo .cofiel-cert-body {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: var(--cofiel-space-6) var(--cofiel-space-5) !important;
  box-sizing: border-box;
}

.cofiel-v2 section.catalogo-certificados .cofiel-cert-form {
  display: block !important;
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
}

.cofiel-v2 .cofiel-cert-form__card {
  display: flex;
  flex-direction: column;
  gap: var(--cofiel-space-4);
  width: 100%;
  padding: var(--cofiel-space-6);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
}

.cofiel-v2 .cofiel-cert-form__intro {
  margin-bottom: var(--cofiel-space-1);
  padding-bottom: var(--cofiel-space-4);
  border-bottom: 1px solid var(--cofiel-border-light);
  text-align: center;
}

.cofiel-v2 .cofiel-cert-form__title {
  margin: 0 0 var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-lg);
  font-weight: 700;
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-cert-form__lead {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  line-height: 1.5;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-cert-form__field {
  display: flex !important;
  flex-direction: column;
  align-items: stretch;
  gap: var(--cofiel-space-2);
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
}

.cofiel-v2 .cofiel-cert-form__label {
  display: block;
  width: 100% !important;
  margin: 0;
  padding: 0 !important;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .cofiel-cert-form__input,
.cofiel-v2 .cofiel-cert-form__field .form-control {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  min-height: 44px;
  padding: 0.6rem 0.85rem;
  font-size: var(--cofiel-font-size-base) !important;
  box-sizing: border-box;
}

.cofiel-v2 .cofiel-cert-form__upload {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--cofiel-space-2);
  padding: var(--cofiel-space-4);
  background: var(--cofiel-bg-hover);
  border: 1px dashed var(--cofiel-border);
  border-radius: var(--cofiel-radius-lg);
}

.cofiel-v2 .cofiel-cert-form__upload-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cofiel-space-2);
  width: 100%;
  min-height: 44px;
  font-weight: 600;
}

.cofiel-v2 .cofiel-cert-form__file-badge {
  width: 100%;
  max-width: 100%;
  min-height: 40px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cofiel-v2 .cofiel-cert-form__field--checkbox {
  padding-top: var(--cofiel-space-2);
  border-top: 1px solid var(--cofiel-border-light);
}

.cofiel-v2 .cofiel-cert-form__check {
  display: inline-flex;
  align-items: center;
  gap: var(--cofiel-space-3);
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  color: var(--cofiel-text);
  cursor: pointer;
}

.cofiel-v2 .cofiel-cert-form__check input {
  width: 18px;
  height: 18px;
  margin: 0;
  flex-shrink: 0;
}

.cofiel-v2 .cofiel-cert-form__field.has-error .cofiel-cert-form__input,
.cofiel-v2 .cofiel-cert-form__upload.has-error {
  border-color: var(--cofiel-danger);
}

.cofiel-v2 .cofiel-cert-form__upload.has-error .cofiel-cert-form__upload-btn {
  border-color: var(--cofiel-danger);
}

@media (max-width: 991px) {
  .cofiel-v2 section.catalogo-certificados #opcionNuevo .cofiel-cert-body {
    padding: var(--cofiel-space-4) !important;
  }

  .cofiel-v2 section.catalogo-certificados .cofiel-cert-form {
    max-width: 100%;
  }

  .cofiel-v2 .cofiel-cert-form__card {
    padding: var(--cofiel-space-5);
  }
}

.cofiel-v2 section.catalogo-comprobantes,
.cofiel-v2 section.catalogo-certificados,
.cofiel-v2 section.catalogo-reportes,
.cofiel-v2 section.catalogo-clientes,
.cofiel-v2 section.catalogo-productos,
.cofiel-v2 section.catalogo-sucursales,
.cofiel-v2 section.catalogo-series,
.cofiel-v2 section.catalogo-moneda,
.cofiel-v2 section.catalogo-configuracion,
.cofiel-v2 section.catalogo-tienda,
.cofiel-v2 section.catalogo-detalle {
  min-height: 520px;
}

.cofiel-v2 .cofiel-panel-card > .header-toolbar {
  margin-bottom: 0 !important;
  border-radius: 0 !important;
  border-left: none !important;
  border-right: none !important;
  border-top: none !important;
}

.cofiel-v2 .cofiel-list-toolbar .input-group {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch;
  width: auto !important;
  max-width: 420px;
  min-width: 280px;
  float: none !important;
  margin-bottom: 0 !important;
}

.cofiel-v2 .cofiel-list-toolbar .input-group-btn {
  display: flex;
  flex: 0 0 auto;
  width: auto;
}

.cofiel-v2 .cofiel-list-toolbar .input-group-btn > .btn {
  border-radius: var(--cofiel-radius) 0 0 var(--cofiel-radius) !important;
  min-height: 38px;
  white-space: nowrap;
  display: flex;
  align-items: center;
}

.cofiel-v2 .cofiel-list-toolbar .input-group .form-control {
  width: auto !important;
  flex: 1 1 auto;
  min-width: 0;
  min-height: 38px;
  float: none !important;
  display: block !important;
  border-radius: 0 var(--cofiel-radius) var(--cofiel-radius) 0 !important;
}

.cofiel-v2 .cofiel-list-toolbar .pagination {
  display: inline-flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  margin: 0 0 0 auto;
  padding: 0;
  list-style: none;
  float: none !important;
}

.cofiel-v2 .cofiel-list-toolbar .pagination > li {
  display: inline-flex;
  float: none !important;
}

.cofiel-v2 .cofiel-list-toolbar .pagination > li > a,
.cofiel-v2 .cofiel-list-toolbar .pagination > li > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: var(--cofiel-space-2) var(--cofiel-space-4);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  line-height: 1.2;
  color: var(--cofiel-text-secondary);
  text-decoration: none !important;
  white-space: nowrap;
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border);
  border-radius: var(--cofiel-radius);
  box-shadow: var(--cofiel-shadow-xs);
  transition: background-color var(--cofiel-transition), border-color var(--cofiel-transition), color var(--cofiel-transition);
}

.cofiel-v2 .cofiel-list-toolbar .pagination > li:not(.disabled) > a:hover,
.cofiel-v2 .cofiel-list-toolbar .pagination > li:not(.disabled) > a:focus {
  background: var(--cofiel-bg-hover);
  border-color: var(--cofiel-primary);
  color: var(--cofiel-primary);
}

.cofiel-v2 .cofiel-list-toolbar .pagination > li.disabled > a,
.cofiel-v2 .cofiel-list-toolbar .pagination > li.disabled > span {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
  background: var(--cofiel-bg-hover);
  box-shadow: none;
}

.cofiel-v2 .cofiel-list-body {
  padding: 0 0 var(--cofiel-space-1) !important;
  background: var(--cofiel-bg-card) !important;
  border-radius: 0 0 var(--cofiel-radius-lg) var(--cofiel-radius-lg);
  overflow: visible;
}

.cofiel-v2 .cofiel-list-body.scrollThis {
  max-height: none;
  overflow: visible;
}

.cofiel-v2 .cofiel-list-body table {
  margin: 0 !important;
  border: none !important;
  width: 100% !important;
}

.cofiel-v2 .cofiel-list-body tbody td:first-child {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  border: none !important;
  vertical-align: top !important;
  box-sizing: border-box !important;
}

/* DataTables helper columns (sort/filter) must stay hidden in list UI */
.cofiel-v2 .cofiel-list-body tbody td:not(:first-child) {
  display: none !important;
  width: 0 !important;
  max-width: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  overflow: hidden !important;
}

/* Catalog list rows — reset legacy default.css float/width layout */
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left,
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .right,
.cofiel-v2 section.catalogo-generico #opcionListado .body-form tr .left,
.cofiel-v2 section.catalogo-generico #opcionListado .body-form tr .right,
.cofiel-v2 #listadoSeries .body-form tr .left,
.cofiel-v2 #listadoSeries .body-form tr .right {
  width: auto !important;
  float: none !important;
  margin: 0 !important;
  padding-top: 0 !important;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left p.big,
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left p.small,
.cofiel-v2 section.catalogo-generico #opcionListado .body-form tr .left p.big,
.cofiel-v2 section.catalogo-generico #opcionListado .body-form tr .left p.small,
.cofiel-v2 #listadoSeries .body-form tr .left p.big,
.cofiel-v2 #listadoSeries .body-form tr .left p.small {
  float: none !important;
  width: auto !important;
  max-width: 100%;
  margin: 0 !important;
  white-space: normal !important;
  overflow: visible !important;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.cofiel-v2 .cofiel-list-body .dataTables_wrapper .dataTables_paginate,
.cofiel-v2 .cofiel-list-body .dataTables_wrapper .dataTables_length,
.cofiel-v2 .cofiel-list-body .dataTables_wrapper .dataTables_filter,
.cofiel-v2 .cofiel-list-body .dataTables_wrapper .dataTables_info {
  display: none !important;
}

.cofiel-v2 .cofiel-list-body .dataTables_processing {
  background: rgba(255, 255, 255, 0.96);
  color: var(--cofiel-text-muted);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius);
  box-shadow: var(--cofiel-shadow-xs);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
}

.cofiel-v2 .cofiel-list-body .dataTables_empty {
  margin: 0;
  padding: var(--cofiel-space-10) var(--cofiel-space-6);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  line-height: 1.5;
  color: var(--cofiel-text-muted);
  text-align: center;
  background:
    url('../img/v2/empty-products.svg') center top / 56px no-repeat,
    linear-gradient(180deg, var(--cofiel-bg-hover) 0%, var(--cofiel-bg-card) 100%);
  background-position: center 28px, 0 0;
  padding-top: calc(var(--cofiel-space-10) + 56px);
}

.cofiel-v2 .cofiel-list-body tbody tr {
  display: block !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
}

.cofiel-v2 .cofiel-list-body tbody tr:hover,
.cofiel-v2 .cofiel-list-body tbody tr.bg-white {
  background: transparent !important;
}

.cofiel-v2 #listadoSeries .cofiel-list-body .item-serie:not(.item-comprobante),
.cofiel-v2 #opcionListado .body-form .item-serie:not(.item-comprobante),
.cofiel-v2 #listadoSeries .body-form .item-serie:not(.item-comprobante),
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) {
  position: relative;
  display: flex !important;
  flex-direction: row;
  flex-wrap: nowrap;
  float: none !important;
  width: auto !important;
  align-items: center;
  justify-content: space-between;
  gap: var(--cofiel-space-3);
  min-height: 56px;
  padding: var(--cofiel-space-3) var(--cofiel-space-4) var(--cofiel-space-3) calc(var(--cofiel-space-4) + 6px);
  border-bottom: 1px solid var(--cofiel-border-light);
  transition: background-color var(--cofiel-transition), box-shadow var(--cofiel-transition);
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante)::before {
  content: '';
  position: absolute;
  top: var(--cofiel-space-3);
  bottom: var(--cofiel-space-3);
  left: 0;
  width: 3px;
  border-radius: var(--cofiel-radius-full);
  background: var(--cofiel-border);
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante)[data-status="1"]::before {
  background: var(--cofiel-success);
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante)[data-status="0"]::before {
  background: var(--cofiel-text-placeholder);
}

.cofiel-v2 .cofiel-list-body tbody tr:hover .item-serie:not(.item-comprobante),
.cofiel-v2 .cofiel-list-body tbody tr.bg-white .item-serie:not(.item-comprobante),
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante):focus-within {
  background: var(--cofiel-bg-hover);
}

.cofiel-v2 .cofiel-list-body tbody tr:last-child .item-serie:not(.item-comprobante) {
  border-bottom: none;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante)[data-status="0"] .left {
  opacity: 0.82;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left {
  flex: 1 1 0;
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--cofiel-space-1) var(--cofiel-space-4);
  align-items: center;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left .row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--cofiel-space-1) var(--cofiel-space-4);
  width: 100%;
  margin: 0;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left .row > p {
  margin: 0;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left p.big,
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left p.small {
  margin: 0;
  min-width: 0;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left p.big {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text);
  line-height: 1.45;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left p.small {
  font-size: var(--cofiel-font-size-xs);
  color: var(--cofiel-text-muted);
  line-height: 1.4;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left label {
  margin: 0;
  font-weight: inherit;
  color: inherit;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left b {
  font-weight: 600;
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones,
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones.visibility-hidden {
  visibility: visible !important;
  opacity: 1 !important;
  display: flex;
  flex: 0 0 auto;
  flex-shrink: 0;
  flex-wrap: nowrap;
  align-items: center;
  align-self: center;
  gap: var(--cofiel-space-1);
  width: auto !important;
  max-width: none;
  margin-left: auto;
  min-width: 0;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones > button {
  min-height: 36px;
  margin: 0 !important;
  border-radius: var(--cofiel-radius-sm) !important;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones > button:not(.btn-pago):not(.btn-danger):not(.btn-success):not(.btn-mostrar) {
  min-width: 36px;
  padding: 0;
  color: var(--cofiel-text-secondary);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border);
  box-shadow: none;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones > button:not(.btn-pago):not(.btn-danger):not(.btn-success):not(.btn-mostrar):hover,
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones > button:not(.btn-pago):not(.btn-danger):not(.btn-success):not(.btn-mostrar):focus-visible {
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  border-color: var(--cofiel-primary-muted);
}

.cofiel-v2 section.catalogo-generico:not(.catalogo-comprobantes) .body-form .item-serie .opciones > button.btn-mostrar,
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones > button.btn-mostrar {
  min-width: 36px;
  padding: 0;
  color: var(--cofiel-text-inverse);
  background: var(--cofiel-primary);
  border-color: var(--cofiel-primary);
}

.cofiel-v2 section.catalogo-generico:not(.catalogo-comprobantes) .body-form .item-serie .opciones > button.btn-mostrar:hover,
.cofiel-v2 section.catalogo-generico:not(.catalogo-comprobantes) .body-form .item-serie .opciones > button.btn-mostrar:focus-visible,
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones > button.btn-mostrar:hover,
.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones > button.btn-mostrar:focus-visible {
  color: var(--cofiel-text-inverse);
  background: var(--cofiel-primary-hover);
  border-color: var(--cofiel-primary-hover);
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones > button.btn-pago {
  min-height: 36px;
  padding: 0 var(--cofiel-space-3);
  font-size: var(--cofiel-font-size-xs);
  white-space: nowrap;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones .btn-group {
  display: inline-flex;
  align-items: stretch;
  vertical-align: middle;
  height: auto;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones .btn-group > .btn {
  float: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 36px;
  margin: 0 !important;
  padding: 0 var(--cofiel-space-3) !important;
  font-size: var(--cofiel-font-size-xs);
  border-radius: 0 !important;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones .btn-group > .btn:first-child {
  border-top-left-radius: var(--cofiel-radius-sm) !important;
  border-bottom-left-radius: var(--cofiel-radius-sm) !important;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones .btn-group > .dropdown-toggle {
  border-top-right-radius: var(--cofiel-radius-sm) !important;
  border-bottom-right-radius: var(--cofiel-radius-sm) !important;
  padding-left: var(--cofiel-space-2);
  padding-right: var(--cofiel-space-2);
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones .btn-group > .btn + .btn {
  margin-left: -1px !important;
}

.cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones .btn-group .dropdown-toggle .caret {
  display: none !important;
}

/* fe_comprobantes — filas de comprobante */
.cofiel-v2 .catalogo-comprobantes #opcionListado .body-form tr .left,
.cofiel-v2 .catalogo-comprobantes #opcionListado .body-form tr .right,
.cofiel-v2 .catalogo-comprobantes #opcionNuevo .body-form tr .left,
.cofiel-v2 .catalogo-comprobantes #opcionNuevo .body-form tr .right,
.cofiel-v2 .catalogo-comprobantes #opcionCancelados .body-form tr .left,
.cofiel-v2 .catalogo-comprobantes #opcionCancelados .body-form tr .right {
  width: auto !important;
  float: none !important;
  margin: 0 !important;
  padding-top: 0 !important;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante {
  position: relative;
  display: flex;
  float: none !important;
  width: auto !important;
  align-items: center;
  justify-content: space-between;
  gap: var(--cofiel-space-2);
  min-height: 0;
  padding: var(--cofiel-space-2) var(--cofiel-space-3) var(--cofiel-space-2) calc(var(--cofiel-space-3) + 6px);
  border-bottom: 1px solid var(--cofiel-border-light);
  transition: background-color var(--cofiel-transition);
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante::before {
  content: '';
  position: absolute;
  top: var(--cofiel-space-2);
  bottom: var(--cofiel-space-2);
  left: 0;
  width: 3px;
  border-radius: var(--cofiel-radius-full);
  background: var(--cofiel-success);
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante--pending::before {
  background: var(--cofiel-warning);
}

.cofiel-v2 .catalogo-comprobantes tbody tr:hover .item-comprobante,
.cofiel-v2 .catalogo-comprobantes .item-comprobante:focus-within {
  background: var(--cofiel-bg-hover);
}

.cofiel-v2 .catalogo-comprobantes tbody tr:last-child .item-comprobante {
  border-bottom: none;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .left.cofiel-voucher-row {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto;
  grid-template-areas: "ids details amount";
  gap: var(--cofiel-space-2) var(--cofiel-space-4);
  align-items: center;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__ids {
  grid-area: ids;
  display: flex;
  align-items: stretch;
  gap: var(--cofiel-space-2);
  min-width: 0;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__id-block {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1px;
  min-width: 56px;
  padding: 2px var(--cofiel-space-2);
  background: var(--cofiel-bg-hover);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-sm);
  box-shadow: none;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__id-block--folio {
  min-width: 60px;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__id-label {
  font-size: 9px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__id-value {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  line-height: 1.15;
  color: var(--cofiel-text);
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__id-block--folio .cofiel-voucher-row__id-value {
  font-weight: 700;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__details {
  grid-area: details;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--cofiel-space-1) var(--cofiel-space-2);
  min-width: 0;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__name {
  font-size: var(--cofiel-font-size-xs);
  font-weight: 600;
  color: var(--cofiel-text-secondary);
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: min(220px, 32vw);
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__rfc {
  font-size: 11px;
  font-weight: 500;
  color: var(--cofiel-text-muted);
  line-height: 1.2;
  white-space: nowrap;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__secondary {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--cofiel-space-1);
  min-width: 0;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  max-width: 100%;
  padding: 1px var(--cofiel-space-2);
  font-size: 11px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--cofiel-text-muted);
  background: var(--cofiel-bg-hover);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-sm);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__chip .cofiel-voucher-row__chip-label {
  font-weight: 600;
  color: var(--cofiel-text-secondary);
  margin-right: 0.35em;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__chip--status {
  color: var(--cofiel-warning);
  background: var(--cofiel-warning-bg);
  border-color: rgba(217, 119, 6, 0.25);
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__amount {
  grid-area: amount;
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 96px;
  padding: 0 var(--cofiel-space-2);
  text-align: right;
  white-space: nowrap;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__amount-value {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text);
  line-height: 1.15;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones,
.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones.visibility-hidden {
  visibility: visible !important;
  opacity: 1 !important;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  align-self: center;
  gap: var(--cofiel-space-2);
  margin-left: auto;
  flex: 0 0 auto;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones > button {
  min-height: 36px;
  border-radius: var(--cofiel-radius-sm) !important;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones > button.btn-mostrar {
  min-width: 36px;
  padding: 0;
  color: var(--cofiel-text-inverse);
  background: var(--cofiel-primary);
  border-color: var(--cofiel-primary);
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones > button.btn-mostrar:hover,
.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones > button.btn-mostrar:focus-visible {
  color: var(--cofiel-text-inverse);
  background: var(--cofiel-primary-hover);
  border-color: var(--cofiel-primary-hover);
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones > button.btn-cancelar,
.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones > button.btn-descartar {
  min-width: 36px;
  padding: 0;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones .btn-group,
.cofiel-v2 .catalogo-comprobantes .item-comprobante .cofiel-voucher-download {
  display: inline-flex;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 0 !important;
  vertical-align: middle;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones .btn-group > .btn,
.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download > .btn {
  float: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 36px;
  margin: 0 !important;
  padding: 0 var(--cofiel-space-3) !important;
  font-size: var(--cofiel-font-size-xs) !important;
  font-weight: 600 !important;
  line-height: 1.2;
  color: var(--cofiel-text-secondary) !important;
  background: var(--cofiel-bg-card) !important;
  border: 1px solid var(--cofiel-border) !important;
  border-radius: 0 !important;
  box-shadow: none;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones .btn-group > .btn:first-child,
.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download > .btn:first-child {
  border-top-left-radius: var(--cofiel-radius-sm) !important;
  border-bottom-left-radius: var(--cofiel-radius-sm) !important;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones .btn-group > .dropdown-toggle,
.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download > .dropdown-toggle {
  border-top-right-radius: var(--cofiel-radius-sm) !important;
  border-bottom-right-radius: var(--cofiel-radius-sm) !important;
  padding-left: var(--cofiel-space-2) !important;
  padding-right: var(--cofiel-space-2) !important;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones .btn-group > .btn + .btn,
.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download > .btn + .btn {
  margin-left: -1px !important;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download > .btn:hover,
.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download > .btn:focus-visible,
.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download.open > .btn {
  color: var(--cofiel-primary) !important;
  background: var(--cofiel-primary-light) !important;
  border-color: var(--cofiel-primary-muted) !important;
  z-index: 1;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download__trigger {
  display: inline-flex !important;
  align-items: center;
  gap: var(--cofiel-space-2);
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download__toggle::after {
  display: none !important;
  content: none !important;
}

.cofiel-v2 .catalogo-comprobantes .cofiel-voucher-download__toggle::before {
  content: '\f107';
  font-family: FontAwesome;
  font-size: 12px;
  line-height: 1;
}

.cofiel-v2 .catalogo-comprobantes .item-comprobante .btn-pago,
.cofiel-v2 .catalogo-comprobantes .item-comprobante .btn-timbrar {
  display: inline-flex !important;
  align-items: center;
  gap: var(--cofiel-space-2);
  min-height: 36px;
  padding: 0 var(--cofiel-space-3) !important;
  font-size: var(--cofiel-font-size-xs) !important;
  white-space: nowrap;
}

@media (max-width: 991px) {
  .cofiel-v2 .catalogo-comprobantes .item-comprobante .left.cofiel-voucher-row {
    grid-template-columns: auto minmax(0, 1fr);
    grid-template-areas:
      "ids amount"
      "details details";
  }
}

@media (max-width: 767px) {
  .cofiel-v2 .catalogo-comprobantes .item-comprobante .left.cofiel-voucher-row {
    grid-template-columns: 1fr;
    grid-template-areas:
      "ids"
      "amount"
      "details";
  }

  .cofiel-v2 .catalogo-comprobantes .cofiel-voucher-row__amount {
    width: 100%;
    min-width: 0;
    justify-content: flex-start;
    text-align: left;
  }

  .cofiel-v2 .catalogo-comprobantes .item-comprobante .opciones {
    flex-wrap: wrap;
  }
}

.cofiel-v2 .cofiel-list-toolbar__summary {
  order: -1;
  flex: 1 1 100%;
  margin: 0;
  font-size: var(--cofiel-font-size-xs);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-list-toolbar .input-group .form-control::placeholder {
  color: var(--cofiel-text-placeholder);
}

@media (min-width: 768px) {
  .cofiel-v2 .cofiel-list-toolbar__summary {
    order: 0;
    flex: 0 1 auto;
    min-width: 96px;
    margin-right: var(--cofiel-space-2);
    text-transform: none;
    letter-spacing: 0;
    font-size: var(--cofiel-font-size-sm);
    font-weight: 500;
  }
}

/* fe_tienda — tienda de paquetes */
.cofiel-v2 section.catalogo-tienda .content {
  margin-left: 0 !important;
  margin-right: 0 !important;
  overflow: visible !important;
}

.cofiel-v2 section.catalogo-tienda .cofiel-panel-card {
  overflow: visible;
}

.cofiel-v2 section.catalogo-tienda .content .body-form.cofiel-tienda-body,
.cofiel-v2 section.catalogo-tienda #opcionListado .body-form.cofiel-tienda-body {
  box-sizing: border-box !important;
  position: relative !important;
  top: auto !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  float: none !important;
  width: 100% !important;
  max-width: 100%;
  margin: 0 !important;
  padding: var(--cofiel-space-5) var(--cofiel-space-6) var(--cofiel-space-6) !important;
  overflow: visible !important;
  background: var(--cofiel-bg-card) !important;
}

.cofiel-v2 .cofiel-tienda-body > * {
  max-width: 100%;
  min-width: 0;
}

.cofiel-v2 .cofiel-tienda-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--cofiel-space-5);
  margin-bottom: var(--cofiel-space-6);
  padding: var(--cofiel-space-6);
  background: linear-gradient(135deg, var(--cofiel-primary-light) 0%, #fff 68%);
  border: 1px solid var(--cofiel-primary-muted);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-sm);
}

.cofiel-v2 .cofiel-tienda-hero__eyebrow {
  margin: 0 0 var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cofiel-primary);
}

.cofiel-v2 .cofiel-tienda-hero__title {
  margin: 0 0 var(--cofiel-space-3);
  font-size: clamp(1.35rem, 2.2vw, 1.75rem);
  font-weight: 700;
  line-height: 1.25;
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-tienda-hero__lead {
  margin: 0;
  font-size: var(--cofiel-font-size-base);
  line-height: 1.55;
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .cofiel-tienda-hero__features {
  display: flex;
  flex-direction: column;
  gap: var(--cofiel-space-3);
  justify-content: center;
}

.cofiel-v2 .cofiel-tienda-feature {
  display: flex;
  align-items: flex-start;
  gap: var(--cofiel-space-3);
  padding: var(--cofiel-space-3) var(--cofiel-space-4);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
}

.cofiel-v2 .cofiel-tienda-feature__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  font-size: var(--cofiel-font-size-md);
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  border-radius: var(--cofiel-radius);
}

.cofiel-v2 .cofiel-tienda-feature__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.cofiel-v2 .cofiel-tienda-feature__text strong {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-tienda-feature__text span {
  font-size: var(--cofiel-font-size-sm);
  line-height: 1.4;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-tienda-slider {
  margin-bottom: var(--cofiel-space-5);
}

.cofiel-v2 .cofiel-tienda-slider__header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--cofiel-space-3);
  margin-bottom: var(--cofiel-space-4);
}

.cofiel-v2 .cofiel-tienda-slider__title {
  margin: 0 0 var(--cofiel-space-1);
  font-size: var(--cofiel-font-size-lg);
  font-weight: 700;
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-tienda-slider__subtitle {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-tienda-slider__nav {
  display: inline-flex;
  gap: var(--cofiel-space-2);
}

.cofiel-v2 .cofiel-tienda-slider__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  color: var(--cofiel-text-secondary);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border);
  border-radius: var(--cofiel-radius-full);
  cursor: pointer;
  box-shadow: var(--cofiel-shadow-xs);
  transition: background-color var(--cofiel-transition), border-color var(--cofiel-transition), color var(--cofiel-transition);
}

.cofiel-v2 .cofiel-tienda-slider__arrow:hover,
.cofiel-v2 .cofiel-tienda-slider__arrow:focus-visible {
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  border-color: var(--cofiel-primary-muted);
  outline: none;
}

.cofiel-v2 .cofiel-tienda-slider__viewport {
  position: relative;
  margin: 0;
  padding: 0;
  overflow: visible;
}

.cofiel-v2 .cofiel-tienda-slider__track {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-4);
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x proximity;
  scroll-behavior: auto;
  scroll-padding-inline: max(var(--cofiel-space-4), calc(50% - 140px));
  /* Extra vertical room for scale(1.04) + active card shadow */
  padding: var(--cofiel-space-6) max(var(--cofiel-space-4), calc(50% - 140px)) var(--cofiel-space-8);
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.cofiel-v2 .cofiel-tienda-slider__track.cofiel-tienda-slider__track--animating {
  scroll-snap-type: none;
}

.cofiel-v2 .cofiel-tienda-slider__track::-webkit-scrollbar {
  display: none;
}

.cofiel-v2 .cofiel-tienda-slider__track .cofiel-tienda-card {
  flex: 0 0 280px;
  scroll-snap-align: center;
  max-width: 280px;
  opacity: 0.72;
  transform: scale(0.94);
  transform-origin: center center;
  filter: saturate(0.85);
  z-index: 1;
  cursor: pointer;
}

.cofiel-v2 .cofiel-tienda-slider__track .cofiel-tienda-card.is-active {
  opacity: 1;
  transform: scale(1.04);
  filter: none;
  z-index: 3;
  border-color: var(--cofiel-primary);
  box-shadow: 0 14px 36px rgba(43, 89, 195, 0.2);
}

.cofiel-v2 .cofiel-tienda-slider__dots {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--cofiel-space-2);
  margin-top: var(--cofiel-space-3);
}

.cofiel-v2 .cofiel-tienda-slider__dot {
  width: 8px;
  height: 8px;
  padding: 0;
  border: none;
  border-radius: var(--cofiel-radius-full);
  background: var(--cofiel-border);
  cursor: pointer;
  transition: transform var(--cofiel-transition), background-color var(--cofiel-transition);
}

.cofiel-v2 .cofiel-tienda-slider__dot.is-active {
  background: var(--cofiel-primary);
  transform: scale(1.25);
}

.cofiel-v2 .cofiel-tienda-table {
  display: none !important;
}

.cofiel-v2 .cofiel-tienda-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  min-height: 100%;
  padding: var(--cofiel-space-5) var(--cofiel-space-4) var(--cofiel-space-4);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.55s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.55s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.55s cubic-bezier(0.22, 1, 0.36, 1), filter 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

.cofiel-v2 .cofiel-tienda-slider__track .cofiel-tienda-card:not(.is-active):hover {
  opacity: 0.82;
  transform: scale(0.96);
  border-color: var(--cofiel-primary-muted);
}

.cofiel-v2 .cofiel-tienda-slider__track .cofiel-tienda-card.is-active:hover {
  transform: scale(1.02);
  box-shadow: 0 16px 40px rgba(43, 89, 195, 0.24);
}

.cofiel-v2 .cofiel-tienda-card--popular:not(.is-active) {
  border-color: var(--cofiel-primary-muted);
  box-shadow: 0 6px 20px rgba(43, 89, 195, 0.1);
}

.cofiel-v2 .cofiel-tienda-card__badge {
  position: absolute;
  top: var(--cofiel-space-3);
  right: var(--cofiel-space-3);
  padding: var(--cofiel-space-1) var(--cofiel-space-3);
  font-size: var(--cofiel-font-size-xs);
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  border: 1px solid var(--cofiel-primary-muted);
  border-radius: var(--cofiel-radius-full);
}

.cofiel-v2 .cofiel-tienda-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  margin-bottom: var(--cofiel-space-3);
  font-size: 1.35rem;
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  border-radius: var(--cofiel-radius-full);
}

.cofiel-v2 .cofiel-tienda-card__folios {
  margin: 0 0 var(--cofiel-space-1);
  font-size: var(--cofiel-font-size-2xl);
  font-weight: 700;
  line-height: 1.1;
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-tienda-card__folios span {
  display: block;
  margin-top: var(--cofiel-space-1);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.cofiel-v2 .cofiel-tienda-card__desc {
  margin: 0 0 var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .cofiel-tienda-card__unit {
  margin: 0 0 var(--cofiel-space-3);
  font-size: var(--cofiel-font-size-xs);
  font-weight: 600;
  color: var(--cofiel-success);
}

.cofiel-v2 .cofiel-tienda-card__unit span {
  font-weight: 500;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-tienda-card__price {
  margin-bottom: var(--cofiel-space-1);
  font-size: var(--cofiel-font-size-xl);
  font-weight: 700;
  line-height: 1.2;
  color: var(--cofiel-primary);
}

.cofiel-v2 .cofiel-tienda-card__currency {
  font-size: var(--cofiel-font-size-md);
  vertical-align: top;
}

.cofiel-v2 .cofiel-tienda-card__price small {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-tienda-card__iva {
  margin: 0 0 var(--cofiel-space-4);
  font-size: var(--cofiel-font-size-xs);
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-tienda-card__cta {
  width: 100%;
  margin-top: auto;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cofiel-space-2);
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(43, 89, 195, 0.2);
}

.cofiel-v2 .cofiel-tienda-notes {
  display: flex;
  flex-direction: column;
  gap: var(--cofiel-space-2);
  padding: var(--cofiel-space-4);
  background: var(--cofiel-bg-page);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
}

.cofiel-v2 .cofiel-tienda-notes__item {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .cofiel-tienda-notes__item .fa {
  margin-right: var(--cofiel-space-2);
  color: var(--cofiel-primary);
}

.cofiel-v2 .cofiel-tienda-notes__item a {
  color: var(--cofiel-primary);
  font-weight: 600;
  text-decoration: none;
}

.cofiel-v2 .cofiel-tienda-notes__item a:hover {
  text-decoration: underline;
}

.cofiel-v2 .cofiel-tienda-checkout {
  padding: var(--cofiel-space-6) !important;
  background: var(--cofiel-bg-page) !important;
}

.cofiel-v2 .cofiel-tienda-checkout__card {
  max-width: 520px;
  margin: 0 auto;
  padding: var(--cofiel-space-6);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-sm);
  text-align: center;
}

.cofiel-v2 .cofiel-tienda-checkout__eyebrow {
  margin: 0 0 var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-tienda-checkout__title {
  margin: 0 0 var(--cofiel-space-5);
  font-size: var(--cofiel-font-size-xl);
  font-weight: 700;
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-tienda-checkout__title span {
  color: var(--cofiel-primary);
}

.cofiel-v2 .cofiel-tienda-checkout__breakdown {
  margin: 0 0 var(--cofiel-space-5);
  padding: var(--cofiel-space-4);
  background: var(--cofiel-bg-page);
  border-radius: var(--cofiel-radius-lg);
  text-align: left;
}

.cofiel-v2 .cofiel-tienda-checkout__breakdown > div {
  display: flex;
  justify-content: space-between;
  gap: var(--cofiel-space-3);
  padding: var(--cofiel-space-2) 0;
  border-bottom: 1px solid var(--cofiel-border-light);
}

.cofiel-v2 .cofiel-tienda-checkout__breakdown > div:last-child {
  border-bottom: none;
}

.cofiel-v2 .cofiel-tienda-checkout__breakdown dt {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .cofiel-tienda-checkout__breakdown dd {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-tienda-checkout__total-row dt,
.cofiel-v2 .cofiel-tienda-checkout__total-row dd {
  font-size: var(--cofiel-font-size-md);
  font-weight: 700;
  color: var(--cofiel-primary);
}

.cofiel-v2 .cofiel-tienda-checkout__cta {
  width: 100%;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cofiel-space-2);
  font-weight: 600;
}

.cofiel-v2 .cofiel-tienda-checkout__amount {
  margin: 0 0 var(--cofiel-space-5);
  font-size: var(--cofiel-font-size-lg);
  font-weight: 700;
  color: var(--cofiel-primary);
}

.cofiel-v2 .cofiel-tienda-payment {
  text-align: left;
}

.cofiel-v2 .cofiel-tienda-payment__title {
  margin: 0 0 var(--cofiel-space-4);
  font-size: var(--cofiel-font-size-base);
  font-weight: 600;
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-tienda-payment__list {
  margin: 0;
}

.cofiel-v2 .cofiel-tienda-payment__list > div {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--cofiel-space-2) var(--cofiel-space-4);
  padding: var(--cofiel-space-2) 0;
  border-bottom: 1px solid var(--cofiel-border-light);
}

.cofiel-v2 .cofiel-tienda-payment__list > div:last-child {
  border-bottom: none;
}

.cofiel-v2 .cofiel-tienda-payment__list dt {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-tienda-payment__list dd {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  color: var(--cofiel-text);
  word-break: break-word;
}

.cofiel-v2 .cofiel-tienda-payment__value {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  min-width: 0;
}

.cofiel-v2 .cofiel-tienda-payment__text {
  flex: 1;
  min-width: 0;
}

.cofiel-v2 .cofiel-tienda-payment__text--mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: var(--cofiel-font-size-xs);
}

.cofiel-v2 .cofiel-tienda-copy-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  padding: 0;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-secondary);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border);
  border-radius: var(--cofiel-radius);
  cursor: pointer;
  transition: background-color var(--cofiel-transition), border-color var(--cofiel-transition), color var(--cofiel-transition);
}

.cofiel-v2 .cofiel-tienda-copy-btn:hover,
.cofiel-v2 .cofiel-tienda-copy-btn:focus-visible {
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  border-color: var(--cofiel-primary-muted);
  outline: none;
}

.cofiel-v2 .cofiel-tienda-copy-btn.is-copied {
  color: var(--cofiel-success);
  background: var(--cofiel-success-bg);
  border-color: rgba(22, 163, 74, 0.35);
}

@media (max-width: 991px) {
  .cofiel-v2 section.catalogo-tienda .content .body-form.cofiel-tienda-body,
  .cofiel-v2 section.catalogo-tienda #opcionListado .body-form.cofiel-tienda-body {
    padding: var(--cofiel-space-4) !important;
  }

  .cofiel-v2 .cofiel-tienda-slider__track {
    scroll-padding-inline: max(var(--cofiel-space-3), calc(50% - 130px));
    padding: var(--cofiel-space-5) max(var(--cofiel-space-3), calc(50% - 130px)) var(--cofiel-space-6);
  }

  .cofiel-v2 .cofiel-tienda-slider__track .cofiel-tienda-card {
    flex-basis: min(260px, calc(100vw - 96px));
    max-width: min(260px, calc(100vw - 96px));
  }

  .cofiel-v2 .cofiel-tienda-hero {
    grid-template-columns: 1fr;
    padding: var(--cofiel-space-5);
  }

  .cofiel-v2 .cofiel-tienda-hero__title {
    font-size: var(--cofiel-font-size-lg);
  }

  .cofiel-v2 .cofiel-tienda-payment__list > div {
    grid-template-columns: 1fr;
  }
}

.cofiel-v2 section.catalogo-reportes .sidebar_left:not(.no-display) {
  flex: 0 0 240px;
  width: 240px !important;
}

/* fe_reportes — exportar comprobantes */
.cofiel-v2 section.catalogo-reportes #opcionListado .body-form.cofiel-report-panel {
  position: relative !important;
  top: auto !important;
  bottom: auto !important;
  float: none !important;
  width: 100% !important;
  overflow: visible !important;
  margin-top: 0 !important;
  padding: var(--cofiel-space-6) var(--cofiel-space-5) !important;
  box-sizing: border-box;
}

.cofiel-v2 section.catalogo-reportes .cofiel-report-body {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.cofiel-v2 section.catalogo-reportes .cofiel-report-form {
  display: block !important;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__card {
  display: flex;
  flex-direction: column;
  gap: var(--cofiel-space-4);
  width: 100%;
  padding: var(--cofiel-space-6);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__intro {
  padding-bottom: var(--cofiel-space-4);
  border-bottom: 1px solid var(--cofiel-border-light);
  text-align: center;
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__title {
  margin: 0 0 var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-lg);
  font-weight: 700;
  color: var(--cofiel-text);
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__lead {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
  line-height: 1.5;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__dates {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--cofiel-space-4);
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__field {
  display: flex !important;
  flex-direction: column;
  gap: var(--cofiel-space-2);
  margin: 0 !important;
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__label {
  margin: 0;
  padding: 0 !important;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__input,
.cofiel-v2 .catalogo-reportes .cofiel-report-form .form-control {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 44px;
  box-sizing: border-box;
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__hint {
  margin: 0;
  padding: var(--cofiel-space-3) var(--cofiel-space-4);
  font-size: var(--cofiel-font-size-sm);
  line-height: 1.45;
  color: var(--cofiel-text-muted);
  text-align: center;
  background: var(--cofiel-bg-hover);
  border-radius: var(--cofiel-radius);
}

.cofiel-v2 .catalogo-reportes .cofiel-report-form__actions {
  display: flex;
  flex-direction: column;
  gap: var(--cofiel-space-3);
  margin: 0;
  padding-top: var(--cofiel-space-2);
  border-top: 1px solid var(--cofiel-border-light);
}

.cofiel-v2 .catalogo-reportes .cofiel-report-action {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--cofiel-space-2);
  padding: var(--cofiel-space-4);
  background: var(--cofiel-bg-hover);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
}

.cofiel-v2 .catalogo-reportes .cofiel-report-action__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cofiel-space-2);
  width: 100%;
  min-height: 44px;
  font-weight: 600;
}

.cofiel-v2 .catalogo-reportes .cofiel-report-action__btn:disabled,
.cofiel-v2 .catalogo-reportes .cofiel-report-action__btn[disabled] {
  color: var(--cofiel-success);
  background: var(--cofiel-success-light);
  border-color: var(--cofiel-success-muted);
  opacity: 0.5;
  cursor: not-allowed;
  box-shadow: none;
}

.cofiel-v2 .catalogo-reportes .cofiel-report-action__desc {
  font-size: var(--cofiel-font-size-sm);
  line-height: 1.45;
  color: var(--cofiel-text-muted);
  text-align: center;
}

@media (max-width: 767px) {
  .cofiel-v2 section.catalogo-reportes #opcionListado .body-form.cofiel-report-panel {
    padding: var(--cofiel-space-4) !important;
  }

  .cofiel-v2 section.catalogo-reportes .cofiel-report-form {
    max-width: 100%;
  }

  .cofiel-v2 .catalogo-reportes .cofiel-report-form__card {
    padding: var(--cofiel-space-5);
  }

  .cofiel-v2 .catalogo-reportes .cofiel-report-form__dates {
    grid-template-columns: 1fr;
  }
}

/* CP7 — auth pages (login / registro) */
.cofiel-auth {
  background: var(--cofiel-bg-page);
  min-height: 100vh;
}

.cofiel-auth__page {
  max-width: 520px;
  margin: 0 auto;
  padding: var(--cofiel-space-8) var(--cofiel-space-4) var(--cofiel-space-10);
}

.cofiel-auth__header {
  text-align: center;
  margin-bottom: var(--cofiel-space-6);
}

.cofiel-auth__logo {
  height: 56px;
  width: auto;
  margin-bottom: var(--cofiel-space-5);
}

.cofiel-auth__title {
  margin: 0 0 var(--cofiel-space-3);
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1.25;
  color: #1E293B;
}

.cofiel-auth__title-accent {
  color: var(--cofiel-primary);
}

.cofiel-auth__subtitle {
  margin: 0;
  color: var(--cofiel-text-secondary);
  font-size: var(--cofiel-font-size-md);
  line-height: 1.5;
}

.cofiel-auth__card {
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
  padding: var(--cofiel-space-8) var(--cofiel-space-6);
  background: var(--cofiel-bg-card);
  border: none;
  border-radius: 16px;
  box-shadow: 0 8px 32px rgba(43, 89, 195, 0.1);
}

/* Auth shell — login & registro */
.cofiel-auth--login.login-usuario,
.cofiel-auth--register.registro-usuario {
  margin-top: 0 !important;
  background: linear-gradient(180deg, #F7F9FD 0%, #EEF2FA 100%);
}

.cofiel-auth--login .cofiel-auth__logo,
.cofiel-auth--register .cofiel-auth__logo {
  height: 64px;
}

.cofiel-auth--login .cofiel-auth__avatar {
  width: 80px;
  height: 80px;
  margin: 0 auto var(--cofiel-space-6);
}

.cofiel-auth--login .cofiel-auth__avatar img {
  display: block;
  width: 80px;
  height: 80px;
}

.cofiel-auth .cofiel-auth-field {
  margin-bottom: var(--cofiel-space-4);
}

.cofiel-auth .cofiel-auth-field__control {
  position: relative;
}

.cofiel-auth .cofiel-auth-field__icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  color: var(--cofiel-text-muted);
  font-size: 1rem;
  line-height: 1;
  pointer-events: none;
}

.cofiel-auth .cofiel-auth-field .form-control {
  width: 100%;
  min-height: 48px;
  padding: 0.625rem 0.875rem 0.625rem 2.75rem;
  font-size: var(--cofiel-font-size-base);
  text-align: left !important;
  background: var(--cofiel-bg-input);
  border: 1px solid var(--cofiel-border);
  border-radius: 12px;
  transition: border-color var(--cofiel-transition), box-shadow var(--cofiel-transition);
}

.cofiel-auth .cofiel-auth-field .form-control:hover,
.cofiel-auth .cofiel-auth-field .form-control:focus {
  border-width: 1px;
  border-color: var(--cofiel-border-focus);
  box-shadow: 0 0 0 3px var(--cofiel-primary-muted);
  outline: none;
}

.cofiel-auth .cofiel-auth-field--password .form-control {
  padding-right: 2.75rem;
}

.cofiel-auth .cofiel-auth-field__toggle {
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border: none;
  border-radius: var(--cofiel-radius);
  background: transparent;
  color: var(--cofiel-text-muted);
  cursor: pointer;
  transition: color var(--cofiel-transition), background-color var(--cofiel-transition);
}

.cofiel-auth .cofiel-auth-field__toggle:hover,
.cofiel-auth .cofiel-auth-field__toggle:focus-visible {
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  outline: none;
}

.cofiel-auth .cofiel-auth-field.has-error .form-control {
  border-color: var(--cofiel-danger);
  box-shadow: 0 0 0 3px var(--cofiel-danger-bg);
}

.cofiel-auth .cofiel-auth-field__help {
  margin: var(--cofiel-space-1) 0 0;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-danger);
}

.cofiel-auth .popover {
  z-index: 1060;
}

.cofiel-auth .cofiel-auth__submit {
  width: 100%;
  min-height: 48px;
  margin-top: var(--cofiel-space-2);
  padding: var(--cofiel-space-3) var(--cofiel-space-5);
  font-size: var(--cofiel-font-size-md);
  font-weight: 600;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(22, 163, 74, 0.28);
}

.cofiel-auth .cofiel-auth__submit:hover,
.cofiel-auth .cofiel-auth__submit:focus-visible {
  box-shadow: 0 6px 16px rgba(22, 163, 74, 0.35);
}

.cofiel-auth .cofiel-auth__register-link {
  margin: var(--cofiel-space-5) 0 0;
  text-align: center;
}

.cofiel-auth .cofiel-auth__register-link a {
  font-size: var(--cofiel-font-size-base);
  font-weight: 500;
  color: var(--cofiel-primary);
  text-decoration: none;
}

.cofiel-auth .cofiel-auth__register-link a:hover {
  color: var(--cofiel-primary-hover);
  text-decoration: underline;
}

.cofiel-auth .cofiel-auth__alert {
  margin-top: var(--cofiel-space-4);
}

.cofiel-auth .cofiel-auth__alert .alert {
  margin: 0;
  border-radius: var(--cofiel-radius);
}

.cofiel-auth .cofiel-auth__footer {
  margin-top: var(--cofiel-space-8);
  text-align: center;
}

.cofiel-auth .cofiel-auth__footer-lead {
  margin: 0 0 var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-base);
  line-height: 1.5;
  color: var(--cofiel-text-secondary);
}

.cofiel-auth .cofiel-auth__footer-contact {
  display: inline-flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-md);
  font-weight: 600;
  color: var(--cofiel-primary);
  text-decoration: none;
}

.cofiel-auth .cofiel-auth__footer-contact:hover {
  color: var(--cofiel-primary-hover);
  text-decoration: underline;
}

.cofiel-auth .cofiel-auth__footer-divider {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-3);
  max-width: 280px;
  margin: var(--cofiel-space-5) auto;
  color: var(--cofiel-text-muted);
  font-size: var(--cofiel-font-size-sm);
}

.cofiel-auth .cofiel-auth__footer-divider::before,
.cofiel-auth .cofiel-auth__footer-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--cofiel-border);
}

.cofiel-auth--register .cofiel-auth__page {
  max-width: 960px;
}

.cofiel-auth--register .cofiel-auth__register-layout {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cofiel-space-6);
  align-items: stretch;
  justify-content: center;
}

.cofiel-auth--register .cofiel-auth__info {
  flex: 1 1 300px;
  max-width: 380px;
  padding: var(--cofiel-space-6);
  background: var(--cofiel-bg-card);
  border: none;
  border-radius: 16px;
  box-shadow: 0 8px 32px rgba(43, 89, 195, 0.1);
}

.cofiel-auth--register .cofiel-auth__info-title {
  margin: 0 0 var(--cofiel-space-5);
  font-size: 1.125rem;
  font-weight: 600;
  color: #1E293B;
}

.cofiel-auth--register .cofiel-auth__info-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.cofiel-auth--register .cofiel-auth__info-list li {
  position: relative;
  padding-left: 1.5rem;
  margin-bottom: var(--cofiel-space-4);
  font-size: var(--cofiel-font-size-base);
  line-height: 1.5;
  color: var(--cofiel-text-secondary);
}

.cofiel-auth--register .cofiel-auth__info-list li:last-child {
  margin-bottom: 0;
}

.cofiel-auth--register .cofiel-auth__info-list li::before {
  content: '\f00c';
  font-family: FontAwesome;
  position: absolute;
  left: 0;
  top: 0.15em;
  color: var(--cofiel-primary);
  font-size: 0.875rem;
}

.cofiel-auth--register .cofiel-auth__card {
  flex: 1 1 400px;
  max-width: 440px;
  margin: 0;
}

.cofiel-auth-terms {
  margin: var(--cofiel-space-2) 0 var(--cofiel-space-4);
  font-size: var(--cofiel-font-size-sm);
  line-height: 1.5;
  color: var(--cofiel-text-secondary);
}

.cofiel-auth-terms p {
  margin: 0 0 var(--cofiel-space-2);
}

.cofiel-auth-terms a {
  color: var(--cofiel-primary);
  text-decoration: none;
}

.cofiel-auth-terms a:hover {
  text-decoration: underline;
}

.cofiel-auth-terms input[type="checkbox"] {
  margin-right: var(--cofiel-space-2);
  vertical-align: middle;
}

.cofiel-auth-terms p.has-error {
  color: var(--cofiel-danger);
}

.cofiel-auth__form .form-control {
  min-height: 44px;
}

.cofiel-auth__form .btn-block {
  min-height: 44px;
}

.cofiel-auth__footer {
  margin-top: var(--cofiel-space-6);
  text-align: center;
  color: var(--cofiel-text-secondary);
}

.cofiel-auth__footer label {
  font-weight: 500;
}

.cofiel-v2 .catalogo-detalle .content,
.cofiel-v2 .detalle-emision .content {
  margin-left: 0 !important;
  margin-right: 0 !important;
  overflow: visible !important;
}

.cofiel-v2 .catalogo-detalle .header-toolbar .left h3 {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 500;
}

/* fe_detalle — comprobante timbrado */
.cofiel-v2 section.catalogo-detalle .content .body-form.cofiel-detalle-body,
.cofiel-v2 .detalle-emision .body-form.cofiel-detalle-body,
.cofiel-v2 .catalogo-detalle .body-form.cofiel-detalle-body {
  box-sizing: border-box !important;
  position: relative !important;
  top: auto !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  float: none !important;
  width: 100% !important;
  max-width: 100%;
  margin: 0 !important;
  padding: var(--cofiel-space-6) !important;
  overflow: visible !important;
}

.cofiel-v2 .cofiel-detalle-body > * {
  max-width: 100%;
  min-width: 0;
}

.cofiel-v2 .cofiel-detalle-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cofiel-space-2);
}

.cofiel-v2 .cofiel-detalle-actions .btn {
  display: inline-flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  min-height: 40px;
  padding: var(--cofiel-space-2) var(--cofiel-space-4);
  white-space: nowrap;
  box-shadow: var(--cofiel-shadow-xs);
}

.cofiel-v2 .cofiel-detalle-actions .btn-default {
  background: var(--cofiel-bg-card);
  border-color: var(--cofiel-border);
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .cofiel-detalle-actions .btn-default:hover,
.cofiel-v2 .cofiel-detalle-actions .btn-default:focus-visible {
  background: var(--cofiel-bg-hover);
  border-color: var(--cofiel-primary);
  color: var(--cofiel-primary);
}

.cofiel-v2 .cofiel-detalle-actions .btn-success,
.cofiel-v2 .cofiel-detalle-actions .btn-primary:has(.fa-plus) {
  box-shadow: 0 2px 8px rgba(22, 163, 74, 0.28);
}

.cofiel-v2 .cofiel-detalle-receipt {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  grid-template-areas: "main details total";
  align-items: stretch;
  gap: var(--cofiel-space-3);
  margin-bottom: var(--cofiel-space-5);
  padding: var(--cofiel-space-3);
  background: linear-gradient(135deg, var(--cofiel-success-bg) 0%, var(--cofiel-primary-light) 55%, #fff 100%);
  border: 1px solid var(--cofiel-primary-muted);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-sm);
  position: relative;
  z-index: 10;
  overflow: visible;
}

.cofiel-v2 .cofiel-detalle-receipt__main {
  grid-area: main;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  justify-content: flex-start;
  gap: var(--cofiel-space-2);
  min-width: 0;
  height: 100%;
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
  box-sizing: border-box;
}

.cofiel-v2 .cofiel-detalle-receipt__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cofiel-space-2);
  flex: 0 0 auto;
  align-self: stretch;
  min-height: 0;
  padding: var(--cofiel-space-1) var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-xs);
  font-weight: 600;
  color: var(--cofiel-success);
  background: var(--cofiel-bg-card);
  border: 1px solid rgba(22, 163, 74, 0.25);
  border-radius: var(--cofiel-radius);
  box-shadow: var(--cofiel-shadow-xs);
  white-space: nowrap;
}

.cofiel-v2 .cofiel-detalle-receipt__badge .fa {
  font-size: 1.1em;
}

.cofiel-v2 .cofiel-detalle-receipt__ids {
  display: flex;
  flex: 0 1 auto;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: var(--cofiel-space-2);
  min-width: 0;
}

.cofiel-v2 .cofiel-detalle-pill {
  display: inline-flex;
  flex: 0 1 auto;
  align-items: center;
  justify-content: center;
  gap: var(--cofiel-space-1);
  align-self: stretch;
  min-height: 0;
  min-width: 0;
  padding: var(--cofiel-space-1) var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-xs);
  color: var(--cofiel-text-secondary);
  background: var(--cofiel-bg-hover);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius);
  box-shadow: none;
  white-space: nowrap;
}

.cofiel-v2 .cofiel-detalle-pill strong {
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text);
  font-weight: 700;
}

.cofiel-v2 .cofiel-detalle-receipt__total {
  grid-area: total;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  align-self: stretch;
  flex-shrink: 0;
  height: 100%;
  min-width: 148px;
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  text-align: right;
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
  box-sizing: border-box;
}

.cofiel-v2 .cofiel-detalle-receipt__total-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--cofiel-text-muted);
  line-height: 1.2;
}

.cofiel-v2 .cofiel-detalle-receipt__total-amount-row {
  display: flex;
  align-items: baseline;
  justify-content: flex-end;
  gap: var(--cofiel-space-2);
  flex-wrap: nowrap;
  margin-top: 2px;
}

.cofiel-v2 .cofiel-detalle-receipt__total-amount {
  margin-top: 0;
  font-size: var(--cofiel-font-size-xl);
  font-weight: 700;
  line-height: 1.1;
  color: var(--cofiel-primary);
  white-space: nowrap;
}

.cofiel-v2 .cofiel-detalle-receipt__total-currency {
  margin-top: 0;
  font-size: var(--cofiel-font-size-xs);
  font-weight: 600;
  color: var(--cofiel-text-muted);
  white-space: nowrap;
}

.cofiel-v2 .cofiel-detalle-receipt__total > .cofiel-detalle-receipt__total-amount {
  margin-top: var(--cofiel-space-1);
}

.cofiel-v2 .cofiel-detalle-receipt__total > .cofiel-detalle-receipt__total-currency {
  margin-top: var(--cofiel-space-1);
}

.cofiel-v2 .cofiel-detalle-receipt__details {
  grid-area: details;
  display: flex;
  flex-direction: column;
  justify-content: stretch;
  gap: 0;
  min-width: 0;
  align-self: stretch;
  height: 100%;
}

.cofiel-v2 .cofiel-detalle-receipt__details > .cofiel-detalle-receipt__detail {
  flex: 1 1 auto;
  height: 100%;
}

.cofiel-v2 .cofiel-detalle-receipt__detail {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  gap: var(--cofiel-space-2);
  min-width: 0;
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
}

.cofiel-v2 .cofiel-detalle-receipt__detail-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-primary);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-primary-muted);
  border-radius: var(--cofiel-radius);
}

.cofiel-v2 .cofiel-detalle-receipt__detail-content {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.cofiel-v2 .cofiel-detalle-receipt__detail-label {
  font-size: var(--cofiel-font-size-xs);
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-detalle-receipt__detail-value {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  line-height: 1.4;
  color: var(--cofiel-text);
  word-break: break-word;
}

.cofiel-v2 .cofiel-detalle-receipt__detail-value-row {
  display: inline-flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  max-width: 100%;
}

.cofiel-v2 .cofiel-detalle-receipt__detail--uuid .cofiel-detalle-receipt__detail-value-row {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}

.cofiel-v2 .cofiel-detalle-receipt__detail--uuid .cofiel-detalle-receipt__detail-value {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: var(--cofiel-font-size-xs);
  word-break: normal;
  overflow-wrap: normal;
  white-space: nowrap;
  flex: 1 1 auto;
  min-width: 0;
}

.cofiel-v2 .cofiel-detalle-receipt__detail--with-email.cofiel-detalle-receipt__detail {
  display: grid;
  grid-template-columns: repeat(2, minmax(200px, 1fr));
  align-items: stretch;
  gap: 0;
  padding: 0;
  min-width: 0;
  height: 100%;
  min-height: 0;
}

.cofiel-v2 .cofiel-detalle-receipt__uuid-panel,
.cofiel-v2 .cofiel-detalle-receipt__email-panel {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  min-width: 0;
  height: 100%;
  min-height: 0;
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  box-sizing: border-box;
}

.cofiel-v2 .cofiel-detalle-receipt__email-panel {
  position: relative;
  z-index: 2;
  border-left: 1px solid var(--cofiel-border-light);
  overflow: visible;
}

.cofiel-v2 .cofiel-detalle-email-send--inline {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.cofiel-v2 .cofiel-detalle-email-send--inline > .cofiel-detalle-receipt__detail-content {
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
}

.cofiel-v2 .cofiel-detalle-email-send__controls {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: var(--cofiel-space-2);
  margin-top: 2px;
  width: 100%;
}

.cofiel-v2 .cofiel-detalle-email-send--inline .cofiel-detalle-email-send__field {
  flex: 1 1 auto;
  width: auto;
  min-width: 0;
}

.cofiel-v2 .cofiel-detalle-email-send--inline .cofiel-detalle-email-send__field .chosen-container-multi .chosen-choices {
  min-height: 34px;
  padding: 2px 6px;
}

.cofiel-v2 .cofiel-detalle-email-send--inline .cofiel-detalle-email-send__field .chosen-container-multi .chosen-choices li.search-field input[type="text"] {
  height: 28px;
  min-height: 28px;
}

.cofiel-v2 .cofiel-detalle-email-send--inline .cofiel-detalle-email-send__action {
  flex: 0 0 auto;
}

.cofiel-v2 .cofiel-detalle-email-send--inline .cofiel-detalle-email-send__action .btn {
  width: auto;
  min-width: 84px;
  min-height: 34px;
  padding: 0 var(--cofiel-space-2);
  justify-content: center;
}

.cofiel-v2 .cofiel-detalle-copy-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  padding: 0;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text-secondary);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border);
  border-radius: var(--cofiel-radius);
  cursor: pointer;
  transition: background-color var(--cofiel-transition), border-color var(--cofiel-transition), color var(--cofiel-transition);
}

.cofiel-v2 .cofiel-detalle-copy-btn:hover,
.cofiel-v2 .cofiel-detalle-copy-btn:focus-visible {
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  border-color: var(--cofiel-primary-muted);
  outline: none;
}

.cofiel-v2 .cofiel-detalle-copy-btn.is-copied {
  color: var(--cofiel-success);
  background: var(--cofiel-success-bg);
  border-color: rgba(22, 163, 74, 0.35);
}

.cofiel-v2 .cofiel-detalle-sections {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--cofiel-space-4);
  margin-top: var(--cofiel-space-2);
}

.cofiel-v2 .cofiel-detalle-body > .cofiel-detalle-section {
  margin-bottom: var(--cofiel-space-6);
}

.cofiel-v2 .cofiel-detalle-section:has(.cofiel-detalle-email-send) {
  position: relative;
  z-index: 20;
  overflow: visible;
}

.cofiel-v2 .cofiel-detalle-section:has(.cofiel-detalle-email-send) .cofiel-detalle-section__body {
  overflow: visible;
  padding-bottom: var(--cofiel-space-2);
}

.cofiel-v2 .cofiel-detalle-section {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-xs);
  overflow: hidden;
}

.cofiel-v2 .cofiel-detalle-section--full {
  grid-column: 1 / -1;
}

.cofiel-v2 .cofiel-detalle-section__head {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-3);
  padding: var(--cofiel-space-3) var(--cofiel-space-4);
  background: var(--cofiel-bg-hover);
  border-bottom: 1px solid var(--cofiel-border-light);
}

.cofiel-v2 .cofiel-detalle-section__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  border-radius: var(--cofiel-radius);
}

.cofiel-v2 .cofiel-detalle-section__title {
  margin: 0;
  font-size: var(--cofiel-font-size-base);
  font-weight: 600;
  color: var(--cofiel-text);
}

.cofiel-v2 .cofiel-detalle-section__body {
  padding: var(--cofiel-space-4);
}

.cofiel-v2 .cofiel-detalle-fields {
  display: grid;
  gap: var(--cofiel-space-3) var(--cofiel-space-4);
}

.cofiel-v2 .cofiel-detalle-fields--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cofiel-v2 .cofiel-detalle-fields--3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cofiel-v2 .cofiel-detalle-field {
  display: flex;
  flex-direction: column;
  gap: var(--cofiel-space-2);
  min-width: 0;
}

.cofiel-v2 .cofiel-detalle-field--wide {
  grid-column: 1 / -1;
}

.cofiel-v2 .cofiel-detalle-field__label {
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .cofiel-detalle-field__value {
  min-height: 40px;
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  line-height: 1.45;
  color: var(--cofiel-text);
  word-break: break-word;
  background: var(--cofiel-bg-hover);
  border: 1px solid var(--cofiel-border);
  border-radius: var(--cofiel-radius);
}

.cofiel-v2 .cofiel-detalle-field--mono .cofiel-detalle-field__value {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: var(--cofiel-font-size-xs);
}

.cofiel-v2 .cofiel-detalle-field--accent .cofiel-detalle-field__value {
  font-size: var(--cofiel-font-size-md);
  font-weight: 700;
  color: var(--cofiel-primary);
  background: var(--cofiel-primary-light);
  border-color: var(--cofiel-primary-muted);
}

.cofiel-v2 .cofiel-detalle-tech {
  margin-top: var(--cofiel-space-4);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  background: var(--cofiel-bg-card);
  box-shadow: var(--cofiel-shadow-xs);
  overflow: hidden;
}

.cofiel-v2 .cofiel-detalle-tech > summary {
  display: flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  padding: var(--cofiel-space-3) var(--cofiel-space-4);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text);
  cursor: pointer;
  list-style: none;
  background: var(--cofiel-bg-hover);
  transition: background-color var(--cofiel-transition);
}

.cofiel-v2 .cofiel-detalle-tech > summary:hover {
  background: var(--cofiel-bg-active);
}

.cofiel-v2 .cofiel-detalle-tech > summary::-webkit-details-marker {
  display: none;
}

.cofiel-v2 .cofiel-detalle-tech > summary .fa-lock {
  color: var(--cofiel-text-muted);
}

.cofiel-v2 .cofiel-detalle-tech > summary::after {
  content: '\f107';
  margin-left: auto;
  font-family: FontAwesome;
  font-size: var(--cofiel-font-size-md);
  color: var(--cofiel-text-muted);
  transition: transform var(--cofiel-transition);
}

.cofiel-v2 .cofiel-detalle-tech[open] > summary::after {
  transform: rotate(180deg);
}

.cofiel-v2 .cofiel-detalle-tech__body {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--cofiel-space-4);
  padding: var(--cofiel-space-4);
  border-top: 1px solid var(--cofiel-border-light);
  background: var(--cofiel-bg-page);
}

.cofiel-v2 .cofiel-detalle-tech__field label {
  display: block;
  margin-bottom: var(--cofiel-space-2);
  font-size: var(--cofiel-font-size-sm);
  font-weight: 500;
  color: var(--cofiel-text-secondary);
}

.cofiel-v2 .cofiel-detalle-tech__field textarea {
  min-height: 72px;
  max-height: 140px;
  padding: var(--cofiel-space-2) var(--cofiel-space-3);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 11px;
  line-height: 1.45;
  resize: vertical;
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border);
  border-radius: var(--cofiel-radius);
}

.cofiel-v2 .cofiel-detalle-email-send {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--cofiel-space-3);
  position: relative;
  z-index: 1;
}

.cofiel-v2 .cofiel-detalle-email-send__field {
  flex: 1 1 280px;
  min-width: 0;
  position: relative;
  z-index: 2;
}

.cofiel-v2 .cofiel-detalle-email-send__field .chosen-container {
  width: 100% !important;
  position: relative;
  z-index: 2;
}

.cofiel-v2 .cofiel-detalle-email-send__field .chosen-container .chosen-drop {
  z-index: 1200;
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-md);
}

.cofiel-v2 .cofiel-detalle-email-send__field .chosen-container.chosen-with-drop {
  z-index: 1200;
}

.cofiel-v2 .cofiel-detalle-email-send__action .btn {
  display: inline-flex;
  align-items: center;
  gap: var(--cofiel-space-2);
  min-height: 40px;
  white-space: nowrap;
}

.cofiel-v2 .cofiel-detalle-pagos-table-wrap {
  overflow-x: auto;
}

.cofiel-v2 .cofiel-detalle-pagos-table {
  margin: 0;
  font-size: var(--cofiel-font-size-sm);
}

.cofiel-v2 .cofiel-detalle-pagos-table thead th {
  background: var(--cofiel-bg-hover);
  border-bottom: 1px solid var(--cofiel-border-light);
  font-size: var(--cofiel-font-size-xs);
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--cofiel-text-muted);
  white-space: nowrap;
}

.cofiel-v2 .cofiel-detalle-pagos-table tbody td {
  vertical-align: middle;
}

.cofiel-v2 .cofiel-detalle-pagos-table a {
  color: var(--cofiel-primary);
  font-weight: 500;
  text-decoration: none;
}

.cofiel-v2 .cofiel-detalle-pagos-table a:hover {
  text-decoration: underline;
}

.cofiel-v2 .catalogo-comprobantes.catalogo-detalle .content {
  margin-left: 0 !important;
}

@media (max-width: 1199px) {
  .cofiel-v2 .cofiel-detalle-receipt {
    grid-template-columns: minmax(160px, 1fr) auto;
    grid-template-areas:
      "main total"
      "details details";
  }

  .cofiel-v2 .cofiel-detalle-receipt__detail--with-email.cofiel-detalle-receipt__detail {
    grid-template-columns: repeat(2, minmax(240px, 1fr));
  }
}

@media (max-width: 991px) {
  .cofiel-v2 .cofiel-detalle-receipt {
    grid-template-columns: 1fr;
    grid-template-areas:
      "main"
      "details"
      "total";
  }

  .cofiel-v2 .cofiel-detalle-receipt__main {
    flex-wrap: wrap;
  }

  .cofiel-v2 .cofiel-detalle-receipt__total {
    align-items: flex-start;
    align-self: stretch;
    width: 100%;
    text-align: left;
  }

  .cofiel-v2 .cofiel-detalle-receipt__total-amount-row {
    justify-content: flex-start;
  }

  .cofiel-v2 .cofiel-detalle-receipt__detail--with-email.cofiel-detalle-receipt__detail {
    grid-template-columns: 1fr;
  }

  .cofiel-v2 .cofiel-detalle-receipt__email-panel {
    border-left: none;
    border-top: 1px solid var(--cofiel-border-light);
  }

  .cofiel-v2 .cofiel-detalle-receipt__main,
  .cofiel-v2 .cofiel-detalle-receipt__details,
  .cofiel-v2 .cofiel-detalle-receipt__total {
    width: 100%;
    min-height: 0;
  }

  .cofiel-v2 .cofiel-detalle-sections,
  .cofiel-v2 .cofiel-detalle-fields--2,
  .cofiel-v2 .cofiel-detalle-fields--3,
  .cofiel-v2 .cofiel-detalle-tech__body {
    grid-template-columns: 1fr;
  }

  .cofiel-v2 .cofiel-page-header__actions {
    width: 100%;
  }

  .cofiel-v2 .cofiel-detalle-actions {
    width: 100%;
  }

  .cofiel-v2 .cofiel-detalle-actions .btn {
    flex: 1 1 calc(50% - var(--cofiel-space-2));
    justify-content: center;
    min-width: 0;
  }
}

/* CP8 — responsive QA */
@media (max-width: 1024px) {
  /* Neutralize legacy default.css sidebar squeeze (100px + margin-left) */
  .cofiel-v2 section .sidebar_left:not(.no-display) li {
    height: auto !important;
    overflow: visible !important;
  }

  .cofiel-v2 section .sidebar_left:not(.no-display) li:hover {
    width: auto !important;
  }

  .cofiel-v2 section .content {
    margin-left: 0 !important;
  }

  .cofiel-v2 section.catalogo-generico:has(.sidebar_left:not(.no-display)) {
    flex-direction: column;
  }

  .cofiel-v2 section .sidebar_left:not(.no-display) {
    position: relative !important;
    flex: 0 0 auto;
    width: 100% !important;
    height: auto !important;
    border-radius: var(--cofiel-radius-lg) var(--cofiel-radius-lg) 0 0;
  }

  .cofiel-v2 section .sidebar_left:not(.no-display) + .content {
    border-radius: 0 0 var(--cofiel-radius-lg) var(--cofiel-radius-lg);
    border-top: none;
  }

  .cofiel-v2 section .sidebar_left:not(.no-display) ul.menu-options {
    position: relative;
    top: auto;
    bottom: auto;
    display: flex;
    flex-direction: row;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-bottom: 1px solid var(--cofiel-border-light);
  }

  .cofiel-v2 section .sidebar_left:not(.no-display) ul.menu-options li {
    flex: 0 0 auto;
    min-width: 220px;
    border-right: 1px solid var(--cofiel-border-light) !important;
  }

  .cofiel-v2 section .sidebar_left:not(.no-display) ul.menu-options li span {
    display: block;
    white-space: normal;
  }

  .cofiel-v2 section.catalogo-generico:not(.catalogo-emision):not(.catalogo-detalle) {
    min-height: 0;
  }
}

.cofiel-v2 .cofiel-list-toolbar.pull-left {
  float: none !important;
  width: 100%;
}

.cofiel-v2 .cofiel-list-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--cofiel-space-3);
}

body.cofiel-v2.cofiel-sidebar-open .cofiel-layout::before {
  content: '';
  position: fixed;
  top: var(--cofiel-topbar-height);
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1025;
  background: rgba(17, 24, 39, 0.45);
}

@media (max-width: 991px) {
  .cofiel-v2 .cofiel-main,
  .cofiel-v2 .cofiel-main__inner,
  .cofiel-v2 section.catalogo-generico,
  .cofiel-v2 section .content {
    max-width: 100%;
    min-width: 0;
  }

  .cofiel-v2 .cofiel-main {
    overflow-x: clip;
  }

  .cofiel-v2 .dataTables_wrapper,
  .cofiel-v2 .cofiel-list-body table.dataTable {
    max-width: 100%;
  }

  .cofiel-v2 .dataTables_wrapper .dataTables_scroll,
  .cofiel-v2 .cofiel-list-body:has(table.dataTable) {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .cofiel-v2 .catalogo-emision .cofiel-products-table-wrap,
  .cofiel-v2 .catalogo-emision #tablaProductos {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .cofiel-v2 .catalogo-emision .datosConceptos .input-group[style*="margin-top"] {
    grid-template-columns: 1fr;
  }

  .cofiel-v2 section .content .header-toolbar {
    flex-wrap: wrap;
    gap: var(--cofiel-space-2);
  }

  .cofiel-v2 section .content .header-toolbar .right {
    flex-wrap: wrap;
  }
}

@media (max-width: 767px) {
  .cofiel-v2 section.catalogo-generico {
    min-height: 0;
  }

  .cofiel-v2 .cofiel-page-header {
    margin-bottom: var(--cofiel-space-4);
    flex-direction: column;
    align-items: stretch;
  }

  .cofiel-v2 .cofiel-page-header__actions {
    width: 100%;
  }

  .cofiel-v2 .cofiel-page-header__actions .btn {
    flex: 1 1 auto;
    min-width: 0;
  }

  .cofiel-v2 .cofiel-list-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .cofiel-v2 .cofiel-list-toolbar .input-group {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
  }

  .cofiel-v2 .cofiel-list-toolbar .bootstrap-select,
  .cofiel-v2 .cofiel-list-toolbar .bootstrap-select > .dropdown-toggle {
    width: 100% !important;
    min-width: 0 !important;
  }

  .cofiel-v2 .cofiel-list-toolbar .pagination {
    width: 100%;
    margin-left: 0;
    justify-content: space-between;
  }

  .cofiel-v2 section .content .header-toolbar .left,
  .cofiel-v2 section .content .header-toolbar .right {
    width: 100%;
    margin-left: 0 !important;
  }

  .cofiel-v2 section .content .header-toolbar .right {
    justify-content: flex-start;
  }

  .cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) {
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
  }

  .cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left {
    flex: 1 1 auto;
    width: 100%;
    grid-template-columns: 1fr;
  }

  .cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .left .row {
    grid-template-columns: 1fr;
  }

  .cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones.visibility-hidden {
    visibility: visible !important;
  }

  .cofiel-v2 .form-horizontal [class*="col-sm-"],
  .cofiel-v2 .form-horizontal [class*="col-md-"],
  .cofiel-v2 .catalogo-detalle [class*="col-sm-"],
  .cofiel-v2 .catalogo-detalle [class*="col-md-"] {
    width: 100% !important;
    float: none !important;
  }

  .cofiel-v2 .catalogo-detalle .header-toolbar .right .btn {
    flex: 1 1 calc(50% - var(--cofiel-space-1));
    min-width: 0;
    white-space: normal;
  }

  .cofiel-v2 .catalogo-detalle .w47mr3,
  .cofiel-v2 .catalogo-detalle .w97 {
    width: 100% !important;
    margin-right: 0 !important;
  }

  .cofiel-v2 .cofiel-panel-card > .cofiel-card__header,
  .cofiel-v2 .cofiel-panel-card .panel-body,
  .cofiel-v2 section .content .header-toolbar,
  .cofiel-v2 section .content .body-form:not(.cofiel-detalle-body):not(.cofiel-tienda-body) {
    padding-left: var(--cofiel-space-4) !important;
    padding-right: var(--cofiel-space-4) !important;
  }

  .cofiel-v2 section.catalogo-detalle .content .body-form.cofiel-detalle-body,
  .cofiel-v2 .detalle-emision .body-form.cofiel-detalle-body,
  .cofiel-v2 .catalogo-detalle .body-form.cofiel-detalle-body,
  .cofiel-v2 section.catalogo-tienda .content .body-form.cofiel-tienda-body,
  .cofiel-v2 section.catalogo-tienda #opcionListado .body-form.cofiel-tienda-body {
    padding: var(--cofiel-space-4) !important;
  }

  .cofiel-auth__page {
    padding: var(--cofiel-space-4) var(--cofiel-space-3) var(--cofiel-space-6);
  }

  .cofiel-auth__title {
    font-size: var(--cofiel-font-size-xl);
  }

  .cofiel-auth__card {
    padding: var(--cofiel-space-5);
  }

  .cofiel-auth--login .cofiel-auth__card,
  .cofiel-auth--register .cofiel-auth__card {
    padding: var(--cofiel-space-6) var(--cofiel-space-5);
  }

  .cofiel-auth--login .cofiel-auth__title,
  .cofiel-auth--register .cofiel-auth__title {
    font-size: 1.5rem;
  }

  .cofiel-auth--register .cofiel-auth__card {
    max-width: 400px;
    margin: 0 auto;
    flex-basis: 100%;
  }

  .cofiel-v2 .cofiel-emision-actions {
    justify-content: stretch;
    gap: var(--cofiel-space-2);
  }

  .cofiel-v2 .cofiel-emision-actions .btn {
    flex: 1 1 calc(50% - var(--cofiel-space-1));
    min-width: 0;
    white-space: normal;
    text-align: center;
  }

  .cofiel-v2 section .content .header-toolbar .right .btn,
  .cofiel-v2 section .content .header-toolbar .left .btn {
    min-width: 0;
    white-space: normal;
  }

  .cofiel-v2 section .content img {
    max-width: 100%;
    height: auto;
  }

  body.cofiel-v2 .ui-dialog {
    max-width: calc(100vw - var(--cofiel-space-4) * 2) !important;
    width: auto !important;
    left: var(--cofiel-space-4) !important;
    right: var(--cofiel-space-4);
    box-sizing: border-box;
  }

  body.cofiel-v2 .ui-dialog .ui-dialog-content {
    max-width: 100%;
    overflow-x: auto;
  }

  .cofiel-v2 .nomina_step {
    display: flex;
    align-items: center;
    gap: var(--cofiel-space-2);
    height: auto;
    min-height: 52px;
    padding: var(--cofiel-space-2) var(--cofiel-space-3);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .cofiel-v2 .nomina_step li {
    flex: 0 0 auto;
    margin-left: 0;
    font-size: var(--cofiel-font-size-sm);
    white-space: nowrap;
  }

  .cofiel-v2 .nomina_step .nextStep {
    float: none;
    margin-top: 0;
    padding: var(--cofiel-space-2) var(--cofiel-space-3);
    font-size: var(--cofiel-font-size-xs);
  }
}

@media (max-width: 767px), (hover: none) and (pointer: coarse) {
  .cofiel-v2 .cofiel-list-body .item-serie:not(.item-comprobante) .opciones.visibility-hidden {
    visibility: visible !important;
  }
}

/* bootstrap-datetimepicker — v2 skin (picker renders on body) */
body.cofiel-v2 .datetimepicker {
  padding: var(--cofiel-space-3);
  margin-top: var(--cofiel-space-2);
  background: var(--cofiel-bg-card);
  border: 1px solid var(--cofiel-border-light);
  border-radius: var(--cofiel-radius-lg);
  box-shadow: var(--cofiel-shadow-md);
}

body.cofiel-v2 .datetimepicker table {
  margin: 0;
  border-collapse: separate;
  border-spacing: 2px;
}

body.cofiel-v2 .datetimepicker thead th {
  text-transform: none;
  letter-spacing: normal;
  font-size: var(--cofiel-font-size-sm);
  font-weight: 600;
  color: var(--cofiel-text);
  border: none;
  padding: var(--cofiel-space-2);
  vertical-align: middle;
}

body.cofiel-v2 .datetimepicker th.switch {
  width: auto;
  min-width: 140px;
  border-radius: var(--cofiel-radius);
  background: var(--cofiel-bg-hover);
  color: var(--cofiel-text);
}

body.cofiel-v2 .datetimepicker th.prev,
body.cofiel-v2 .datetimepicker th.next {
  width: 36px;
  min-width: 36px;
  border-radius: var(--cofiel-radius-sm);
  text-align: center;
}

/* Glyphicons are not bundled in BS5 — use Font Awesome chevrons */
body.cofiel-v2 .datetimepicker th.prev i,
body.cofiel-v2 .datetimepicker th.next i {
  display: none !important;
}

body.cofiel-v2 .datetimepicker th.prev::before,
body.cofiel-v2 .datetimepicker th.next::before {
  display: inline-block;
  font-family: FontAwesome;
  font-style: normal;
  font-weight: normal;
  font-size: 14px;
  line-height: 1;
  color: var(--cofiel-text-secondary);
  -webkit-font-smoothing: antialiased;
}

body.cofiel-v2 .datetimepicker th.prev::before {
  content: '\f053';
}

body.cofiel-v2 .datetimepicker th.next::before {
  content: '\f054';
}

body.cofiel-v2 .datetimepicker thead tr:first-child th:hover,
body.cofiel-v2 .datetimepicker tfoot tr:first-child th:hover {
  background: var(--cofiel-bg-active);
}

body.cofiel-v2 .datetimepicker thead tr:first-child th.prev:hover::before,
body.cofiel-v2 .datetimepicker thead tr:first-child th.next:hover::before {
  color: var(--cofiel-primary);
}

body.cofiel-v2 .datetimepicker table tr td,
body.cofiel-v2 .datetimepicker table tr th {
  border-radius: var(--cofiel-radius-sm);
  border: none;
}

body.cofiel-v2 .datetimepicker table tr td.day,
body.cofiel-v2 .datetimepicker table tr td.hour,
body.cofiel-v2 .datetimepicker table tr td.minute {
  width: 32px;
  height: 32px;
  line-height: 32px;
  padding: 0;
  font-size: var(--cofiel-font-size-sm);
  color: var(--cofiel-text);
}

body.cofiel-v2 .datetimepicker table tr td.day:hover,
body.cofiel-v2 .datetimepicker table tr td.hour:hover,
body.cofiel-v2 .datetimepicker table tr td.minute:hover {
  background: var(--cofiel-primary-light) !important;
  background-image: none !important;
  color: var(--cofiel-primary);
}

body.cofiel-v2 .datetimepicker table tr td.day.active,
body.cofiel-v2 .datetimepicker table tr td.hour.active,
body.cofiel-v2 .datetimepicker table tr td.minute.active,
body.cofiel-v2 .datetimepicker table tr td span.active {
  background: var(--cofiel-primary) !important;
  background-image: none !important;
  color: var(--cofiel-text-inverse) !important;
  text-shadow: none !important;
  border-radius: var(--cofiel-radius-sm);
}

body.cofiel-v2 .datetimepicker table tr td.old,
body.cofiel-v2 .datetimepicker table tr td.new,
body.cofiel-v2 .datetimepicker table tr td span.old {
  color: var(--cofiel-text-muted);
}

body.cofiel-v2 .datetimepicker table tr td.day.disabled,
body.cofiel-v2 .datetimepicker table tr td.day.disabled:hover {
  color: var(--cofiel-text-placeholder) !important;
  background: transparent !important;
  cursor: not-allowed;
}

body.cofiel-v2 .datetimepicker table tr td.day.today,
body.cofiel-v2 .datetimepicker table tr td.day.today:hover {
  background: var(--cofiel-primary-light) !important;
  background-image: none !important;
  color: var(--cofiel-primary);
}

body.cofiel-v2 .datetimepicker table tr td span {
  width: 23%;
  margin: 1%;
  line-height: 38px;
  border-radius: var(--cofiel-radius-sm);
}

body.cofiel-v2 .datetimepicker table tr td span:hover {
  background: var(--cofiel-primary-light);
}

body.cofiel-v2 [class*="datetimepicker-dropdown"]:before,
body.cofiel-v2 [class*="datetimepicker-dropdown"]:after {
  border-bottom-color: var(--cofiel-border-light);
}
