/**
 * Product Table Styles - Optimized & Responsive
 * All styles with !important to prevent theme/plugin conflicts
 * @version 2.0.0
 */

/* ============= Font ============= */
@font-face {
  font-family: 'IranSans';
  src: url('../../fonts/IranSans-Medium.woff2') format('woff2'),
       url('../../fonts/IranSans-Medium.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* ============= Variables ============= */
:root {
  --primary-color: #FE8400 !important;
  --header-bg: #1C39BB !important;
  --border-color: #ccc !important;
  --shadow: 0 2px 10px rgba(0,0,0,0.1) !important;
  --hover-bg: #fdbb73 !important;
  --alt-row-bg: #fffbee !important;
  --font-family: IranSans,  sans-serif, Tahoma !important;
}

/* ============= Container ============= */
.product-table-container {
  max-width: 94% !important;
  margin: 40px auto !important;
  padding: 20px !important;
  background: #fff !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 5px !important;
  box-shadow: var(--shadow) !important;
  font-family: var(--font-family) !important;
  direction: rtl !important;
  display: block !important;
  box-sizing: border-box !important;
}

/* ============= Header ============= */
.table-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-bottom: 20px !important;
}

.table-header h2 {
  font-size: clamp(18px, 4vw, 24px) !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--font-family) !important;
  font-weight: bold !important;
  color: #333 !important;
  line-height: 1.4 !important;
}

.update-date {
  font-size: 14px !important;
  color: #666 !important;
  font-family: var(--font-family) !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.4 !important;
}

/* ============= VAT Checkbox ============= */
.vat-checkbox-container {
  margin-bottom: 20px !important;
  margin-top: 0 !important;
  text-align: right !important;
  padding: 0 !important;
}

.vat-checkbox-container label {
  font-family: var(--font-family) !important;
  font-size: 16px !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.4 !important;
  color: #333 !important;
}

.vat-checkbox {
  cursor: pointer !important;
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  vertical-align: middle !important;
}

/* ============= Table Wrapper ============= */
.product-table-wrapper {
  width: 100% !important;
  overflow-x: hidden !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-width: thin !important;
  scrollbar-color: var(--primary-color) #f1f1f1 !important;
  display: block !important;
  position: relative !important;
}

.product-table-wrapper::-webkit-scrollbar {
  height: 8px !important;
  width: 8px !important;
}

.product-table-wrapper::-webkit-scrollbar-track {
  background: #f1f1f1 !important;
  border-radius: 4px !important;
}

.product-table-wrapper::-webkit-scrollbar-thumb {
  background: var(--primary-color) !important;
  border-radius: 4px !important;
}

.product-table-wrapper::-webkit-scrollbar-thumb:hover {
  background: #ff9900 !important;
}

/* ============= Table ============= */
.product-table {
  width: 100% !important;
  border-collapse: collapse !important;
  font-family: var(--font-family) !important;
  background: #fff !important;
  display: table !important;
  margin: 0 !important;
  padding: 0 !important;
  table-layout: auto !important;
}

.product-table th,
.product-table td {
  border: 1px solid var(--border-color) !important;
  padding: 12px 8px !important;
  text-align: center !important;
  font-size: clamp(12px, 2vw, 14px) !important;
  font-family: var(--font-family) !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  vertical-align: middle !important;
  line-height: 1.5 !important;
  box-sizing: border-box !important;
}

.product-table th {
  background: var(--header-bg) !important;
  color: #fff !important;
  font-weight: bold !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 10 !important;
}

.product-table td {
  background: #fff !important;
  color: #333 !important;
}

.product-table tbody tr:nth-child(even) td {
  background: var(--alt-row-bg) !important;
}

.product-table tbody tr:hover td {
  background: var(--hover-bg) !important;
  transition: background-color 0.2s ease !important;
}

/* ============= Order Button ============= */
.order-button {
  background: var(--primary-color) !important;
  color: #fff !important;
  padding: 8px 16px !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  display: inline-block !important;
  font-family: var(--font-family) !important;
  transition: background-color 0.2s ease !important;
  border: none !important;
  font-size: 14px !important;
  text-decoration: none !important;
  line-height: 1.4 !important;
  font-weight: normal !important;
  text-align: center !important;
}

