/* ==========================================================================
   Bundled backend panel font
   ========================================================================== */
@font-face {
  font-family: 'PBSP Panel Font';
  src: url('../fonts/pbsp-panel-font.woff') format('woff');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --pbsp-panel-font: 'PBSP Panel Font', Tahoma, -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
}

/* ==========================================================================
   Design Tokens
   ========================================================================== */
:root {
  --primary: #2563eb;
  --primary-dark: #1d4ed8;
  --primary-light: #dbeafe;
  --secondary: #7c3aed;
  --success: #10b981;
  --warning: #f59e0b;
  --danger: #ef4444;
  --info: #3b82f6;

  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-400: #9ca3af;
  --gray-500: #6b7280;
  --gray-600: #4b5563;
  --gray-700: #374151;
  --gray-800: #1f2937;
  --gray-900: #111827;

  --radius-sm: 0.375rem;
  --radius: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;

  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);

  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition: 250ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 350ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* ==========================================================================
   Reset & Base
   ========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body.pbsp-fullscreen {
  overflow: hidden;
  background: var(--gray-50);
}

#pbsp-app {
  font-family: var(--pbsp-panel-font);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  height: 100vh;
  overflow: hidden;
  background: var(--gray-50);
}

/* ==========================================================================
   Layout
   ========================================================================== */
.pbsp-shell {
  display: flex;
  flex-direction: column;
  height: 100vh;
  background: linear-gradient(135deg, var(--gray-50) 0%, #ffffff 100%);
}

/* ==========================================================================
   Header
   ========================================================================== */
.pbsp-header {
  background: rgba(255, 255, 255, 0.95);
  border-bottom: 1px solid var(--gray-200);
  padding: 0.3rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: var(--shadow-sm);
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(8px);
}

.pbsp-header-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.pbsp-logo {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.25rem;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition);
}

.pbsp-logo:hover {
  transform: rotate(-5deg) scale(1.05);
}

.pbsp-title-container {
  display: flex;
  flex-direction: column;
}

.pbsp-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--gray-900);
  line-height: 1.2;
}

.pbsp-subtitle {
  font-size: 0.75rem;
  color: var(--gray-500);
  font-weight: 500;
  margin-top: 0.125rem;
}

.pbsp-header-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.pbsp-connection {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.75rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 500;
  transition: all var(--transition);
}

.pbsp-connection::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}

.pbsp-connection-online {
  background: var(--primary-light);
  color: var(--primary-dark);
}

.pbsp-connection-online::before {
  background: var(--success);
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.2);
  animation: pulse 2s infinite;
}

.pbsp-connection-offline {
  background: #fee2e2;
  color: #991b1b;
}

.pbsp-connection-offline::before {
  background: var(--danger);
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* ==========================================================================
   Navigation
   ========================================================================== */
.pbsp-nav {
  display: flex;
  gap: 0.25rem;
  padding: 0.2rem 0.5rem;
  background: #fff;
  border-bottom: 1px solid var(--gray-200);
  overflow-x: auto;
  scrollbar-width: none;
}

.pbsp-nav::-webkit-scrollbar {
  display: none;
}

.pbsp-nav-item {
  border: none;
  background: transparent;
  padding: 0.625rem 1rem;
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-600);
  transition: all var(--transition);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
}

/* Drag & drop menu reorder */
.pbsp-nav-sortable .pbsp-nav-item {
  cursor: grab;
}

.pbsp-nav-sortable .pbsp-nav-item:active {
  cursor: grabbing;
}

.pbsp-nav-sortable .pbsp-nav-item.ui-sortable-helper {
  opacity: 0.95;
  box-shadow: var(--shadow-md);
}

.pbsp-nav-sortable .ui-sortable-placeholder {
  visibility: visible !important;
  background: var(--gray-100);
  border: 1px dashed var(--gray-300);
  border-radius: var(--radius);
}

/* Menu reorder (drag & drop) */
.pbsp-nav .pbsp-nav-item[draggable="true"] {
  cursor: grab;
  user-select: none;
}

.pbsp-nav .pbsp-nav-item.is-dragging {
  opacity: 0.75;
}

.pbsp-nav.pbsp-nav-dragging,
.pbsp-nav.pbsp-nav-dragging *{
  user-select: none;
}

.pbsp-nav-item:hover {
  color: var(--primary);
  background: var(--gray-100);
  transform: translateY(-1px);
}

.pbsp-nav-item.is-active {
  color: var(--primary);
  background: var(--primary-light);
  box-shadow: var(--shadow-sm);
}

.pbsp-nav-item.is-active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--primary);
  border-radius: 2px;
}

/* ==========================================================================
   Main Content
   ========================================================================== */
.pbsp-main {
  flex: 1;
  overflow-y: auto;
  position: relative;
}

.pbsp-section {
  animation: fadeIn 0.3s ease-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ==========================================================================
   Toolbar & Actions
   ========================================================================== */
.pbsp-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.5rem;
  flex-wrap: wrap;
 
  /* Card look (requested): filters live inside a neat container */
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  padding: 0.75rem;
  box-shadow: var(--shadow-sm);
}

.pbsp-toolbar-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: flex-end;
}

.pbsp-toolbar-search {
  flex: 1 1 240px;
  min-width: 220px;
}

.pbsp-toolbar-date-range {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: flex-end;
}

.pbsp-toolbar-date-range label {
  font-size: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pbsp-toolbar-date-range input[type="date"],
.pbsp-toolbar-date-range input[type="text"] {
  min-width: 140px;
}

.pbsp-toolbar-date-range button.button {
  margin-top: 0.2rem;
}

/* --------------------------------------------------------------------------
   Inline filters for list views (Quotes / Invoices / Orders)
   Requested: keep filters + search on a single neat row, compact + modern.
   -------------------------------------------------------------------------- */
.pbsp-toolbar--inline {
  /* Keep toolbar content tidy; filters row can horizontally scroll if needed */
  align-items: center;
}

.pbsp-toolbar--inline .pbsp-toolbar-filters {
  flex-wrap: nowrap;
  align-items: center;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: thin;
}

.pbsp-toolbar--inline .pbsp-toolbar-search {
  flex: 1 1 260px;
  min-width: 220px;
}

.pbsp-toolbar--inline .pbsp-toolbar-date-range {
  flex-wrap: nowrap;
  align-items: center;
}

.pbsp-toolbar--inline .pbsp-toolbar-date-range label {
  flex-direction: row;
  align-items: center;
  gap: 8px;
  margin: 0;
}

.pbsp-toolbar--inline .pbsp-date-label-text {
  font-size: 11px;
  color: var(--gray-600);
  white-space: nowrap;
}

.pbsp-toolbar--inline .pbsp-toolbar-date-range input[type="date"],
.pbsp-toolbar--inline .pbsp-toolbar-date-range input[type="text"] {
  min-width: 128px;
}

.pbsp-toolbar--inline .pbsp-toolbar-date-range select {
  min-width: 160px;
}

/* Slightly smaller controls in inline toolbars */
.pbsp-toolbar--inline input[type="text"],
.pbsp-toolbar--inline input[type="search"],
.pbsp-toolbar--inline input[type="number"],
.pbsp-toolbar--inline input[type="date"],
.pbsp-toolbar--inline select {
  height: 34px;
  padding: 0.38rem 0.6rem;
}

.pbsp-toolbar--inline .button {
  height: 34px;
  line-height: 32px;
}

@media (max-width: 1100px) {
  /* On smaller screens allow wrapping while keeping layout clean */
  .pbsp-toolbar--inline .pbsp-toolbar-filters,
  .pbsp-toolbar--inline .pbsp-toolbar-date-range {
    flex-wrap: wrap;
    overflow-x: visible;
  }
}

/* Compact filter inputs (requested: smaller, cleaner) */
.pbsp-toolbar input[type="text"],
.pbsp-toolbar input[type="search"],
.pbsp-toolbar input[type="number"],
.pbsp-toolbar input[type="date"],
.pbsp-toolbar select {
  height: 36px;
  padding: 0.45rem 0.65rem;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  background: #fff;
  font-size: 0.8125rem;
  line-height: 1.1;
  transition: all var(--transition-fast);
}

.pbsp-toolbar input[type="text"]:focus,
.pbsp-toolbar input[type="search"]:focus,
.pbsp-toolbar input[type="number"]:focus,
.pbsp-toolbar input[type="date"]:focus,
.pbsp-toolbar select:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}


/* ==========================================================================
   Filters Card (requested)
   ========================================================================== */
.pbsp-filters-card {
  margin-bottom: 1rem;
  padding: 0.85rem;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.pbsp-filters-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: flex-end;
}

.pbsp-filters-row + .pbsp-filters-row {
  margin-top: 0.75rem;
}

.pbsp-filter-item {
  flex: 1 1 180px;
  min-width: 160px;
}

.pbsp-filter-item--sm {
  flex: 0 0 160px;
  min-width: 150px;
}

.pbsp-filter-item--search {
  flex: 2 1 280px;
  min-width: 220px;
}

.pbsp-filter-actions {
  display: flex;
  gap: 0.5rem;
  flex: 0 0 auto;
  align-items: center;
}

.pbsp-filters-card .pbsp-label {
  font-size: 0.75rem;
  margin-bottom: 0.25rem;
  font-weight: 700;
  color: var(--gray-600);
}

.pbsp-filters-card .pbsp-input,
.pbsp-filters-card select,
.pbsp-filters-card input[type="text"],
.pbsp-filters-card input[type="search"],
.pbsp-filters-card input[type="number"],
.pbsp-filters-card input[type="date"] {
  height: 36px;
  padding: 0.45rem 0.65rem;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  background: #fff;
  font-size: 0.8125rem;
}

/* ==========================================================================
   Modal form defaults (requested: all accounting modals styled)
   ========================================================================== */
.pbsp-modal-body label {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--gray-700);
  margin: 0 0 0.85rem 0;
}

.pbsp-modal-body .pbsp-grid-2 > label,
.pbsp-modal-body .pbsp-grid-3 > label {
  margin-bottom: 0;
}

.pbsp-modal-body input[type="text"]:not(.button),
.pbsp-modal-body input[type="search"]:not(.button),
.pbsp-modal-body input[type="email"]:not(.button),
.pbsp-modal-body input[type="number"]:not(.button),
.pbsp-modal-body input[type="date"]:not(.button),
.pbsp-modal-body select,
.pbsp-modal-body textarea {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  font-size: 0.875rem;
  background: #fff;
  transition: all var(--transition-fast);
}

.pbsp-modal-body input[type="text"]:focus:not(.button),
.pbsp-modal-body input[type="search"]:focus:not(.button),
.pbsp-modal-body input[type="email"]:focus:not(.button),
.pbsp-modal-body input[type="number"]:focus:not(.button),
.pbsp-modal-body input[type="date"]:focus:not(.button),
.pbsp-modal-body select:focus,
.pbsp-modal-body textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

