.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    font-weight: 600 !important;
    border-radius: 2px;transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    white-space: nowrap;
    font-size: 0.9rem;
}

.btn-label {
    transition: opacity 0.2s ease;
}

@media (max-width: 575.98px) {
    .btn {
        padding: 0.4rem 0.8rem;
        font-size: 0.85rem;
        gap: 0 !important;
    }

    .btn-responsive {
        width: 38px !important;
        height: 38px !important;
        padding: 0 !important;
        border-radius: 2px !important;
    }

    .btn-responsive .btn-label,
    .btn-responsive span:not(.fas):not(.far):not(.bi):not(.badge) {
        display: none !important;
    }

    .btn-responsive i, .btn-responsive svg {
        margin: 0 !important;
        font-size: 1.1rem !important;
    }
}

.btn:active {
    transform: translateY(1px);
}

.btn-primary {
    background-color: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
    color: #ffffff !important;
}

.btn-primary:hover {
    background-color: color-mix(in srgb, var(--bs-primary), black 10%) !important;
    border-color: color-mix(in srgb, var(--bs-primary), black 10%) !important;
    color: #ffffff !important;
}

.btn-outline-primary {
    color: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
    background-color: transparent !important;
}

.btn-outline-primary:hover {
    background-color: var(--bs-primary) !important;
    color: #ffffff !important;
}

.btn-outline-danger {
    color: var(--bs-danger) !important;
    border-color: var(--bs-danger) !important;
}

.btn-outline-danger:hover {
    background-color: var(--bs-danger) !important;
    color: #ffffff !important;
}

/* Icon alignment in buttons */
.btn i, .btn svg {
    font-size: 1.1em;
}

/* ============================================================================
   TPGC MOBILE ENHANCEMENTS
   Generated from template analysis
   Templates analyzed: 437
   Unique classes: 456
   ============================================================================ */

/* Found 10 buttons with icons that need mobile handling */

