/* Bouton d'impression */
.print-button {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  padding: 0.75rem 1.5rem;
  background: var(--color-primary);
  color: white;
  border: none;
  border-radius: 0.75rem;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  transition: all 0.2s;
  z-index: 10;
}

.print-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 8px rgba(0, 0, 0, 0.15);
}

.print-button i {
  width: 1.25rem;
  height: 1.25rem;
}

/* Styles d'impression */
@media print {
  @page {
    size: A4;
    margin: 0.3cm;
  }

  /* Reset global */
  * {
    margin: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    background: none !important;
    border-radius: 0 !important;
    color: black !important;
  }

  /* Masquer les éléments inutiles */
  .page-header,
  .nav-tabs,
  .btn,
  .print-button,
  .no-print,
  .modal-close,
  .method-icon,
  .cashier-avatar,
  .stat-icon {
    display: none !important;
  }

  /* Styles de base */
  body {
    font-size: 7pt !important;
    line-height: 1.1 !important;
    font-family: Arial, sans-serif !important;
  }

  /* En-tête */
  .closing-header {
    border-bottom: 0.5px solid #000 !important;
    margin-bottom: 0.2cm !important;
    padding: 0.1cm 0 !important;
  }

  .closing-title h1 {
    font-size: 10pt !important;
    margin-bottom: 1pt !important;
  }

  .closing-date {
    font-size: 7pt !important;
  }

  /* Sections */
  .closing-section {
    margin-bottom: 0.2cm !important;
    border: 0.5px solid #000 !important;
    padding: 0.1cm !important;
  }

  /* Conteneur principal */
  .closing-container {
    width: 100% !important;
  }

  .closing-content {
    width: 100% !important;
  }

  /* Grilles */
  .payment-methods-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 0.1cm !important;
    page-break-inside: avoid !important;
  }

  /* Grille des caissiers - 5 colonnes */
  .cashiers-list {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 0.1cm !important;
    break-inside: auto !important;
  }

  /* Grille des statistiques - 5 colonnes */
  .stats-grid {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 0.1cm !important;
    page-break-inside: avoid !important;
    width: 100% !important;
  }

  /* Ajustement des cartes de statistiques */
  .stat-card {
    padding: 0.1cm !important;
    border: 0.5px solid #000 !important;
    break-inside: avoid !important;
    font-size: 6pt !important;
  }

  .stat-header {
    display: flex !important;
    gap: 0.05cm !important;
    margin-bottom: 0.05cm !important;
  }

  .stat-title {
    font-size: 6pt !important;
    font-weight: bold !important;
  }

  .stat-value {
    font-size: 7pt !important;
    font-weight: bold !important;
  }

  /* Cartes */
  .payment-method-card,
  .cashier-card {
    border: 0.5px solid #000 !important;
    padding: 0.1cm !important;
    break-inside: avoid !important;
  }

  /* En-têtes des cartes */
  .method-header,
  .cashier-header {
    display: flex !important;
    gap: 0.1cm !important;
    margin-bottom: 0.05cm !important;
    border-bottom: 0.5px solid #000 !important;
    padding-bottom: 0.1cm !important;
  }

  .method-name,
  .cashier-name {
    font-size: 7pt !important;
    font-weight: bold !important;
  }

  .method-amount {
    font-size: 7pt !important;
    font-weight: bold !important;
  }

  /* Retraits */
  .withdrawals-container {
    border-top: 0.5px dashed #000 !important;
    margin-top: 0.1cm !important;
    padding-top: 0.1cm !important;
  }

  .withdrawals-header {
    font-size: 7pt !important;
    margin-bottom: 0.05cm !important;
  }

  .withdrawals-header h3 {
    font-size: 7pt !important;
    font-weight: bold !important;
  }

  .withdrawals-header i {
    width: 6px !important;
    height: 6px !important;
  }

  .withdrawal-item {
    font-size: 7pt !important;
    padding: 0.05cm 0 !important;
    display: flex !important;
    justify-content: space-between !important;
  }

  .withdrawal-reason {
    font-size: 7pt !important;
  }

  .withdrawal-amount {
    font-size: 7pt !important;
  }

  /* Produits */
  .products-list {
    font-size: 6pt !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .product-row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 0.05cm 0 !important;
    border-bottom: 0.5px dotted #000 !important;
  }

  .product-row:last-child {
    border-bottom: none !important;
  }

  .product-row-info {
    display: flex !important;
    align-items: center !important;
    gap: 0.1cm !important;
    width: 100% !important;
  }

  .product-row-quantity {
    min-width: 0.6cm !important;
    text-align: right !important;
    font-size: 6pt !important;
  }

  .product-row-name {
    flex: 1 !important;
    font-size: 6pt !important;
    margin-right: 0.2cm !important;
  }

  .product-row-total {
    min-width: 1cm !important;
    text-align: right !important;
    font-size: 6pt !important;
  }

  /* Totaux et montants */
  .total-card {
    border: 0.5px solid #000 !important;
    font-weight: bold !important;
  }

  .final-amount {
    font-weight: bold !important;
    font-size: 7pt !important;
  }

  /* Optimiser l'espace vertical */
  .closing-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.2cm !important;
  }

  /* Optimisations supplémentaires */
  .method-info,
  .cashier-info,
  .stat-info {
    flex: 1 !important;
    min-width: 0 !important;
  }

  /* Supprimer les décorations */
  .closing-container,
  .closing-section,
  .payment-method-card,
  .cashier-card,
  .stat-card,
  .product-row {
    box-shadow: none !important;
    background: none !important;
  }

  /* Réduire les espacements */
  .closing-section + .closing-section {
    margin-top: 0.2cm !important;
  }

  .payment-method-card + .payment-method-card,
  .cashier-card + .cashier-card,
  .stat-card + .stat-card {
    margin-top: 0.1cm !important;
  }

  /* Optimiser les listes */
  .products-list,
  .withdrawals-list {
    margin: 0 !important;
    padding: 0 !important;
  }

  /* Ajustements pour les résumés des caissiers */
  .cashier-card {
    font-size: 6pt !important;
    height: auto !important;
  }

  /* Modification de l'en-tête du caissier */
  .cashier-card-header {
    border-bottom: 0.5px solid #000 !important;
    padding: 0.1cm !important;
    margin-bottom: 0.1cm !important;
  }

  .cashier-info {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100% !important;
  }

  .cashier-details {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100% !important;
  }

  .cashier-name {
    font-size: 8pt !important;
    font-weight: bold !important;
  }

  .cashier-stats {
    display: flex !important;
    justify-content: flex-end !important;
    font-size: 8pt !important;
    font-weight: bold !important;
  }

  .stat-item {
    display: flex !important;
    align-items: center !important;
    gap: 0.1cm !important;
  }

  .stat-item i {
    display: none !important;
  }

  /* Ajustements spécifiques pour les titres de retrait */
  .withdrawals-header,
  .withdrawals-header h3,
  .withdrawals-header i {
    font-size: 7pt !important;
  }

  /* Ajustements des icônes */
  [data-lucide="minus-circle"],
  [data-lucide="banknote"] {
    width: 6px !important;
    height: 6px !important;
  }

  /* Gestion des sauts de page */
  .closing-section {
    break-inside: avoid !important;
  }

  .cashiers-container {
    break-inside: auto !important;
  }

  .cashier-card {
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }

  /* Taille des résumés des caissiers */
  .cashier-card {
    font-size: 6pt !important;
  }

  .cashier-card-content {
    font-size: 6pt !important;
  }

  .cashier-card .product-row {
    font-size: 6pt !important;
  }

  .cashier-card .product-row-quantity,
  .cashier-card .product-row-name,
  .cashier-card .product-row-total {
    font-size: 6pt !important;
  }
}