.pbsp-modal-body textarea {
  min-height: 92px;
  resize: vertical;
}

/* Make customer/party ledger toolbars look like a card as well */
.pbsp-cust-acc-toolbar {
  padding: 0.75rem;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.pbsp-cust-acc-toolbar input[type="date"],
.pbsp-cust-acc-toolbar input[type="text"] {
  min-width: 150px;
  height: 36px;
  padding: 0.45rem 0.65rem;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  background: #fff;
  font-size: 0.8125rem;
}

/* keep existing search container styles */

.pbsp-search-container {
  position: relative;
  flex: 1;
  max-width: 400px;
}

.pbsp-search-input {
  width: 100%;
  padding: 0.625rem 1rem 0.625rem 2.5rem;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  font-size: 0.875rem;
  transition: all var(--transition);
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E") no-repeat left 0.75rem center;
  background-size: 16px;
}

.pbsp-search-input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.pbsp-actions {
  display: flex;
  gap: 0.5rem;
}

/* ==========================================================================
   Buttons
   ========================================================================== */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  padding: 0.625rem 1rem;
  border: 1px solid transparent;
  border-radius: var(--radius);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition);
  line-height: 1;
  white-space: nowrap;
}

.button:hover {
  transform: translateY(-1px);
}

.button:active {
  transform: translateY(0);
}

.button-primary {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: #fff;
  box-shadow: var(--shadow);
}

.button-primary:hover {
  box-shadow: var(--shadow-md);
  background: linear-gradient(135deg, var(--primary-dark) 0%, #1e40af 100%);
}

/* Header: Top action buttons (Books manager / Back / Fullscreen) */
.pbsp-header-right {
  flex-wrap: wrap;
}

.pbsp-header-btn {
  text-decoration: none;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--gray-300);
  box-shadow: var(--shadow-sm);
  border-radius: 999px;
  padding: 0.5rem 0.95rem;
  color: var(--gray-800);
  font-weight: 600;
}

.pbsp-header-btn::before {
  display: inline-block;
  margin-inline-end: 0.5rem;
  font-size: 14px;
  line-height: 1;
  opacity: 0.95;
}

.pbsp-header-btn:hover {
  background: #fff;
  border-color: var(--primary);
  box-shadow: var(--shadow-md);
  color: var(--gray-900);
}

.pbsp-header-btn:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15), var(--shadow-md);
}

.pbsp-header-btn-books {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: var(--shadow);
}

.pbsp-header-btn-books:hover {
  border-color: transparent;
  background: linear-gradient(135deg, var(--primary-dark) 0%, #1e40af 100%);
  box-shadow: var(--shadow-md);
  color: #fff;
}

.pbsp-header-btn-books::before {
  content: "📚";
}

.pbsp-header-btn-back::before {
  content: "⟵";
}

.pbsp-header-btn-fullscreen::before {
  content: "⛶";
}

/* Backward compat: keep older class names styled the same */
.pbsp-btn-back-to-wp { 
  text-decoration: none;
}

.button-secondary {
  background: #fff;
  color: var(--gray-700);
  border: 1px solid var(--gray-300);
  box-shadow: var(--shadow-sm);
}

.button-secondary:hover {
  background: var(--gray-50);
  border-color: var(--gray-400);
}

.button-small {
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
}

/* Small icon-only action buttons for lists */
.pbsp-icon-button.button.button-small {
  padding: 0 4px;
  min-width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}

.pbsp-icon-button {
  min-width: 32px;
  min-height: 32px;
  padding: 0.375rem;
  border-radius: var(--radius);
  background: #fff;
  border: 1px solid var(--gray-300);
  color: var(--gray-600);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
}

.pbsp-icon-button:hover {
  background: var(--gray-100);
  border-color: var(--gray-400);
  color: var(--gray-800);
  transform: translateY(-1px);
}

.pbsp-icon-button + .pbsp-icon-button {
  margin-inline-start: 0.25rem;
}

/* ==========================================================================
   Tables
   ========================================================================== */
.pbsp-table-wrapper {
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--gray-200);
  overflow: auto;
  box-shadow: var(--shadow);
  margin-bottom: 1.5rem;
}

.pbsp-table-wrapper table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.pbsp-table-wrapper thead {
  background: linear-gradient(to right, var(--gray-50), var(--gray-100));
}

.pbsp-table-wrapper th {
  padding: 1rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gray-600);
  text-align: left;
  border-bottom: 1px solid var(--gray-200);
  white-space: nowrap;
}

.pbsp-table-wrapper td {
  padding: 1rem;
  font-size: 0.875rem;
  color: var(--gray-700);
  border-bottom: 1px solid var(--gray-100);
  transition: background-color var(--transition-fast);
}

.pbsp-table-wrapper tbody tr:hover td {
  background-color: var(--gray-50);
}

.pbsp-table-wrapper tbody tr:last-child td {
  border-bottom: none;
}

.pbsp-table-wrapper tbody tr {
  cursor: pointer;
  transition: all var(--transition-fast);
}

.pbsp-table-wrapper tbody tr:hover {
  transform: translateX(2px);
  box-shadow: inset 2px 0 0 var(--primary);
}

/* Make invoice number cells in reports obviously clickable */
.pbsp-invoice-link-cell {
  cursor: pointer;
}

.pbsp-invoice-link-cell a {
  text-decoration: underline;
}

/* ==========================================================================
   Modal
   ========================================================================== */
.pbsp-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  backdrop-filter: blur(4px);
  animation: fadeInBackdrop 0.3s ease-out;
}

@keyframes fadeInBackdrop {
  from { opacity: 0; }
  to { opacity: 1; }
}

.pbsp-modal {
  background: #fff;
  width: 95%;
  max-height: 85vh;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  display: flex;
  flex-direction: column;
  animation: modalSlideIn 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  overflow: hidden;
  position: relative;
}

@keyframes modalSlideIn {
  from {
    opacity: 0;
    transform: translateY(20px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.pbsp-modal-header {
  padding: 1.5rem;
  border-bottom: 1px solid var(--gray-200);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: linear-gradient(to right, var(--gray-50), #fff);
}

.pbsp-modal-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--gray-900);
}

.pbsp-modal-close {
  width: 32px;
  height: 32px;
  border-radius: var(--radius);
  border: 1px solid var(--gray-300);
  background: #fff;
  color: var(--gray-500);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  transition: all var(--transition);
}

.pbsp-modal-close:hover {
  background: var(--gray-100);
  color: var(--gray-700);
  transform: rotate(90deg);
}

.pbsp-modal-body {
  padding: 1.5rem;
  overflow-y: auto;
  flex: 1;
}

.pbsp-modal-footer {
  padding: 1.5rem;
  border-top: 1px solid var(--gray-200);
  background: var(--gray-50);
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
}

/* ==========================================================================
   Forms
   ========================================================================== */
.pbsp-form-row {
  margin-bottom: 1.25rem;
}

.pbsp-form-row label {
  display: block;
  margin-bottom: 0.375rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-700);
}

.pbsp-form-row input,
.pbsp-form-row textarea,
.pbsp-form-row select {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  font-size: 0.875rem;
  transition: all var(--transition);
  background: #fff;
}

.pbsp-form-row input:focus,
.pbsp-form-row textarea:focus,
.pbsp-form-row select:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.pbsp-form-row textarea {
  min-height: 100px;
  resize: vertical;
}

.pbsp-input-small {
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
}

/* --------------------------------------------------------------------------
   PBSP lightweight form helpers used in new accounting/invoice modals
   -------------------------------------------------------------------------- */
.pbsp-label {
  display: block;
  margin-bottom: 0.375rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gray-700);
}

.pbsp-input {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  font-size: 0.875rem;
  transition: all var(--transition);
  background: #fff;
}

.pbsp-input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

.pbsp-grid {
  display: grid;
  gap: 0.75rem;
}

.pbsp-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.pbsp-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.pbsp-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

@media (max-width: 640px) {
  .pbsp-grid-2,
  .pbsp-grid-3,
  .pbsp-grid-4 {
    grid-template-columns: 1fr;
  }
}

.pbsp-flex {
  display: flex;
  align-items: center;
}

/* Nicer tables inside modals (covers WP widefat + PBSP tables) */
.pbsp-modal .pbsp-items-table tbody tr:nth-child(even),
.pbsp-modal .widefat tbody tr:nth-child(even) {
  background: var(--gray-50);
}

.pbsp-modal .widefat {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  overflow: hidden;
  background: #fff;
}

.pbsp-modal .widefat thead th {
  background: var(--gray-50);
  padding: 0.75rem;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--gray-600);
  border-bottom: 1px solid var(--gray-200);
  position: sticky;
  top: 0;
  z-index: 20;
}

.pbsp-modal .widefat td {
  padding: 0.75rem;
  border-bottom: 1px solid var(--gray-100);
  font-size: 0.875rem;
}

.pbsp-modal .widefat tbody tr:last-child td {
  border-bottom: none;
}

/* Cheque details box */
.pbsp-pay-cheque-details,
#pbsp-pay-cheque-box {
  padding: 0.75rem;
  border: 1px dashed var(--gray-300);
  background: var(--gray-50);
  border-radius: var(--radius);
}

/* Invoice view cards: a bit more breathing room */
.pbsp-doc-view .pbsp-card > div {
  margin: 0.35rem 0;
}

.pbsp-doc-view .pbsp-card strong {
  color: var(--gray-700);
}

/* Persian: avoid uppercase headers */
.pbsp-locale-fa .pbsp-items-table th,
.pbsp-locale-fa .widefat thead th {
  text-transform: none;
  letter-spacing: 0;
}

/* Items table inside modal */
.pbsp-items-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  overflow: visible; /* Sticky behavior needs visible overflow on table element, scroll wrapper handles scroll */
}

/* Sticky Header for Modal Table */
.pbsp-items-table th {
  background: var(--gray-50);
  padding: 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--gray-600);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--gray-200);
  
  /* Sticky properties */
  position: sticky;
  top: 0;
  z-index: 20; 
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

.pbsp-items-table td {
  padding: 0.75rem;
  border-bottom: 1px solid var(--gray-100);
  font-size: 0.875rem;
}

.pbsp-items-table tbody tr:last-child td {
  border-bottom: none;
}

/* Quote view: show edition/binding under product name */
.pbsp-quote-item-extra{
  margin-top: 4px;
  font-size: 0.75rem;
  color: var(--gray-600);
  line-height: 1.3;
}

/* Orders: compact rows + shipment highlighting (light colors) */
.pbsp-orders-items-table th {
  padding: 0.45rem 0.55rem;
  font-size: 0.7rem;
}