/* --- Mobile: Buttons with icons --- */
@media (max-width: 768px) {

  /* All buttons in action areas - icon only */
  .action-col .btn {
    min-width: 36px !important;
    width: 36px !important;
    height: 36px !important;
    padding: 0.25rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* Hide text in action buttons, keep icons */
  .action-col .btn {
    overflow: hidden !important;
  }

  .action-col .btn i,
  .action-col .btn .bi,
  .action-col .btn [class*="fa-"] {
    margin: 0 !important;
    font-size: 1rem !important;
  }

  /* --- Mobile: Tables --- */
  .table-responsive {
    display: block !important;
    width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* Action column - sticky with solid background */
  .action-col {
    position: sticky !important;
    right: 0 !important;
    background: #ffffff !important;
    z-index: 10 !important;
    border-left: 1px solid #dee2e6 !important;
    min-width: 70px !important;
    max-width: 80px !important;
  }

  /* Table cells - single line */
  .table td,
  .table th {
    white-space: nowrap !important;
    font-size: 0.8125rem !important;
    padding: 0.5rem 0.75rem !important;
  }

  /* --- Mobile: Form Toolbar Buttons (icon-only) --- */
  /* Square buttons with proper spacing - remove gap, me-*, ms-* from icons */
  .border-bottom .action-btn-group .btn,
  .card-header .action-btn-group .btn,
  .summary-bar .action-btn-group .btn,
  .summary-bar-pms .summary-actions .btn {
    min-width: 36px !important;
    width: 36px !important;
    height: 36px !important;
    padding: 0.35rem 0.35rem !important;
    border-radius: 2px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* Remove gap from button containers */
  .border-bottom .action-btn-group,
  .card-header .action-btn-group,
  .summary-bar .action-btn-group,
  .summary-bar-pms .summary-actions {
    gap: 0.5rem !important;
  }

  /* Hide text by setting font-size to 0 */
  .border-bottom .action-btn-group .btn,
  .card-header .action-btn-group .btn,
  .summary-bar .action-btn-group .btn,
  .summary-bar-pms .summary-actions .btn {
    font-size: 0 !important;
  }

  /* Restore icon size and remove me-*, ms-* spacing */
  .border-bottom .action-btn-group .btn i,
  .border-bottom .action-btn-group .btn svg,
  .border-bottom .action-btn-group .btn .bi,
  .border-bottom .action-btn-group .btn [class*="fa-"],
  .border-bottom .action-btn-group .btn [class*="me-"],
  .border-bottom .action-btn-group .btn [class*="ms-"],
  .card-header .action-btn-group .btn i,
  .card-header .action-btn-group .btn svg,
  .card-header .action-btn-group .btn .bi,
  .card-header .action-btn-group .btn [class*="fa-"],
  .card-header .action-btn-group .btn [class*="me-"],
  .card-header .action-btn-group .btn [class*="ms-"],
  .summary-bar .action-btn-group .btn i,
  .summary-bar .action-btn-group .btn svg,
  .summary-bar .action-btn-group .btn .bi,
  .summary-bar .action-btn-group .btn [class*="fa-"],
  .summary-bar .action-btn-group .btn [class*="me-"],
  .summary-bar .action-btn-group .btn [class*="ms-"],
  .summary-bar-pms .summary-actions .btn i,
  .summary-bar-pms .summary-actions .btn svg,
  .summary-bar-pms .summary-actions .btn .bi,
  .summary-bar-pms .summary-actions .btn [class*="fa-"],
  .summary-bar-pms .summary-actions .btn [class*="me-"],
  .summary-bar-pms .summary-actions .btn [class*="ms-"] {
    font-size: 1rem !important;
    margin: 0 !important;
    margin-inline-end: 0 !important;
    margin-inline-start: 0 !important;
    padding: 0 !important;
  }


      /* List controls - compact and proper on mobile */
  .list-controls-grid {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 0.5rem !important;
    align-items: center !important;
    padding: 0.5rem !important;
  }

  .list-controls-grid .search-wrapper {
    flex: 1 !important;
    min-width: 0 !important;
  }

  .list-controls-grid form {
    margin-bottom: 0 !important;
  }

  .list-controls-grid .input-group {
    font-size: 0.85rem !important;
  }

  .list-controls-grid .input-group-text {
    padding: 0.4rem 0.6rem !important;
    font-size: 0.85rem !important;
    background: #fff !important;
    border-color: #dee2e6 !important;
  }

  .list-controls-grid .input-group-text i {
    margin: 0 !important;
    font-size: 0.9rem !important;
  }

  .list-controls-grid .form-control {
    font-size: 0.85rem !important;
    padding: 0.4rem 0.6rem !important;
    border-color: #dee2e6 !important;
  }

  .list-controls-grid .form-select {
    font-size: 0.85rem !important;
    padding: 0.4rem 0.6rem !important;
    border-color: #dee2e6 !important;
  }

  .list-controls-grid .btn {
    padding: 0.4rem 0.6rem !important;
    font-size: 0.8rem !important;
    border-radius: 2px !important;
  }

  .list-controls-grid .btn i {
    margin: 0 !important;
    font-size: 0.85rem !important;
  }

  .list-controls-grid .btn .btn-label {
    display: none !important;
  }

  .list-controls-grid .action-btn-group {
    display: flex !important;
    gap: 0.35rem !important;
    flex-shrink: 0 !important;
  }

  .list-controls-grid .search-wrapper {
    flex: 1 !important;
    min-width: 0 !important;
  }

  .list-controls-grid .search-wrapper .form-control {
    font-size: 0.85rem !important;
    padding: 0.35rem 0.5rem !important;
  }

  .list-controls-grid .search-wrapper .input-group-text {
    padding: 0.35rem 0.5rem !important;
    font-size: 0.85rem !important;
  }

  .list-controls-grid .action-btn-group {
    display: flex !important;
    gap: 0.35rem !important;
    flex-shrink: 0 !important;
  }

  .list-controls-grid .action-btn-group .btn {
    padding: 0.35rem 0.5rem !important;
    font-size: 0.8rem !important;
  }

  .list-controls-grid .action-btn-group .btn i {
    margin: 0 !important;
    font-size: 0.9rem !important;
  }

  .list-controls-grid .action-btn-group .btn .btn-label {
    display: none !important;
  }

  .list-controls-grid form {
    margin-bottom: 0 !important;
  }

  .list-controls-grid .search-wrapper {
    flex: 1 !important;
    min-width: 0 !important;
  }

  .list-controls-grid .action-btn-group {
    display: flex !important;
    gap: 0.5rem !important;
    flex-shrink: 0 !important;
  }

  .list-controls-grid form {
    margin-bottom: 0 !important;
  }

  /* Search + action bar - matches template pattern */
  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.75rem !important;
    padding: 0.75rem !important;
  }

  /* Search form wrapper - compact */
  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 .flex-grow-1 {
    flex: 1 1 auto !important;
    max-width: 100% !important;
    min-width: 200px !important;
  }

  /* Search form - compact */
  .p-3.border-bottom.d-flex.flex-wrap.just-content-between.align-items-center.gap-3 .flex-grow-1 form.d-flex {
    margin-bottom: 0 !important;
  }

  /* Search input */
  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 .form-control {
    font-size: 0.85rem !important;
    padding: 0.4rem 0.6rem !important;
    border-color: #dee2e6 !important;
    height: auto !important;
  }

  /* Search button - icon only style */
  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 .btn-primary {
    padding: 0.4rem 0.6rem !important;
    font-size: 0.8rem !important;
  }

  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 .btn-primary i {
    margin: 0 !important;
    font-size: 0.9rem !important;
  }

  /* Action buttons container */
  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 .d-flex.gap-2 {
    display: flex !important;
    gap: 0.5rem !important;
    flex-shrink: 0 !important;
  }

  /* Action buttons */
  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 .btn {
    padding: 0.4rem 0.6rem !important;
    font-size: 0.8rem !important;
  }

  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 .btn i {
    margin: 0 !important;
    font-size: 0.85rem !important;
  }

  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 .btn-outline-danger,
  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3 .btn-outline-secondary {
    padding: 0.35rem 0.5rem !important;
  }
}
  /* Mobile Search Bar - compact and clean */
  .mobile-search-bar,
  .p-3.border-bottom.d-flex.flex-wrap.justify-content-between.align-items-center.gap-3.bg-light-subtle {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.5rem !important;
    background: #f8f9fa !important;
  }

  /* Search form wrapper - full width */
  .mobile-search-bar .flex-grow-1,
  .mobile-search-bar form.d-flex {
    flex: 1 1 auto !important;
    min-width: 150px !important;
    max-width: 100% !important;
    margin-bottom: 0 !important;
  }

  /* Search input - compact */
  .mobile-search-bar .form-control,
  .mobile-search-bar input[type="text"],
  .mobile-search-bar input[type="search"] {
    font-size: 0.85rem !important;
    padding: 0.4rem 0.6rem !important;
    border-color: #dee2e6 !important;
    border-radius: 2px !important;
    height: auto !important;
  }

  /* Search button - icon only, square */
  .mobile-search-bar .btn-primary,
  .mobile-search-bar button[type="submit"] {
    padding: 0.4rem !important;
    border-radius: 2px !important;
    width: 32px !important;
    height: 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .mobile-search-bar .btn-primary i,
  .mobile-search-bar button[type="submit"] i {
    margin: 0 !important;
    font-size: 0.9rem !important;
  }

  /* Action buttons container */
  .mobile-search-bar .d-flex.gap-2,
  .mobile-search-bar .action-btn-group {
    display: flex !important;
    gap: 0.4rem !important;
    flex-shrink: 0 !important;
  }

  /* All action buttons - icon only, square, small */
  .mobile-search-bar .btn,
  .mobile-search-bar button {
    padding: 0.35rem 0.5rem !important;
    font-size: 0 !important;
    border-radius: 2px !important;
    width: 32px !important;
    height: 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .mobile-search-bar .btn i,
  .mobile-search-bar button i {
    margin: 0 !important;
    font-size: 0.85rem !important;
  }

  /* Restore text for non-mobile */
  @media (min-width: 769px) {
    .mobile-search-bar .btn {
      font-size: 0.875rem !important;
      width: auto !important;
      height: auto !important;
      padding: 0.4rem 0.75rem !important;
    }

    .mobile-search-bar .btn i {
      margin-right: 0.35rem !important;
    }

    .mobile-search-bar .btn .btn-text {
      display: inline !important;
    }
  }


/* ============================================================================
   END TPGC MOBILE ENHANCEMENTS
   ============================================================================ */