.order-button:hover {
  background: #ff9900 !important;
  color: #fff !important;
}

/* ============= Price Note ============= */
.price-note {
  text-align: right !important;
  font-size: 14px !important;
  margin-top: 10px !important;
  margin-bottom: 0 !important;
  padding: 0 !important;
  font-family: var(--font-family) !important;
  color: #666 !important;
  line-height: 1.5 !important;
}

/* ============= Auto Scroll Mode ============= */
.product-table-container.scroll-enabled .product-table-wrapper {
  overflow-y: hidden !important;
  scroll-behavior: smooth !important;
  max-height: 400px !important;
}

.product-table-container.scroll-enabled tbody {
  display: block !important;
}

.product-table-container.scroll-enabled thead,
.product-table-container.scroll-enabled tbody tr {
  display: table !important;
  width: 100% !important;
  table-layout: fixed !important;
}

.product-table-container.scroll-enabled thead {
  position: sticky !important;
  top: 0 !important;
  z-index: 20 !important;
  background: var(--header-bg) !important;
}

/* ============= Responsive Design ============= */

/* Tablets */
@media (max-width: 1024px) {
  .product-table-container {
    max-width: 96% !important;
    padding: 15px !important;
    margin: 30px auto !important;
  }

  .product-table th,
  .product-table td {
    padding: 10px 6px !important;
    font-size: 13px !important;
  }

  .table-header h2 {
    font-size: 22px !important;
  }
}

/* Mobile Landscape */
@media (max-width: 768px) {
  .product-table-container {
    max-width: 98% !important;
    margin: 20px auto !important;
    padding: 12px !important;
  }

  .table-header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }

  .table-header h2 {
    font-size: 20px !important;
  }

  .update-date {
    font-size: 12px !important;
  }

  .vat-checkbox-container {
    margin-bottom: 15px !important;
  }

  .vat-checkbox-container label {
    font-size: 14px !important;
  }

  .product-table th,
  .product-table td {
    padding: 8px 4px !important;
    font-size: 12px !important;
  }

  .order-button {
    padding: 6px 12px !important;
    font-size: 12px !important;
  }

  .price-note {
    font-size: 12px !important;
  }
}

/* Mobile Portrait */
@media (max-width: 480px) {
  .product-table-container {
    max-width: 100% !important;
    margin: 10px auto !important;
    padding: 10px !important;
    border-radius: 0 !important;
  }

  .table-header {
    margin-bottom: 15px !important;
  }

  .table-header h2 {
    font-size: 18px !important;
  }

  .update-date {
    font-size: 11px !important;
  }

  .vat-checkbox-container {
    margin-bottom: 12px !important;
  }

  .vat-checkbox-container label {
    font-size: 13px !important;
  }

  .vat-checkbox {
    width: 16px !important;
    height: 16px !important;
  }

  .product-table th,
  .product-table td {
    padding: 6px 3px !important;
    font-size: 11px !important;
  }

  .order-button {
    padding: 5px 10px !important;
    font-size: 11px !important;
  }

  .price-note {
    font-size: 11px !important;
    margin-top: 8px !important;
  }
}

/* Very Small Screens */
@media (max-width: 360px) {
  .product-table-container {
    padding: 8px !important;
  }

  .table-header h2 {
    font-size: 16px !important;
  }

  .update-date {
    font-size: 10px !important;
  }

  .vat-checkbox-container label {
    font-size: 12px !important;
  }

  .product-table th,
  .product-table td {
    padding: 5px 2px !important;
    font-size: 10px !important;
  }

  .order-button {
    padding: 4px 8px !important;
    font-size: 10px !important;
  }

  .price-note {
    font-size: 10px !important;
  }
}

/* ============= Print Styles ============= */
@media print {
  .product-table-container {
    box-shadow: none !important;
    border: 1px solid #000 !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 10px !important;
  }

  .vat-checkbox-container {
    display: none !important;
  }

  .order-button {
    display: none !important;
  }

  .product-table-wrapper {
    overflow: visible !important;
  }

  .product-table tbody tr:hover td {
    background: inherit !important;
  }

  .product-table th {
    background: #1C39BB !important;
    color: #fff !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
}