.pbsp-orders-items-table td {
  padding: 0.45rem 0.55rem;
  font-size: 0.8125rem;
  line-height: 1.15;
  vertical-align: top;
}

.pbsp-orders-items-table input.pbsp-input-small {
  width: 74px;
  padding: 0.25rem 0.5rem;
}

.pbsp-order-details--redesigned {
  display: grid;
  gap: 1rem;
}

.pbsp-order-meta--cards,
.pbsp-order-summary-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.75rem;
}

.pbsp-order-meta-card,
.pbsp-order-summary-card,
.pbsp-order-help-box {
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  background: #fff;
  padding: 0.85rem 1rem;
}

.pbsp-order-meta-value,
.pbsp-order-summary-value {
  font-size: 1rem;
  font-weight: 700;
  margin-top: 0.25rem;
}

.pbsp-order-meta-substatus {
  margin-top: 0.45rem;
}

.pbsp-order-help-box ol {
  margin: 0.5rem 0 0;
  padding-inline-start: 1.1rem;
}

.pbsp-order-help-box li {
  margin: 0.3rem 0;
}

.pbsp-order-item-main {
  font-weight: 600;
}

.pbsp-order-item-sub {
  margin-top: 0.2rem;
  font-size: 0.75rem;
  color: var(--gray-600);
}

.pbsp-order-row-actions {
  min-width: 168px;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.pbsp-order-row-actions .button {
  justify-content: center;
}

.pbsp-order-manual-note {
  margin: -0.2rem 0 0;
}

.pbsp-orders-items-table tbody tr.pbsp-ship-none td {
  background-color: #fff !important;
}

.pbsp-orders-items-table tbody tr.pbsp-ship-partial td {
  background-color: #fffbe6 !important; /* light yellow */
}

.pbsp-orders-items-table tbody tr.pbsp-ship-full td {
  background-color: #e9f9ee !important; /* light green */
}

/* Customer profile: accounting tab */
.pbsp-cust-acc-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: flex-end;
  margin: 0 0 1rem;
}

.pbsp-cust-acc-toolbar label {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.75rem;
  color: var(--gray-600);
}

.pbsp-cust-acc-toolbar input[type="date"],
.pbsp-cust-acc-toolbar input[type="text"] {
  min-width: 170px;
}

.pbsp-cust-acc-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.pbsp-cust-acc-cards .pbsp-card {
  padding: 1rem;
}

.pbsp-ledger-table-wrap {
  max-height: 360px;
  overflow: auto;
  border-radius: var(--radius);
  border: 1px solid var(--gray-200);
}

.pbsp-ledger-table-wrap .pbsp-items-table {
  border: 0;
}

/* ==========================================================================
   Status Badges (Quotes / Invoices / Orders)
   ========================================================================== */
.pbsp-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.18rem 0.6rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.4;
  white-space: nowrap;
  border: 1px solid transparent;
  vertical-align: middle;
}

.pbsp-status-badge::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.85;
  flex: 0 0 auto;
}

.pbsp-status-badge--success {
  background: #d1fae5;
  color: #065f46;
  border-color: rgba(16, 185, 129, 0.25);
}

.pbsp-status-badge--warning {
  background: #fef3c7;
  color: #92400e;
  border-color: rgba(245, 158, 11, 0.25);
}

.pbsp-status-badge--info {
  background: #dbeafe;
  color: #1e40af;
  border-color: rgba(59, 130, 246, 0.25);
}

.pbsp-status-badge--danger {
  background: #fee2e2;
  color: #991b1b;
  border-color: rgba(239, 68, 68, 0.25);
}

.pbsp-status-badge--neutral {
  background: #f3f4f6;
  color: #374151;
  border-color: rgba(107, 114, 128, 0.25);
}

.pbsp-status-badge--purple {
  background: #ede9fe;
  color: #5b21b6;
  border-color: rgba(124, 58, 237, 0.25);
}

/* ==========================================================================
   Customer & Product Picker
   ========================================================================== */
.pbsp-customer-picker,
.pbsp-product-picker {
  position: relative;
}

/* Quote form: customer picker + quick add button */
.pbsp-inline-actions.pbsp-customer-picker-inline .pbsp-customer-picker{
  flex: 1 1 auto;
  min-width: 0;
}
.pbsp-inline-actions.pbsp-customer-picker-inline .pbsp-customer-picker input[type="text"]{
  width: 100%;
}

/* Quote item: product search basis selector */
.pbsp-product-searchbar{
  display:flex;
  gap:0.4rem;
  align-items:stretch;
}
.pbsp-product-searchbar .pbsp-product-input{
  flex:1 1 auto;
  min-width:0;
}
.pbsp-product-search-by{
  /* Keep the search-basis selector compact so the product title input has more room. */
  width:84px;
  min-width:72px;
  padding-inline:0.5rem;
}

/*
  In some admin themes / WP styles, <select> elements get a fixed width (or min-width)
  with higher specificity (e.g., select.pbsp-input-small { width: ... }).
  Make the “search by” dropdown reliably compact and let the product title input expand.
*/
.pbsp-product-searchbar select.pbsp-product-search-by,
#pbsp-quote-form .pbsp-product-searchbar select.pbsp-product-search-by,
.pbsp-qw-quote-form .pbsp-product-searchbar select.pbsp-product-search-by{
  width:64px !important;
  min-width:64px !important;
  max-width:64px !important;
  padding-inline:0.35rem !important;
}
.pbsp-product-searchbar .pbsp-product-input,
#pbsp-quote-form .pbsp-product-searchbar .pbsp-product-input,
.pbsp-qw-quote-form .pbsp-product-searchbar .pbsp-product-input{
  flex:1 1 auto !important;
  width:auto !important;
  min-width:0 !important;
}

.pbsp-customer-results,
.pbsp-product-results {
  position: relative;
  inset-inline-start: 0;
  inset-inline-end: 0;
  top: 100%;
  background: #fff;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  max-height: 300px;
  overflow-y: auto;
  z-index: 100;
  box-shadow: var(--shadow-lg);
  margin-top: 0.25rem;
  animation: dropdownSlide 0.2s ease-out;
}

@keyframes dropdownSlide {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.pbsp-customer-option,
.pbsp-product-option {
  padding: 0.75rem 1rem;
  cursor: pointer;
  font-size: 0.875rem;
  transition: background-color var(--transition-fast);
  border-bottom: 1px solid var(--gray-100);
}

/* Product picker options: add thumbnail + compact layout */
.pbsp-product-option{
  display:flex;
  gap: 0.75rem;
  align-items:flex-start;
}

.pbsp-product-option__media{
  width: 44px;
  height: 44px;
  flex: 0 0 44px;
  border-radius: 10px;
  overflow: hidden;
  background: var(--gray-100);
  display:flex;
  align-items:center;
  justify-content:center;
}

.pbsp-product-option__img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display:block;
}

.pbsp-product-option__img--ph{
  width: 100%;
  height: 100%;
  background: var(--gray-200);
  display:block;
}

.pbsp-product-option__content{
  flex: 1;
  min-width: 0;
}

.pbsp-customer-option:last-child,
.pbsp-product-option:last-child {
  border-bottom: none;
}

.pbsp-customer-option:hover,
.pbsp-product-option:hover {
  background-color: var(--primary-light);
}

.pbsp-option-empty {
  padding: 1rem;
  text-align: center;
  color: var(--gray-500);
  font-size: 0.875rem;
}

.pbsp-option-loading {
  padding: 1rem;
  text-align: center;
  color: var(--gray-600);
  font-size: 0.875rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.pbsp-spinner {
  width: 16px;
  height: 16px;
  border: 2px solid var(--gray-300);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: pbspSpin 0.8s linear infinite;
}

@keyframes pbspSpin {
  to { transform: rotate(360deg); }
}

.pbsp-product-results.is-loading {
  opacity: 0.95;
}

/* Extra product meta (book/mag) */
.pbsp-product-extra {
  margin-top: 4px;
  font-size: 11px;
}


.pbsp-product-option__title{
  font-weight: 600;
  line-height: 1.35;
}

.pbsp-product-extra--badges{
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 6px;
}

.pbsp-meta-badge{
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--gray-100);
  border: 1px solid var(--gray-200);
  font-size: 11px;
  color: var(--gray-700);
}

.pbsp-meta-badge--year{
  background: rgba(246, 192, 0, 0.16);
  border-color: rgba(246, 192, 0, 0.28);
  color: #7a5a00;
}

.pbsp-meta-badge--isbn{
  background: rgba(59, 130, 246, 0.12);
  border-color: rgba(59, 130, 246, 0.22);
  color: #1e3a8a;
}

.pbsp-product-extra--meta{
  margin-top: 0;
  margin-bottom: 6px;
}

.pbsp-meta-badge--stock{
  font-weight: 600;
}

.pbsp-meta-badge--stock.is-yes{
  background: #ecfdf5;
  border-color: rgba(16, 185, 129, 0.35);
  color: #065f46;
}

.pbsp-meta-badge--stock.is-no{
  background: #fef2f2;
  border-color: rgba(239, 68, 68, 0.35);
  color: #7f1d1d;
}

/* ==========================================================================
   Dashboard & Reports
   ========================================================================== */
.pbsp-report-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.pbsp-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  box-shadow: var(--shadow);
  border: 1px solid var(--gray-200);
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
}

.pbsp-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.pbsp-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(to right, var(--primary), var(--secondary));
}

.pbsp-card-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gray-500);
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.pbsp-card-value {
  font-size: 2rem;
  font-weight: 800;
  color: var(--gray-900);
  line-height: 1.2;
}

.pbsp-bar-chart {
  display: flex;
  align-items: flex-end;
  gap: 0.5rem;
  height: 200px;
  padding: 1rem 0;
  position: relative;
}

.pbsp-bar-chart::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: var(--gray-300);
}

.pbsp-bar {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.pbsp-bar-inner {
  width: 100%;
  background: linear-gradient(to top, var(--primary), var(--secondary));
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  transition: height 1s ease-out;
  position: relative;
  overflow: hidden;
}

.pbsp-bar-inner::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 20px;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.3), transparent);
}

.pbsp-bar-label {
  font-size: 0.75rem;
  color: var(--gray-600);
  font-weight: 500;
  text-align: center;
}

/* Report tabs */
.pbsp-report-tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--gray-200);
  overflow-x: auto;
}

.pbsp-report-tab-btn {
  border: none;
  background: transparent;
  padding: 0.75rem 1.25rem;
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-600);
  transition: all var(--transition);
  white-space: nowrap;
  position: relative;
}

.pbsp-report-tab-btn:hover {
  color: var(--primary);
  background: var(--gray-100);
}

.pbsp-report-tab-btn.is-active {
  color: var(--primary);
  background: var(--primary-light);
}

.pbsp-report-tab-btn.is-active::after {
  content: '';
  position: absolute;
  bottom: -1rem;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--primary);
  border-radius: 2px;
}

.pbsp-report-tab {
  animation: fadeIn 0.3s ease-out;
}

/* Report charts */
.pbsp-report-charts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.pbsp-chart-card {
  padding: 1.25rem;
}

.pbsp-chart-wrap {
  position: relative;
  height: 280px;
  margin-top: 8px;
}

.pbsp-chart-wrap canvas {
  display: block;
  width: 100%;
  height: 100%;
}

.pbsp-chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
  font-size: 12px;
  color: var(--gray-700);
}

.pbsp-chart-legend-item {
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

.pbsp-chart-legend-swatch {
  width: 10px;
  height: 10px;
  border-radius: 3px;
  box-shadow: var(--shadow-sm);
}

.pbsp-chart-tooltip {
  position: absolute;
  top: 8px;
  left: 8px;
  background: rgba(17, 24, 39, 0.92);
  color: #fff;
  padding: 8px 10px;
  border-radius: 10px;
  box-shadow: var(--shadow-lg);
  pointer-events: none;
  min-width: 120px;
  z-index: 5;
}

.pbsp-chart-tooltip-title {
  font-size: 12px;
  opacity: 0.85;
  margin-bottom: 4px;
}

.pbsp-chart-tooltip-value {
  font-size: 13px;
  font-weight: 700;
}

/* Report filters layout */
.pbsp-reports-filters {
  margin-bottom: 12px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--gray-200);
  border-radius: 14px;
  background: #fff;
}

.pbsp-reports-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 8px;
  margin: 0; /* keep all filter groups in one row */
}

.pbsp-reports-row label {
  font-size: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pbsp-reports-row select,
.pbsp-reports-row input.pbsp-report-date {
  min-width: 130px;
  height: 32px;
  line-height: 32px;
  padding: 0 10px;
  border-radius: 10px;
}

.pbsp-reports-row button.button {
  height: 32px;
  line-height: 30px;
  padding: 0 12px;
  border-radius: 10px;
  white-space: nowrap;
}

.pbsp-reports-inline-title {
  font-weight: 800;
  font-size: 12px;
  padding: 6px 10px;
  border: 1px solid var(--gray-300);
  border-radius: 12px;
  background: var(--gray-50);
  align-self: flex-end;
  white-space: nowrap;
}

.pbsp-report-customer-picker {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.pbsp-report-customer-picker span {
  margin-bottom: 2px;
}

.pbsp-report-customer-picker input[type="text"] {
  min-width: 220px;
  height: 32px;
  border-radius: 10px;
}
/* ==========================================================================
   Jalali Datepicker
   ========================================================================== */
.pbsp-jalali-picker {
  position: absolute;
  z-index: 1100;
  background: #fff;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: 1rem;
  font-size: 0.875rem;
  animation: dropdownSlide 0.2s ease-out;
  min-width: 280px;
}

.pbsp-jalali-picker-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--gray-200);
}

.pbsp-jalali-picker-header-title {
  font-weight: 700;
  color: var(--gray-900);
  font-size: 1rem;
}

.pbsp-jalali-picker-nav {
  width: 32px;
  height: 32px;
  border-radius: var(--radius);
  border: 1px solid var(--gray-300);
  background: #fff;
  color: var(--gray-600);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  transition: all var(--transition);
}

.pbsp-jalali-picker-nav:hover {
  background: var(--gray-100);
  color: var(--gray-800);
  border-color: var(--gray-400);
}

.pbsp-jalali-picker-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.25rem;
}

.pbsp-jalali-picker-weekday {
  text-align: center;
  font-size: 0.75rem;
  color: var(--gray-500);
  font-weight: 600;
  padding: 0.5rem 0;
}

.pbsp-jalali-picker-cell {
  width: 36px;
  height: 36px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  background: transparent;
  color: var(--gray-700);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  transition: all var(--transition-fast);
}

.pbsp-jalali-picker-cell:hover {
  background: var(--gray-100);
  border-color: var(--gray-300);
}

.pbsp-jalali-picker-cell.is-today {
  background: var(--primary-light);
  color: var(--primary);
  font-weight: 600;
}

.pbsp-jalali-picker-cell.is-selected {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}

.pbsp-jalali-picker-cell.is-other-month {
  color: var(--gray-400);
  opacity: 0.7;
}

/* ==========================================================================
   Order Details
   ========================================================================== */
.pbsp-order-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
  padding: 1.5rem;
  background: var(--gray-50);
  border-radius: var(--radius);
  border: 1px solid var(--gray-200);
}

.pbsp-order-billing {
  padding: 1.5rem;
  background: var(--gray-50);
  border-radius: var(--radius);
  border: 1px solid var(--gray-200);
  margin-bottom: 1.5rem;
}

/* ==========================================================================
   Splash Screen
   ========================================================================== */
.pbsp-splash {
  position: fixed;
  inset: 0;
  background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.pbsp-splash::before,
.pbsp-splash::after {
  content: '';
  position: absolute;
  inset: -40%;
  pointer-events: none;
}

.pbsp-splash::before {
  background:
    radial-gradient(circle at 25% 30%, rgba(255, 255, 255, 0.22), transparent 55%),
    radial-gradient(circle at 70% 65%, rgba(255, 255, 255, 0.18), transparent 55%);
  animation: pbspBgFloat 10s ease-in-out infinite;
}

.pbsp-splash::after {
  background:
    radial-gradient(circle at 20% 85%, rgba(0, 0, 0, 0.10), transparent 60%),
    radial-gradient(circle at 90% 20%, rgba(0, 0, 0, 0.08), transparent 60%);
  animation: pbspBgFloat2 14s ease-in-out infinite;
}

.pbsp-splash-inner {
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 28px 28px 22px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.22);
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(10px);
  animation: splashPulse 2.8s ease-in-out infinite;
}

@keyframes splashPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}

.pbsp-splash-logo {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.92);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  font-size: 2rem;
  font-weight: 700;
  box-shadow: var(--shadow-xl);
  position: relative;
  animation: logoFloat 2.6s ease-in-out infinite;
}

.pbsp-splash-logo::before {
  content: '';
  position: absolute;
  inset: -5px;
  border-radius: calc(var(--radius-xl) + 6px);
  background: conic-gradient(from 0deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0.95));
  filter: blur(0.2px);
  animation: ringSpin 2.2s linear infinite;
  z-index: -1;
}

.pbsp-splash-logo-svg {
  display: block;
  color: var(--primary);
}

@keyframes logoFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

@keyframes ringSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@keyframes logoSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.pbsp-splash-title {
  font-size: 2rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: 0.5rem;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.pbsp-splash-subtitle {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: 2rem;
}

.pbsp-splash-dots span {
  display: inline-block;
  width: 0.35em;
  opacity: 0;
  animation: pbspDot 1.1s infinite;
}

.pbsp-splash-dots span:nth-child(2) { animation-delay: .15s; }
.pbsp-splash-dots span:nth-child(3) { animation-delay: .3s; }

@keyframes pbspDot {
  0% { opacity: 0; transform: translateY(0); }
  40% { opacity: 1; transform: translateY(-2px); }
  80% { opacity: 0; transform: translateY(0); }
}

.pbsp-splash-progress {
  width: 200px;
  height: 6px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  overflow: hidden;
  margin: 0 auto;
}

.pbsp-splash-bar {
  width: 60%;
  height: 100%;
  background: #fff;
  border-radius: 999px;
  animation: loading 1.5s ease-in-out infinite;
}

@keyframes loading {
  0%, 100% { transform: translateX(-100%); }
  50% { transform: translateX(200%); }
}

@keyframes pbspBgFloat {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(-2%, 2%, 0) scale(1.04); }
}

@keyframes pbspBgFloat2 {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(3%, -2%, 0) scale(1.06); }
}


/* ==========================================================================
   Import progress
   ========================================================================== */
.pbsp-progress {
  width: 100%;
  height: 10px;
  background: var(--gray-200);
  border-radius: 999px;
  overflow: hidden;
}

.pbsp-progress-bar {
  height: 100%;
  background: var(--primary);
  width: 0%;
  transition: width 200ms ease;
}

.pbsp-progress-text {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: var(--gray-700);
}

.pbsp-import-hint {
  margin-top: 0.5rem;
  font-size: 0.8125rem;
  color: var(--gray-600);
  opacity: 0.9;
}

.pbsp-import-status {
  margin-top: 0.75rem;
  font-size: 0.875rem;
  color: var(--gray-800);
  white-space: pre-line;
}


/* ==========================================================================
   RTL / Locale
   ========================================================================== */
/* RTL container: Persian UI */
.pbsp-locale-fa {
  direction: rtl;
  text-align: right;
  font-family: var(--pbsp-panel-font);
}

/* Apply Vazir to all inner elements in RTL mode */
.pbsp-locale-fa,
.pbsp-locale-fa * {
  font-family: var(--pbsp-panel-font) !important;
  letter-spacing: 0; /* مناسب برای فارسی */
}

.pbsp-locale-fa .pbsp-table-wrapper th,
.pbsp-locale-fa .pbsp-table-wrapper td {
  text-align: right;
}

/* Persian tables should not force uppercase spacing */
.pbsp-locale-fa .pbsp-table-wrapper th {
  text-transform: none;
  letter-spacing: 0;
}

.pbsp-locale-fa .pbsp-form-row label {
  text-align: right;
}

.pbsp-locale-fa .pbsp-modal-footer {
  justify-content: flex-start;
}

.pbsp-locale-fa .pbsp-jalali-picker-grid {
  direction: rtl;
}

/* LTR locale: انگلیسی / بین‌المللی */
.pbsp-locale-en {
  direction: ltr;
  text-align: left;
  font-family: var(--pbsp-panel-font);
}

/* ==========================================================================
   Print
   ========================================================================== */
@media print {
  .pbsp-no-print {
    display: none !important;
  }

  .pbsp-modal {
    position: static;
    box-shadow: none;
    border: 1px solid var(--gray-300);
  }

  .pbsp-modal-backdrop {
    position: static;
    background: none;
  }
}

/* ==========================================================================
   Utilities
   ========================================================================== */
.pbsp-text-success { color: var(--success); }
.pbsp-text-warning { color: var(--warning); }
.pbsp-text-danger { color: var(--danger); }
.pbsp-text-info { color: var(--info); }

.pbsp-bg-success { background: var(--success); color: #fff; }
.pbsp-bg-warning { background: var(--warning); color: #fff; }
.pbsp-bg-danger { background: var(--danger); color: #fff; }
.pbsp-bg-info { background: var(--info); color: #fff; }

.pbsp-border { border: 1px solid var(--gray-200); }
.pbsp-border-t { border-top: 1px solid var(--gray-200); }
.pbsp-border-b { border-bottom: 1px solid var(--gray-200); }
.pbsp-border-l { border-left: 1px solid var(--gray-200); }
.pbsp-border-r { border-right: 1px solid var(--gray-200); }

.pbsp-rounded { border-radius: var(--radius); }
.pbsp-rounded-full { border-radius: 999px; }

.pbsp-shadow { box-shadow: var(--shadow); }
.pbsp-shadow-lg { box-shadow: var(--shadow-lg); }

.pbsp-animate-spin {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Fullscreen mode: hide WP admin chrome */
body.pbsp-fullscreen #adminmenumain,
body.pbsp-fullscreen #wpadminbar,
body.pbsp-fullscreen #screen-meta,
body.pbsp-fullscreen #screen-meta-links,
body.pbsp-fullscreen #wpfooter {
  display: none !important;
}
body.pbsp-fullscreen #wpcontent {
  margin-left: 0 !important;
}
body.pbsp-fullscreen #wpbody-content {
  padding-top: 0 !important;
}

/* Hide WP notices on kiosk panel page so the app can use full height */
body.pbsp-fullscreen .notice,
body.pbsp-fullscreen .updated,
body.pbsp-fullscreen .update-nag,
body.pbsp-fullscreen .error {
  display: none !important;
}


/* Customer profile tabs */
.pbsp-tabs.pbsp-customer-tabs {
  display: flex;
  gap: 0.5rem;
  margin: 12px 0;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--gray-200);
  overflow-x: auto;
}

.pbsp-tab-btn {
  border: none;
  background: transparent;
  padding: 0.6rem 1rem;
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-600);
  transition: all var(--transition);
  white-space: nowrap;
}

.pbsp-tab-btn:hover {
  color: var(--primary);
  background: var(--gray-100);
}

.pbsp-tab-btn.is-active {
  color: var(--primary);
  background: var(--primary-light);
}

.pbsp-tab-panel {
  display: none;
  animation: fadeIn 0.2s ease-out;
}

.pbsp-tab-panel.is-active {
  display: block;
}

.pbsp-clickable-table tbody tr {
  cursor: pointer;
}

.pbsp-clickable-table tbody tr:hover {
  background: var(--gray-100);
}

.pbsp-customer-profile-header h3 {
  margin-top: 0;
}

.pbsp-customer-profile-contacts {
  margin-top: 0.75rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  background: var(--gray-50);
}

.pbsp-customer-profile-contacts__title {
  font-weight: 800;
  color: var(--gray-800);
  margin-bottom: 0.35rem;
}

.pbsp-customer-profile-contacts__list {
  margin: 0;
  padding-inline-start: 1.1rem;
  display: grid;
  gap: 0.25rem;
  color: var(--gray-700);
}

/* ========================================================================
   Offline Manager
   ======================================================================== */
.pbsp-offline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.pbsp-offline-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin-top: 1rem;
}

@media (min-width: 1100px) {
  .pbsp-offline-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.pbsp-offline-card-meta {
  margin-top: 0.75rem;
  font-size: 0.8125rem;
  color: var(--gray-600);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.pbsp-offline-h3 {
  margin: 0.25rem 0 0.75rem;
  font-size: 1rem;
  font-weight: 800;
  color: var(--gray-800);
}

.pbsp-offline-progress {
  margin: 0.75rem 0 1rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,255,255,0.86));
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(6px);
}

.pbsp-offline-progress__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.pbsp-offline-progress__title {
  font-weight: 800;
  color: var(--gray-900);
  font-size: 0.95rem;
}

.pbsp-offline-progress__meta {
  font-size: 0.85rem;
  color: var(--gray-700);
  white-space: nowrap;
}

.pbsp-offline-progress__bar {
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--gray-100);
  border: 1px solid var(--gray-200);
}

.pbsp-offline-progress__barfill {
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: var(--primary);
  transition: width 180ms ease-out;
}

/* ========================================================================
   Toasts
   ======================================================================== */
.pbsp-toast-container {
  position: fixed;
  bottom: 1rem;
  inset-inline-end: 1rem;
  z-index: 100000;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-width: 420px;
  pointer-events: none;
}

.pbsp-toast {
  pointer-events: auto;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.75rem 0.9rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--gray-200);
  background: #fff;
  animation: pbspToastIn 180ms ease-out;
}

.pbsp-toast.is-hiding {
  animation: pbspToastOut 160ms ease-in forwards;
}

.pbsp-toast__msg {
  flex: 1;
  font-size: 0.875rem;
  color: var(--gray-800);
  line-height: 1.4;
}

.pbsp-toast__close {
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 1.1rem;
  line-height: 1;
  color: var(--gray-500);
  padding: 0 0.25rem;
}

.pbsp-toast--info {
  border-color: rgba(59, 130, 246, 0.35);
  background: #eff6ff;
}

.pbsp-toast--success {
  border-color: rgba(16, 185, 129, 0.35);
  background: #ecfdf5;
}

.pbsp-toast--warning {
  border-color: rgba(245, 158, 11, 0.35);
  background: #fffbeb;
}

.pbsp-toast--danger {
  border-color: rgba(239, 68, 68, 0.35);
  background: #fef2f2;
}

@keyframes pbspToastIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes pbspToastOut {
  from { opacity: 1; transform: translateY(0); }
  to { opacity: 0; transform: translateY(10px); }
}

/* ---------------- Quote items: row numbers ---------------- */
.pbsp-col-rownum,
td.pbsp-rownum {
  width: 42px;
  text-align: center;
  white-space: nowrap;
}

/* ---------------- Product extra: PB book stock badge ---------------- */
.pbsp-stock-wrap {
  margin-top: 6px;
  font-size: 12px;
  display: flex;
  gap: 6px;
  align-items: center;
}

.pbsp-stock-label {
  color: #475569;
}

.pbsp-stock-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid #e2e8f0;
  font-weight: 600;
  line-height: 1.2;
}

.pbsp-stock-badge.is-yes {
  background: #ecfdf5;
  border-color: rgba(16, 185, 129, 0.35);
  color: #065f46;
}

.pbsp-stock-badge.is-no {
  background: #fef2f2;
  border-color: rgba(239, 68, 68, 0.35);
  color: #7f1d1d;
}

.pbsp-stock-qty {
  color: #64748b;
  font-size: 11px;
}

/* --------------------------------------------------------------------------
   Quote (New Window/Modal) Column Widths
   Notes:
   - New quote UI uses multiple floating windows with a unique prefix for IDs.
   - Those forms have the class `.pbsp-qw-quote-form`.
   - Keep legacy selector (#pbsp-quote-form) for backward compatibility.
   -------------------------------------------------------------------------- */
#pbsp-quote-form .pbsp-items-table,
.pbsp-qw-quote-form .pbsp-items-table {
  table-layout: fixed; /* Force column widths */
}

/* 1. Row # */
#pbsp-quote-form .pbsp-items-table th.pbsp-col-rownum,
.pbsp-qw-quote-form .pbsp-items-table th.pbsp-col-rownum {
  width: 40px;
}

/* 2. Product (Maximize space) */
#pbsp-quote-form .pbsp-items-table th:nth-child(2),
.pbsp-qw-quote-form .pbsp-items-table th:nth-child(2) {
  width: auto; /* Takes all remaining space */
}

/* 3. Quantity (Reduced ~50%) */
#pbsp-quote-form .pbsp-items-table th:nth-child(3),
.pbsp-qw-quote-form .pbsp-items-table th:nth-child(3) {
  width: 128px; /* Qty column: expanded (x2) */
}

/* 4. Unit Price (Reduced ~50%) */
#pbsp-quote-form .pbsp-items-table th:nth-child(4),
.pbsp-qw-quote-form .pbsp-items-table th:nth-child(4) {
  width: 220px; /* x2 */
}

/* 5. Discount */
#pbsp-quote-form .pbsp-items-table th:nth-child(5),
.pbsp-qw-quote-form .pbsp-items-table th:nth-child(5) {
  width: 160px; /* x2 */
}

/* 6. Line Total */
#pbsp-quote-form .pbsp-items-table th:nth-child(6),
.pbsp-qw-quote-form .pbsp-items-table th:nth-child(6) {
  width: 110px;
}

/* 7. Action (Remove) */
#pbsp-quote-form .pbsp-items-table th:nth-child(7),
.pbsp-qw-quote-form .pbsp-items-table th:nth-child(7) {
  width: 35px;
}

/* Make the product search input actually use the available column width */
#pbsp-quote-form .pbsp-items-table td:nth-child(2) .pbsp-product-picker,
.pbsp-qw-quote-form .pbsp-items-table td:nth-child(2) .pbsp-product-picker {
  width: 100%;
}

#pbsp-quote-form .pbsp-items-table td:nth-child(2) .pbsp-product-input,
.pbsp-qw-quote-form .pbsp-items-table td:nth-child(2) .pbsp-product-input {
  width: 100%;
  box-sizing: border-box;
}

/* Compact qty input so it doesn't look "giant" compared to the product field */
#pbsp-quote-form .pbsp-items-table td:nth-child(3) input[data-field="qty"],
.pbsp-qw-quote-form .pbsp-items-table td:nth-child(3) input[data-field="qty"] {
  width: 100%;
  min-width: 0;
  text-align: center;
  padding-inline: 0.4rem;
}

/* Ensure price/discount inputs actually fill their (now wider) columns */
#pbsp-quote-form .pbsp-items-table td:nth-child(4) input[data-field="price"],
.pbsp-qw-quote-form .pbsp-items-table td:nth-child(4) input[data-field="price"],
#pbsp-quote-form .pbsp-items-table td:nth-child(5) input[data-field="discount"],
.pbsp-qw-quote-form .pbsp-items-table td:nth-child(5) input[data-field="discount"] {
  width: 100%;
  min-width: 0;
}

/* --------------------------------------------------------------------------
   Quote form: compact layout + zebra rows (easier data entry)
   -------------------------------------------------------------------------- */
.pbsp-qw-quote-form .pbsp-form-row {
  margin-bottom: 0.85rem;
}

.pbsp-qw-quote-form .pbsp-items-table th {
  padding: 0.45rem 0.55rem;
  font-size: 0.72rem;
}

.pbsp-qw-quote-form .pbsp-items-table td {
  padding: 0.45rem 0.55rem;
  font-size: 0.84rem;
  vertical-align: top;
}

.pbsp-qw-quote-form .pbsp-items-table tbody tr:nth-child(even) {
  background: var(--gray-50);
}

.pbsp-qw-quote-form .pbsp-items-table tbody tr:hover {
  background: rgba(37, 99, 235, 0.06);
}

.pbsp-qw-quote-form .pbsp-input-small {
  padding: 0.28rem 0.55rem;
  font-size: 0.78rem;
}

.pbsp-qw-quote-form .pbsp-product-extra {
  margin-top: 2px;
}

/* Edition + binding on one row */
.pbsp-book-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 4px;
}

.pbsp-book-meta-field {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-width: 0;
}

.pbsp-book-meta-label {
  font-weight: 600;
  color: #475569;
  white-space: nowrap;
}

.pbsp-book-meta-field select {
  min-width: 140px;
  max-width: 320px;
}

/* Extra discount (rounding) controls in quote form */
.pbsp-extra-discount-controls{
  display:flex;
  gap:8px;
  align-items:center;
}
.pbsp-extra-discount-controls .pbsp-extra-discount-toggle{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin:0;
  margin-bottom:0;
  width:auto;
  white-space:nowrap;
}
.pbsp-extra-discount-controls .pbsp-extra-discount-toggle input{
  width:16px;
  height:16px;
}
.pbsp-extra-discount-controls .pbsp-extra-discount-input{
  flex:1;
  min-width:0;
}
.pbsp-extra-discount-controls .pbsp-extra-discount-input:disabled{
  opacity:0.7;
  background: var(--gray-100);
}

/* Customer type inline controls */
.pbsp-inline-actions {
  display: flex;
  gap: 6px;
  align-items: center;
}
.pbsp-inline-actions select {
  flex: 1;
}

/* Customer contacts */
.pbsp-contacts-wrap{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:8px;
}
.pbsp-contact-row{
  display:flex;
  gap:8px;
  align-items:center;
}
.pbsp-contact-row input{
  flex:1;
}
.pbsp-contact-row .pbsp-contact-mobile{
  direction:ltr;
}
.pbsp-contact-row .pbsp-contact-remove{
  flex:0 0 auto;
  padding:0 10px;
  height:42px;
  line-height:42px;
}

/* Customer specialties (multi-select) */
.pbsp-specialties-wrap{
  display:flex;
  gap:10px;
  align-items:flex-start;
}
.pbsp-specialties-select{
  width:100%;
  min-height:120px;
}
.pbsp-specialties-actions{
  display:flex;
  flex-direction:column;
  gap:6px;
  white-space:nowrap;
}
@media (max-width: 780px){
  .pbsp-specialties-wrap{
    flex-direction:column;
  }
  .pbsp-specialties-actions{
    flex-direction:row;
  }
}

/* Select2/SelectWoo styling for specialties */
.pbsp-specialties-wrap .select2-container,
.pbsp-specialties-wrap .selectWoo-container{
  width:100% !important;
  flex:1 1 auto;
}
.pbsp-specialties-wrap .select2-container--default .select2-selection--multiple,
.pbsp-specialties-wrap .selectWoo-container--default .selectWoo-selection--multiple{
  min-height:42px;
  border-radius:12px;
  padding:4px 8px;
}
.pbsp-specialties-wrap .select2-selection__rendered{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.pbsp-specialties-wrap .select2-selection__choice{
  border-radius:999px;
  padding:4px 10px;
}
.pbsp-specialties-wrap .select2-selection__choice__remove{
  margin-left:6px;
}
.pbsp-specialties-wrap .select2-search--inline .select2-search__field{
  margin-top:4px;
}



/* Sub-modal (nested) — used for managing lists inside the classic modal */
.pbsp-submodal-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  display: none;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(3px);
  animation: fadeInBackdrop 0.25s ease-out;
}
.pbsp-submodal{
  background: #fff;
  width: 92vw;
  max-width: 760px;
  max-height: 85vh;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--gray-200);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: modalSlideIn 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}
.pbsp-submodal-header{
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--gray-200);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: linear-gradient(to right, var(--gray-50), #fff);
}
.pbsp-submodal-title{
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--gray-900);
}
.pbsp-submodal-close{
  width: 32px;
  height: 32px;
  border-radius: var(--radius);
  border: 1px solid var(--gray-300);
  background: #fff;
  color: var(--gray-500);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  transition: all var(--transition);
}
.pbsp-submodal-close:hover{
  background: var(--gray-100);
  color: var(--gray-700);
  transform: rotate(90deg);
}
.pbsp-submodal-body{
  padding: 1.25rem;
  overflow-y: auto;
  flex: 1;
}
.pbsp-submodal-footer{
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--gray-200);
  background: var(--gray-50);
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  flex-wrap: wrap;
}

/* Specialties manager */
.pbsp-specmgr-toolbar{
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.pbsp-specmgr-list{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pbsp-specmgr-row{
  display: flex;
  gap: 8px;
  align-items: center;
}
.pbsp-specmgr-row .pbsp-specmgr-input{
  flex: 1;
}
.pbsp-specmgr-row .pbsp-specmgr-del{
  flex: 0 0 auto;
  padding: 0 10px;
  height: 42px;
  line-height: 42px;
}


/* ===================== Quote windows (multi-instance) ===================== */
/*
  این پنجره‌ها از نظر ظاهری باید شبیه مودال قبلی باشند (BackDrop تار،
  بک‌گراند سفید، هدر گرادیانی، فوتر خاکستری)، ولی قابلیت multi-instance/minimize را نگه می‌دارند.
*/

.pbsp-qw-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: none;
  z-index: 1800;
  backdrop-filter: blur(4px);
  animation: fadeInBackdrop 0.25s ease-out;
}

.pbsp-qw{
  position: fixed;
  /* Responsive: keep the classic centered modal feel but scale with viewport */
  width: 90vw;
  max-width: 90vw;
  min-width: 320px;
  max-height: 85vh;
  background: #fff;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--gray-200);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: modalSlideIn 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

.pbsp-qw-header{
  padding: 1.5rem;
  border-bottom: 1px solid var(--gray-200);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  background: linear-gradient(to right, var(--gray-50), #fff);
}

.pbsp-qw-title{
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--gray-900);
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pbsp-qw-actions{
  display: flex;
  gap: 0.5rem;
  flex: 0 0 auto;
}

.pbsp-qw-btn{
  width: 34px;
  height: 34px;
  border-radius: var(--radius);
  border: 1px solid var(--gray-300);
  background: #fff;
  color: var(--gray-500);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  transition: all var(--transition);
  padding: 0;
  line-height: 1;
}

.pbsp-qw-btn:hover{
  background: var(--gray-100);
  color: var(--gray-700);
  transform: translateY(-1px);
}

.pbsp-qw-btn.pbsp-qw-close:hover{
  transform: rotate(90deg);
}

.pbsp-qw-body{
  padding: 1.5rem;
  overflow-y: auto;
  flex: 1;
}

.pbsp-qw-footer{
  padding: 1.5rem;
  border-top: 1px solid var(--gray-200);
  background: var(--gray-50);
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
}

.pbsp-locale-fa .pbsp-qw-footer{
  justify-content: flex-start;
}

/* Tray for minimized quote windows (شیک‌تر) */
.pbsp-qw-tray{
  position: fixed;
  bottom: 14px;
  right: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  z-index: 4000;
  padding: 10px 12px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.78));
  border: 1px solid rgba(0, 0, 0, 0.06);
  backdrop-filter: blur(10px);
  box-shadow: 0 12px 30px rgba(0,0,0,.18);
  max-width: calc(100vw - 28px);
  align-items: center;
}

body.rtl .pbsp-qw-tray{
  right: auto;
  left: 14px;
}

.pbsp-qw-tray-item{
  border: 1px solid rgba(0,0,0,0.08);
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.9));
  color: var(--gray-900);
  border-radius: 999px;
  padding: 8px 12px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0 8px 18px rgba(0,0,0,.14);
  transition: all var(--transition-fast);
  user-select: none;
  white-space: nowrap;
}

.pbsp-qw-tray-item::before{
  content: '';
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 0 0 3px rgba(246, 192, 0, 0.25);
  flex: 0 0 auto;
}

.pbsp-qw-tray-item:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 22px rgba(0,0,0,.18);
}

.pbsp-qw-tray-item:focus{
  outline: none;
  box-shadow: 0 0 0 3px rgba(246, 192, 0, 0.25), 0 10px 18px rgba(0,0,0,.16);
}

@media (max-width: 782px){
  .pbsp-qw{
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    max-height: calc(100vh - 170px);
    left: 10px !important;
    top: 60px !important;
  }
}


/* Draft restore helper text for edition/issue */
.pbsp-extra-summary {
  color: var(--gray-600);
  margin-top: 2px;
  font-size: 11px;
}

/* ---------- Accounting sub-navigation ---------- */
.pbsp-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 8px;
  margin: 5px 10px 5px;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,0.6);
}

body.pbsp-dark .pbsp-subnav {
  background: rgba(31,41,55,0.6);
  border-color: rgba(255,255,255,0.10);
}

.pbsp-subnav-item {
  appearance: none;
  border: 1px solid var(--gray-200);
  background: transparent;
  color: inherit;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  line-height: 1.2;
  cursor: pointer;
  transition: var(--transition-fast);
}

.pbsp-subnav-item:hover {
  border-color: var(--gray-300);
}

.pbsp-subnav-item.is-active {
  background: var(--primary-light);
  border-color: var(--primary);
}

body.pbsp-dark .pbsp-subnav-item {
  border-color: rgba(255,255,255,0.12);
}

body.pbsp-dark .pbsp-subnav-item.is-active {
  background: rgba(37,99,235,0.25);
  border-color: rgba(37,99,235,0.65);
}

/* Invoice payments realtime UX */
tr.pbsp-pay-temp {
  opacity: 0.65;
}

.pbsp-flash {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(17,24,39,0.12);
  background: rgba(249,250,251,0.9);
  color: var(--gray-800);
  animation: pbspFlash 1.6s ease-in-out 0s 2;
}

.pbsp-flash.pbsp-flash-success{
  border-color: rgba(16,185,129,0.35);
  background: rgba(16,185,129,0.10);
}
.pbsp-flash.pbsp-flash-danger{
  border-color: rgba(239,68,68,0.35);
  background: rgba(239,68,68,0.10);
}
.pbsp-flash.pbsp-flash-info{
  border-color: rgba(59,130,246,0.35);
  background: rgba(59,130,246,0.10);
}

@keyframes pbspFlash {
  0%, 100% { background-color: transparent; }
  50% { background-color: rgba(246,192,0,0.18); }
}

/* --------------------------------------------------------------------------
   Books section (inside Sales Panel) cards
   -------------------------------------------------------------------------- */
.pbsp-card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:16px;
  padding:16px;
}
.pbsp-card-grid .pbsp-card{
  padding:16px;
}
.pbsp-card-grid .pbsp-card h3{
  margin:0 0 8px;
  font-size:1.05rem;
}
.pbsp-card-grid .pbsp-card p{
  margin:0 0 12px;
  color:var(--gray-600);
  line-height:1.6;
}

/* --------------------------------------------------------------------------
   Books embedded pages (tabs + iframe)
   -------------------------------------------------------------------------- */
.pbsp-subnav{
  display:flex;
  gap:8px;
  align-items:center;
  padding:4px 16px;
  border-bottom:1px solid var(--gray-200);
  background:#fff;
  position:sticky;
  top:0;
  z-index:5;
}
.pbsp-subnav-item{
  border:1px solid var(--gray-200);
  background:var(--gray-50);
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
  font-size:0.9rem;
}
.pbsp-subnav-item.is-active{
  background:#fff;
  border-color:rgba(59,130,246,.35);
  box-shadow:0 1px 0 rgba(0,0,0,.04);
}
.pbsp-subnav-spacer{ flex:1; }
.pbsp-subnav-link{
  font-size:0.9rem;
  text-decoration:none;
}
/* Books section: embedded apps (no iframe) */
.pbsp-books-content{
  background:#fff;
  border:1px solid var(--gray-200);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}

.pbsp-books-view{
  padding:0.75rem;
}

.pbsp-books-view.is-active{
  display:block;
}

.pbsp-books-settings-subnav{
  margin-top:0.75rem;
}

.pbsp-books-settings-body{
  margin-top:0.75rem;
}

.pbsp-loading{
  padding:1rem;
  color:var(--gray-600);
  font-size:0.9rem;
}

/* Make widefat tables look decent outside wp-admin */
.pbsp-main .widefat{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  border:1px solid var(--gray-200);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
}
.pbsp-main .widefat thead th{
  background:var(--gray-50);
  padding:0.75rem;
  font-size:0.75rem;
  font-weight:700;
  color:var(--gray-600);
  border-bottom:1px solid var(--gray-200);
}
.pbsp-main .widefat td{
  padding:0.75rem;
  border-bottom:1px solid var(--gray-100);
  font-size:0.875rem;
}
.pbsp-main .widefat tbody tr:nth-child(even){
  background:var(--gray-50);
}
.pbsp-main .widefat tbody tr:last-child td{
  border-bottom:none;
}

.pbsp-main .form-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
}
.pbsp-main .form-table th{
  text-align:right;
  padding:0.6rem 0.75rem;
  width:240px;
  color:var(--gray-700);
  font-weight:600;
  vertical-align:top;
}
.pbsp-main .form-table td{
  padding:0.6rem 0.75rem;
}

}


/* ------------------------------------------------------------
   Duplicate line-item highlight (quote/invoice item rows)
------------------------------------------------------------ */
tr.pbsp-dup-existing {
  background: #fff7ed !important;
  position: relative;
  animation: pbspDupPulse 1.1s ease-in-out 0s 2;
}
tr.pbsp-dup-current {
  background: #fee2e2 !important;
  position: relative;
  animation: pbspDupShake 0.45s ease-in-out 0s 1;
}
tr[data-pbsp-dup="1"] td {
  border-top-color: rgba(239, 68, 68, 0.35) !important;
  border-bottom-color: rgba(239, 68, 68, 0.35) !important;
}

@keyframes pbspDupPulse {
  0%   { box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.45); }
  70%  { box-shadow: 0 0 0 10px rgba(245, 158, 11, 0); }
  100% { box-shadow: 0 0 0 0 rgba(245, 158, 11, 0); }
}

@keyframes pbspDupShake {
  0%   { transform: translateX(0); }
  25%  { transform: translateX(-4px); }
  50%  { transform: translateX(4px); }
  75%  { transform: translateX(-3px); }
  100% { transform: translateX(0); }
}

/* ------------------------------------------------------------------
 * SMS stage 2 (templates + bulk customer sms)
 * ------------------------------------------------------------------ */
.pbsp-toolbar--customers{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.pbsp-toolbar--customers .pbsp-toolbar-left{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.pbsp-toolbar--customers .pbsp-toolbar-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.pbsp-inline-checkbox{display:inline-flex;align-items:center;gap:6px;font-size:12px;opacity:.9}

.pbsp-sms-shortcodes{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.pbsp-sms-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(0,0,0,.12);background:#fff;border-radius:999px;padding:4px 10px;font-size:12px;cursor:pointer;user-select:none}
.pbsp-sms-chip code{font-size:12px;opacity:.85}
.pbsp-sms-chip:active{transform:scale(.98)}
.pbsp-sms-chip[draggable="true"]{cursor:grab}

.pbsp-sms-template-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.pbsp-sms-preview{border:1px dashed rgba(0,0,0,.2);border-radius:10px;padding:10px;margin-top:10px;background:rgba(0,0,0,.02)}
.pbsp-sms-preview-item{padding:8px 0;border-top:1px solid rgba(0,0,0,.06)}
.pbsp-sms-preview-item:first-child{border-top:0}

/* SMS automations stats */
.pbsp-sms-auto-stats{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.pbsp-badge{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:3px 8px;font-size:12px;border:1px solid rgba(0,0,0,.12);background:rgba(0,0,0,.02)}
.pbsp-badge--ok{border-color:rgba(0,140,0,.22);background:rgba(0,140,0,.06)}
.pbsp-badge--err{border-color:rgba(200,0,0,.22);background:rgba(200,0,0,.06)}
.pbsp-sms-auto-stat-link{cursor:pointer;user-select:none}
.pbsp-sms-auto-stat-link:hover{filter:brightness(.96)}




/* ==========================================================================
   Fix: TinyMCE / Quicktags icons inside PBSP (Persian font override)
   --------------------------------------------------------------------------
   We set Vazir font on all elements in .pbsp-locale-fa using !important.
   That breaks icon fonts used by TinyMCE + Dashicons. Reset them here.
   ========================================================================== */
.pbsp-locale-fa .mce-ico,
.pbsp-locale-fa .mce-btn .mce-ico,
.pbsp-locale-fa .mce-ico:before {
  font-family: tinymce, Arial, sans-serif !important;
}

.pbsp-locale-fa .dashicons,
.pbsp-locale-fa .dashicons-before:before,
.pbsp-locale-fa .dashicons-after:after,
.pbsp-locale-fa .wp-media-buttons .dashicons,
.pbsp-locale-fa .wp-editor-tabs .dashicons {
  font-family: dashicons !important;
}


/* v1.0.90.106: compact book thumbnail beside line items in quote/invoice/order views */
.pbsp-line-product {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  min-width: 190px;
}

.pbsp-line-thumb {
  width: 38px;
  height: 52px;
  object-fit: contain;
  object-position: center;
  border-radius: 6px;
  border: 1px solid var(--gray-200);
  background: var(--gray-50);
  flex: 0 0 38px;
}

.pbsp-line-thumb--empty {
  display: inline-block;
}

.pbsp-line-thumb-link {
  display: inline-flex;
  flex: 0 0 38px;
  text-decoration: none;
  border-radius: 6px;
}
.pbsp-line-thumb-link:hover .pbsp-line-thumb {
  box-shadow: 0 0 0 2px var(--primary-100, rgba(37, 99, 235, 0.18));
}

.pbsp-line-product__text {
  min-width: 0;
  line-height: 1.35;
}

.pbsp-order-item-extra {
  margin-top: 0.2rem;
  font-size: 0.75rem;
  color: var(--gray-700);
  line-height: 1.3;
}

.pbsp-wallet-admin-card{padding:14px;border:1px solid var(--gray-200);border-radius:16px;background:linear-gradient(180deg,#fff,#f8fbff);box-shadow:0 10px 24px rgba(15,23,42,.05)}
.pbsp-wallet-admin-balance{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px;padding:12px;border-radius:14px;background:#eff6ff;color:#1e40af}
.pbsp-wallet-admin-balance span{font-weight:700}
.pbsp-wallet-admin-balance strong{font-size:18px;font-weight:900}
.pbsp-wallet-admin-charge{display:grid;grid-template-columns:minmax(120px,180px) minmax(160px,1fr) auto;gap:8px;align-items:center}
@media (max-width: 720px){.pbsp-wallet-admin-charge{grid-template-columns:1fr}.pbsp-wallet-admin-charge .button{width:100%}}

/* Wider customer filters for multi-select type/specialty controls. */
#pbsp-customers-filter-type,
#pbsp-customers-filter-specialties {
  min-width: 240px;
}
#pbsp-customers-filter-specialties {
  min-width: 260px;
}
.pbsp-toolbar--customers .select2-container,
.pbsp-toolbar--customers .selectWoo-container {
  min-width: 240px !important;
}

/* Source filter toggles for quotes / invoices / orders. */
.pbsp-source-filter,
.pbsp-invoices-source-filter {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 6px 10px;
  border: 1px solid rgba(148, 163, 184, .35);
  border-radius: 12px;
  background: rgba(248, 250, 252, .92);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
}
.pbsp-source-filter .pbsp-inline-checkbox,
.pbsp-invoices-source-filter .pbsp-inline-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  white-space: nowrap;
  font-weight: 700;
  color: var(--gray-700);
}
.pbsp-source-filter input[type="checkbox"],
.pbsp-invoices-source-filter input[type="checkbox"] {
  margin: 0;
}

/* Force the panel UI to use the configured Persian panel font everywhere. */
#pbsp-app,
#pbsp-app *,
.pbsp-panel-page,
.pbsp-panel-page *,
.pbsp-modal,
.pbsp-modal *,
.pbsp-qw-window,
.pbsp-qw-window *,
.pbsp-toast,
.pbsp-toast * {
  font-family: var(--pbsp-panel-font) !important;
}
#pbsp-app .dashicons,
#pbsp-app .dashicons-before:before,
.pbsp-panel-page .dashicons,
.pbsp-panel-page .dashicons-before:before {
  font-family: dashicons !important;
}

/* v1.0.90.140: fit book cover images in admin product/search/invoice/order frames */
.pbsp-product-option__img,
.pbsp-line-thumb,
.pbsp-product-thumb img,
.pbsp-order-thumb img,
.pbsp-quote-thumb img,
.pbsp-invoice-thumb img,
.pbsp-book-thumb img,
.pbsp-selected-product-thumb img,
.pbsp-product-image img,
.pbsp-item-product-image img,
.pbsp-item-thumb img {
  object-fit: contain !important;
  object-position: center;
  background: #fff;
}

.pbsp-product-option__media,
.pbsp-line-thumb-link,
.pbsp-product-thumb,
.pbsp-order-thumb,
.pbsp-quote-thumb,
.pbsp-invoice-thumb,
.pbsp-book-thumb,
.pbsp-selected-product-thumb,
.pbsp-product-image,
.pbsp-item-product-image,
.pbsp-item-thumb {
  background: #fff;
}


/* v1.0.90.146: fit book images inside admin frames without cropping. */
.pbsp-product-option__media,
.pbsp-line-thumb-link,
.pbsp-line-thumb,
.pbsp-product-thumb,
.pbsp-order-thumb,
.pbsp-quote-thumb,
.pbsp-invoice-thumb,
.pbsp-book-thumb,
.pbsp-selected-product-thumb,
.pbsp-product-image,
.pbsp-item-product-image,
.pbsp-item-thumb {
  background: #fff !important;
  overflow: hidden;
}
.pbsp-product-option__img,
.pbsp-line-thumb,
.pbsp-product-thumb img,
.pbsp-order-thumb img,
.pbsp-quote-thumb img,
.pbsp-invoice-thumb img,
.pbsp-book-thumb img,
.pbsp-selected-product-thumb img,
.pbsp-product-image img,
.pbsp-item-product-image img,
.pbsp-item-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: #fff !important;
}

/* v1.0.90.150: compact fast-payment SMS toggle at the top of quote modal */
.pbsp-qw-quote-form .pbsp-quote-top-tools{
  display:flex;
  justify-content:flex-start;
  align-items:center;
  margin:-0.35rem 0 0.85rem;
}
.pbsp-qw-quote-form .pbsp-payment-sms-mini-toggle{
  display:inline-flex;
  align-items:center;
  gap:6px;
  max-width:100%;
  padding:6px 10px;
  border:1px solid var(--gray-200);
  border-radius:999px;
  background:var(--gray-50);
  color:var(--gray-700);
  font-size:12px;
  font-weight:600;
  line-height:1.35;
  white-space:nowrap;
  cursor:pointer;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.pbsp-qw-quote-form .pbsp-payment-sms-mini-toggle:hover{
  background:#fff;
  border-color:var(--primary-200, var(--gray-300));
}
.pbsp-qw-quote-form .pbsp-payment-sms-mini-toggle input{
  margin:0;
  width:14px;
  height:14px;
  flex:0 0 auto;
}
.pbsp-qw-quote-form .pbsp-payment-sms-mini-toggle span{
  overflow:hidden;
  text-overflow:ellipsis;
}
@media (max-width: 520px){
  .pbsp-qw-quote-form .pbsp-payment-sms-mini-toggle{
    font-size:11px;
    padding:5px 8px;
  }
}

/* v1.0.90.188 - fix invoice items file-stock/formula headers and file stock badge resolution */
.pbsp-doc-toolbar-extra{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:420px;}
.pbsp-doc-customer-type-filter{display:flex;align-items:center;gap:6px;margin:0;white-space:nowrap;}
.pbsp-doc-customer-type-filter select{min-width:140px;max-width:180px;}
.pbsp-doc-summary{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.pbsp-doc-summary-pill{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid #dbe3ef;border-radius:999px;background:#fff;color:#1f2937;font-size:12px;line-height:1.2;box-shadow:0 1px 2px rgba(15,23,42,.04);}
.pbsp-sortable-th{cursor:pointer;user-select:none;position:relative;}
.pbsp-sortable-th:after{content:'⇅';font-size:10px;opacity:.45;margin-inline-start:5px;}
.pbsp-col-customer{width:16%;}
.pbsp-col-description{width:18%;}
.pbsp-desc-cell{max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pbsp-quote-description-row textarea{width:100%;min-height:54px;resize:vertical;}
.pbsp-file-stock-badge{display:inline-flex;align-items:center;justify-content:center;min-width:54px;border-radius:999px;padding:3px 8px;font-size:11px;border:1px solid #d1d5db;background:#f8fafc;color:#374151;}
.pbsp-file-stock-yes{border-color:#86efac;background:#ecfdf5;color:#166534;}
.pbsp-file-stock-no{border-color:#fecaca;background:#fef2f2;color:#991b1b;}
.pbsp-file-stock-unknown{border-color:#e5e7eb;background:#f9fafb;color:#6b7280;}
@media (max-width: 960px){.pbsp-doc-toolbar-extra{min-width:0;width:100%;}.pbsp-doc-summary-pill{font-size:11px}.pbsp-doc-customer-type-filter select{min-width:120px}}


/* v1.0.90.189 - offline queue manual delete action */
.pbsp-offline-row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.pbsp-offline-row-actions .pbsp-offline-delete-job {
  color: #b32d2e;
  border-color: #d63638;
}
.pbsp-offline-row-actions .pbsp-offline-delete-job:hover,
.pbsp-offline-row-actions .pbsp-offline-delete-job:focus {
  color: #fff;
  background: #d63638;
  border-color: #d63638;
}

/* v1.0.90.191 - formula column: show only formula name; show expression in LTR tooltip */
.pbsp-doc-view .pbsp-card {
  overflow: visible;
}
.pbsp-formula-cell {
  position: relative;
  overflow: visible;
  white-space: nowrap;
}
.pbsp-formula-tooltip {
  position: relative;
  display: inline-flex;
  align-items: center;
  max-width: 180px;
  cursor: help;
  vertical-align: middle;
  outline: none;
}
.pbsp-formula-tooltip .pbsp-formula-name,
.pbsp-formula-name {
  display: inline-block;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pbsp-formula-tooltip .pbsp-formula-name {
  border-bottom: 1px dashed #94a3b8;
}
.pbsp-formula-tooltip-box {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 8px);
  transform: translateX(-50%);
  z-index: 99999;
  display: none;
  min-width: 220px;
  max-width: 420px;
  padding: 8px 10px;
  border-radius: 10px;
  background: #111827;
  color: #fff;
  box-shadow: 0 10px 26px rgba(15, 23, 42, .22);
  text-align: left;
  direction: ltr;
  unicode-bidi: plaintext;
  white-space: normal;
  line-height: 1.6;
}
.pbsp-formula-tooltip-box::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: #111827;
}
.pbsp-formula-tooltip-box code {
  color: inherit;
  background: transparent;
  direction: ltr;
  unicode-bidi: plaintext;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
}
.pbsp-formula-tooltip:hover .pbsp-formula-tooltip-box,
.pbsp-formula-tooltip:focus .pbsp-formula-tooltip-box,
.pbsp-formula-tooltip:focus-within .pbsp-formula-tooltip-box {
  display: block;
}

.pbsp-sortable-th[data-sort-dir="asc"]:after{content:'↑';opacity:.85;}
.pbsp-sortable-th[data-sort-dir="desc"]:after{content:'↓';opacity:.85;}

/* v1.0.90.196 - compact one-line invoice list layout */
.pbsp-invoices-list-table {
  table-layout: fixed;
  width: 100%;
}
.pbsp-invoices-list-table th,
.pbsp-invoices-list-table td {
  padding: 7px 6px;
  font-size: 12px;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}
.pbsp-invoices-list-table .pbsp-inv-col-number { width: 8%; }
.pbsp-invoices-list-table .pbsp-inv-col-customer { width: 12%; }
.pbsp-invoices-list-table .pbsp-inv-col-status { width: 8%; }
.pbsp-invoices-list-table .pbsp-inv-col-date { width: 10%; }
.pbsp-invoices-list-table .pbsp-inv-col-total { width: 10%; }
.pbsp-invoices-list-table .pbsp-inv-col-paid { width: 9%; }
.pbsp-invoices-list-table .pbsp-inv-col-due { width: 9%; }
.pbsp-invoices-list-table .pbsp-inv-col-order { width: 6%; }
.pbsp-invoices-list-table .pbsp-inv-col-source { width: 7%; }
.pbsp-invoices-list-table .pbsp-inv-col-desc { width: 10%; }
.pbsp-invoices-list-table .pbsp-inv-col-actions { width: 11%; }
.pbsp-invoices-list-table .pbsp-inv-cell-customer,
.pbsp-invoices-list-table .pbsp-inv-cell-desc,
.pbsp-invoices-list-table .pbsp-inv-cell-number,
.pbsp-invoices-list-table .pbsp-inv-cell-date,
.pbsp-invoices-list-table .pbsp-inv-cell-order,
.pbsp-invoices-list-table .pbsp-inv-cell-money {
  max-width: 100%;
}
.pbsp-invoices-list-table .pbsp-inv-cell-actions {
  overflow: visible;
  text-overflow: clip;
  white-space: nowrap;
}
.pbsp-invoices-list-table .pbsp-icon-button.button.button-small {
  min-width: 24px;
  width: 24px;
  height: 24px;
  padding: 0 2px;
  font-size: 12px;
  margin-inline-start: 2px;
}
.pbsp-invoices-list-table .pbsp-status-badge {
  max-width: 100%;
  padding: 2px 6px;
  font-size: 11px;
  gap: 4px;
}
.pbsp-invoices-list-table .pbsp-status-badge::before {
  width: 6px;
  height: 6px;
}
.pbsp-invoices-list-table .pbsp-desc-cell {
  max-width: none;
}
@media (max-width: 1280px) {
  .pbsp-invoices-list-table th,
  .pbsp-invoices-list-table td {
    font-size: 11px;
    padding: 6px 4px;
  }
  .pbsp-invoices-list-table .pbsp-status-badge {
    font-size: 10px;
    padding-inline: 5px;
  }
}


/* Force the uploaded font across the standalone backend panel UI. */
body.pbsp-panel-page,
body.pbsp-panel-page #pbsp-app,
body.pbsp-panel-page #pbsp-app button,
body.pbsp-panel-page #pbsp-app input,
body.pbsp-panel-page #pbsp-app select,
body.pbsp-panel-page #pbsp-app textarea,
body.pbsp-panel-page #pbsp-app table,
body.pbsp-panel-page #pbsp-app .select2-container,
body.pbsp-panel-page #pbsp-app .select2-container * {
  font-family: var(--pbsp-panel-font) !important;
}

/* Keep WordPress/editor/icon fonts intact. */
body.pbsp-panel-page #pbsp-app .dashicons,
body.pbsp-panel-page #pbsp-app .dashicons-before::before,
body.pbsp-panel-page #pbsp-app [class^="dashicons-"],
body.pbsp-panel-page #pbsp-app [class*=" dashicons-"] {
  font-family: dashicons !important;
}

body.pbsp-panel-page #pbsp-app .mce-ico,
body.pbsp-panel-page #pbsp-app i.mce-i-fw {
  font-family: tinymce, Arial, sans-serif !important;
}

body.pbsp-panel-page #pbsp-app code,
body.pbsp-panel-page #pbsp-app pre,
body.pbsp-panel-page #pbsp-app kbd,
body.pbsp-panel-page #pbsp-app samp,
body.pbsp-panel-page #pbsp-app .pbsp-code,
body.pbsp-panel-page #pbsp-app .pbsp-monospace {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace !important;
}

