/* Product Library module. All selectors are scoped to prodLib ids/classes. */
#prodLibSection .prodLib-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

#invoiceSystem {
  font-size: 14px;
  line-height: 1.45;
}

#invoiceSystem .invoice-head {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

#invoiceSystem .invoice-head h2 {
  font-size: 24px;
  line-height: 1.2;
  margin: 0 0 4px;
}

#invoiceSystem .invoice-head p {
  font-size: 14px;
  margin: 0;
}

#invoiceSystem .invoice-stats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 14px;
}

#invoiceSystem .stat {
  min-height: auto;
}

#invoiceSystem .stat .label {
  font-size: 12px;
}

#invoiceSystem .stat .value {
  font-size: 22px;
  line-height: 1.2;
}

#invoiceSystem .invoice-panel {
  background: #fff;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  margin-bottom: 14px;
  padding: 14px;
}

#invoiceSystem .invoice-panel h3 {
  font-size: 16px;
  line-height: 1.25;
  margin: 0 0 10px;
}

#invoiceSystem .invoice-action-row {
  align-items: end;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(220px, 1fr);
  margin-bottom: 14px;
}

#invoiceSystem .invoice-action-select {
  display: grid;
  gap: 6px;
  margin: 0;
}

#invoiceSystem .invoice-action-select .lbl {
  color: #374151;
  font-size: 13px;
  font-weight: 800;
}

#invoiceSystem .invoice-action-select select {
  min-height: 38px;
}

#invoiceSystem .invoice-send-btn {
  min-height: 38px;
  min-width: 112px;
}

#invoiceSystem .invoice-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: 1fr;
  align-items: start;
}

#invoiceSystem .invoice-form-section,
#invoiceSystem .invoice-subpanel,
#invoiceSystem .invoice-preview-card,
#invoiceSystem .invoice-record-embed {
  background: #fff;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  margin-bottom: 12px;
  padding: 12px;
}

#invoiceSystem .invoice-accordion {
  background: #fff;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  margin-bottom: 12px;
  overflow: hidden;
}

#invoiceSystem .invoice-accordion summary {
  align-items: center;
  background: #eef4ff;
  color: #15375f;
  cursor: pointer;
  display: flex;
  font-size: 15px;
  font-weight: 800;
  justify-content: space-between;
  line-height: 1.25;
  list-style: none;
  min-height: 46px;
  padding: 12px 14px;
}

#invoiceSystem .invoice-accordion summary::-webkit-details-marker {
  display: none;
}

#invoiceSystem .invoice-accordion summary::after {
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 999px;
  color: #374151;
  content: "展開";
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  padding: 6px 9px;
}

#invoiceSystem .invoice-accordion[open] summary::after {
  content: "收合";
}

#invoiceSystem .invoice-accordion-query summary {
  background: #eaf3ff;
}

#invoiceSystem .invoice-accordion-list summary {
  background: #eaf7ef;
  color: #14532d;
}

#invoiceSystem .invoice-accordion-file summary {
  background: #eef4ff;
  color: #15375f;
}

#invoiceSystem .invoice-accordion-print summary {
  background: #f5edff;
  color: #4c1d95;
}

#invoiceSystem .invoice-accordion-body {
  border-top: 1px solid var(--border, #e5e7eb);
  padding: 12px;
}

#invoiceSystem .invoice-accordion-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}

#invoiceSystem .invoice-query-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

#invoiceSystem .invoice-list-grid {
  align-items: end;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

#invoiceSystem .invoice-download-grid {
  align-items: end;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

#invoiceSystem .invoice-date-control {
  align-items: center;
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) auto;
  position: relative;
}

#invoiceSystem .invoice-calendar-btn {
  min-height: 36px;
  white-space: nowrap;
}

#invoiceSystem .invoice-date-native {
  height: 1px;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 100%;
  width: 1px;
}

#invoiceSystem .invoice-form-section h4 {
  font-size: 15px;
  line-height: 1.25;
  margin: 0 0 10px;
}

#invoiceSystem .invoice-mode-toggle {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 12px;
}

#invoiceSystem .invoice-mode-btn {
  align-items: center;
  background: #fff;
  border: 1px solid #d8e0ea;
  border-radius: 8px;
  color: #334155;
  cursor: pointer;
  display: flex;
  gap: 10px;
  min-height: 58px;
  padding: 10px 12px;
  text-align: left;
}

#invoiceSystem .invoice-mode-btn strong {
  display: block;
  font-size: 14px;
  line-height: 1.2;
}

#invoiceSystem .invoice-mode-btn small {
  color: #64748b;
  display: block;
  font-size: 12px;
  margin-top: 3px;
}

#invoiceSystem .invoice-mode-btn.is-active {
  background: #eff6ff;
  border-color: #2563eb;
  box-shadow: inset 0 0 0 1px #2563eb;
  color: #1d4ed8;
}

#invoiceSystem .invoice-mode-icon {
  align-items: center;
  background: #f1f5f9;
  border-radius: 8px;
  color: currentColor;
  display: inline-flex;
  flex: 0 0 auto;
  height: 34px;
  justify-content: center;
  width: 34px;
}

#invoiceSystem .invoice-mode-btn.is-active .invoice-mode-icon {
  background: #dbeafe;
}

#invoiceSystem .invoice-basic-grid {
  align-items: end;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

#invoiceSystem .invoice-basic-grid.is-b2b {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

#invoiceSystem .invoice-basic-remark {
  grid-template-columns: 1fr;
  margin-top: 10px;
}

#invoiceSystem .invoice-ban-status {
  color: #64748b;
  font-size: 12px;
  font-weight: 500;
  margin-left: 8px;
}

#invoiceSystem .invoice-ban-status.is-loading {
  color: #2563eb;
}

#invoiceSystem .invoice-ban-status.is-found {
  color: #047857;
}

#invoiceSystem .invoice-ban-status.is-not-found,
#invoiceSystem .invoice-ban-status.is-error {
  color: #b45309;
}

#invoiceSystem .invoice-subpanel-head {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin-bottom: 8px;
}

#invoiceSystem .invoice-help {
  color: #6b7280;
  display: block;
  font-size: 12px;
  margin-top: 4px;
}

#invoiceSystem .req {
  color: #dc2626;
  margin-left: 3px;
}

#invoiceSystem .invoice-calc-row,
#invoiceSystem .invoice-preview-actions {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 10px;
}

#invoiceSystem .invoice-calc-row {
  justify-content: flex-start;
}

#invoiceSystem .invoice-errors {
  background: #fff1f2;
  border: 1px solid #fecaca;
  border-radius: 8px;
  color: #991b1b;
  margin-bottom: 10px;
  padding: 10px;
}

#invoiceSystem .invoice-errors ul {
  margin: 6px 0 0 18px;
  padding: 0;
}

#invoiceSystem .invoice-preview-summary,
#invoiceSystem .invoice-total-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  margin-bottom: 10px;
}

#invoiceSystem .invoice-preview-title {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin-bottom: 10px;
}

#invoiceSystem .invoice-item-table,
#invoiceSystem .invoice-preview-table {
  min-width: 820px;
  width: 100%;
}

#invoiceSystem .form-grid {
  gap: 10px;
}

#invoiceSystem label .lbl {
  font-size: 13px;
}

#invoiceSystem input,
#invoiceSystem select,
#invoiceSystem textarea {
  font-size: 14px;
}

#invoiceSystem .table-wrap {
  max-height: none;
}

#invoiceSystem .grid-excel th,
#invoiceSystem .grid-excel td {
  font-size: 13px;
  padding: 8px;
}

#invoiceSystem .invoice-result {
  background: #fafafa;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  min-height: 96px;
  padding: 10px;
}

#invoiceSystem .invoice-record-table {
  min-width: 900px;
  width: 100%;
}

#invoiceSystem .invoice-query-result-table {
  min-width: 1120px;
  width: 100%;
}

#invoiceSystem .invoice-record-table button {
  margin: 2px;
}

@media (max-width: 900px) {
  #invoiceSystem .invoice-stats {
    grid-template-columns: 1fr;
  }

  #invoiceSystem .invoice-action-row,
  #invoiceSystem .invoice-grid,
  #invoiceSystem .invoice-basic-grid,
  #invoiceSystem .invoice-mode-toggle,
  #invoiceSystem .invoice-query-grid,
  #invoiceSystem .invoice-list-grid,
  #invoiceSystem .invoice-download-grid {
    grid-template-columns: 1fr;
  }

  #invoiceSystem .invoice-send-btn,
  #invoiceSystem .invoice-accordion-actions .primary {
    width: 100%;
  }
}

#prodLibSection .prodLib-head h2 {
  margin: 0;
}

#prodLibSection .prodLib-head .muted {
  margin-top: 4px;
}

#prodLibSection .prodLib-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 10px 0 12px;
}

#prodLibSection .prodLib-toolbar input,
#prodLibSection .prodLib-toolbar select {
  min-height: 38px;
}

#prodLibSection .prodLib-toolbar .grow {
  flex: 1 1 260px;
}

#prodLibSection .prodLib-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

#prodLibTable {
  width: 100%;
  table-layout: fixed;
}

#prodLibTable th,
#prodLibTable td {
  vertical-align: top;
}

#prodLibTable .prodLib-col-name {
  width: 20%;
}

#prodLibTable .prodLib-col-select {
  width: 44px;
}

#prodLibTable .prodLib-col-meta {
  width: 15%;
}

#prodLibTable .prodLib-col-price {
  width: 12%;
}

#prodLibTable .prodLib-col-copy {
  width: 20%;
}

#prodLibTable .prodLib-col-actions {
  width: 18%;
}

#prodLibTable .prodLib-select-col {
  text-align: center;
  vertical-align: middle;
}

#prodLibTable .prodLib-select-col input {
  width: 18px;
  height: 18px;
}

.prodLib-product-title {
  font-weight: 800;
  line-height: 1.35;
}

.prodLib-product-sub {
  font-size: 12px;
  color: #6b7280;
  margin-top: 3px;
  word-break: break-word;
}

.prodLib-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 6px;
}

.prodLib-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 2px 8px;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 999px;
  background: #fff;
  color: #374151;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.prodLib-badge.ok {
  border-color: #a7f3d0;
  background: #ecfdf5;
  color: #065f46;
}

.prodLib-badge.warn {
  border-color: #fde68a;
  background: #fffbeb;
  color: #78350f;
}

.prodLib-badge.muted {
  border-color: #e5e7eb;
  background: #f9fafb;
  color: #6b7280;
}

.prodLib-price {
  font-weight: 800;
  color: #7f1d1d;
}

.prodLib-product-cell {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.prodLib-row-thumb {
  flex: 0 0 54px;
  width: 54px;
  height: 54px;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 6px;
  object-fit: cover;
  background: #f9fafb;
}

.prodLib-row-thumb.empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #9ca3af;
  font-size: 12px;
}

.prodLib-mini {
  color: #6b7280;
  font-size: 12px;
  line-height: 1.45;
}

.prodLib-link {
  color: var(--primary, #A98B60);
  text-decoration: none;
  word-break: break-all;
}

.prodLib-link:hover {
  text-decoration: underline;
}

.prodLib-copy-grid,
.prodLib-row-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.prodLib-copy-grid button,
.prodLib-row-actions button {
  min-height: 32px;
  padding: 6px 8px;
  font-size: 12px;
  white-space: normal;
}

.prodLib-empty {
  padding: 28px 12px;
  text-align: center;
  color: #6b7280;
}

#prodLibModal .dialog,
#prodLibViewModal .dialog {
  max-width: 1120px;
  width: min(1120px, calc(100vw - 24px));
}

#prodLibForm .form-grid {
  align-items: start;
}

#prodLibForm textarea {
  min-height: 76px;
  resize: vertical;
}

#prodLibForm .prodLib-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  padding: 8px 0;
}

#prodLibForm .prodLib-checks label {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  margin: 0;
  font-weight: 700;
}

.prodLib-range-fields {
  display: grid;
  grid-template-columns: 1fr 96px auto 96px auto;
  gap: 6px;
  align-items: center;
}

.prodLib-range-fields .lbl {
  grid-column: 1 / -1;
}

.prodLib-list-block {
  min-width: 0;
}

.prodLib-list-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin: 4px 0 8px;
}

.prodLib-list-head button {
  width: auto;
  flex: 0 0 auto;
}

.prodLib-edit-table {
  min-width: 760px;
  width: 100%;
}

.prodLib-variant-edit-table {
  min-width: 1320px;
}

.prodLib-edit-table input {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.prodLib-edit-table select {
  width: 100%;
  min-width: 72px;
  box-sizing: border-box;
}

.prodLib-image-block {
  min-width: 0;
}

.prodLib-image-inputs {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.prodLib-image-inputs input {
  flex: 1 1 320px;
}

.prodLib-image-cell {
  flex: 0 0 auto;
  width: 140px;
  height: 140px;
}

.prodLib-image-thumb,
.prodLib-var-thumb {
  width: 100%;
  height: 100%;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  background: #f9fafb;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.prodLib-image-thumb img,
.prodLib-var-thumb img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.prodLib-var-cell {
  width: 104px;
  height: 78px;
  margin: auto;
}

.prodLib-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
  flex-wrap: wrap;
}

.prodLib-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 14px;
}

.prodLib-detail-item {
  border-bottom: 1px dashed var(--border, #e5e7eb);
  padding-bottom: 8px;
}

.prodLib-detail-item.full {
  grid-column: 1 / -1;
}

.prodLib-detail-label {
  display: block;
  color: #6b7280;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 3px;
}

.prodLib-detail-value {
  white-space: pre-wrap;
  word-break: break-word;
}

.prodLib-detail-table {
  width: 100%;
  min-width: 620px;
}

.prodLib-variant-detail-table {
  min-width: 1040px;
}

.prodLib-spec-photo {
  width: 72px;
  height: 72px;
  object-fit: contain;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 6px;
  background: #f9fafb;
}

.prodLib-image-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
}

.prodLib-image-gallery figure {
  margin: 0;
}

.prodLib-image-gallery img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 6px;
  background: #f9fafb;
}

.prodLib-image-gallery figcaption {
  margin-top: 4px;
  color: #6b7280;
  font-size: 12px;
  line-height: 1.35;
}

.prodLib-inv-summary {
  margin-bottom: 8px;
  font-weight: 800;
}

.prodLib-inv-link-table {
  min-width: 980px;
}

.prodLib-detail-actions {
  margin-top: 8px;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.prodLib-copy-dialog {
  max-width: 560px;
}

.prodLib-copy-preview {
  margin-top: 10px;
  padding: 10px;
  border: 1px dashed var(--border, #e5e7eb);
  border-radius: 6px;
  background: #f9fafb;
  color: #374151;
  min-height: 72px;
  white-space: pre-wrap;
}

.prodLib-image-preview {
  display: block;
  max-width: 220px;
  max-height: 160px;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  object-fit: cover;
  background: #f9fafb;
}

@media (max-width: 760px) {
  #prodLibSection .prodLib-head {
    display: block;
  }

  #prodLibSection .prodLib-head button {
    width: 100%;
    margin-top: 10px;
  }

  #prodLibSection .stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #prodLibSection .prodLib-toolbar {
    display: grid;
    grid-template-columns: 1fr;
  }

  #prodLibSection .prodLib-toolbar input,
  #prodLibSection .prodLib-toolbar select,
  #prodLibSection .prodLib-toolbar button {
    width: 100%;
    box-sizing: border-box;
  }

  #prodLibTable,
  #prodLibTable thead,
  #prodLibTable tbody,
  #prodLibTable tr,
  #prodLibTable th,
  #prodLibTable td {
    display: block;
  }

  #prodLibTable thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
  }

  #prodLibTable tr {
    border: 1px solid var(--border, #e5e7eb);
    border-radius: 8px;
    background: #fff;
    margin: 10px 0;
    padding: 8px;
  }

  #prodLibTable td {
    border: 0;
    padding: 8px 4px;
  }

  #prodLibTable td::before {
    content: attr(data-label);
    display: block;
    color: #6b7280;
    font-size: 12px;
    font-weight: 800;
    margin-bottom: 4px;
  }

  .prodLib-copy-grid,
  .prodLib-row-actions {
    grid-template-columns: 1fr;
  }

  .prodLib-product-cell {
    align-items: center;
  }

  .prodLib-range-fields {
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto;
  }

  .prodLib-range-fields .lbl {
    grid-column: 1 / -1;
  }

  .prodLib-list-head {
    align-items: stretch;
    flex-direction: column;
  }

  .prodLib-list-head button {
    width: 100%;
  }

  .prodLib-image-inputs {
    display: grid;
    grid-template-columns: 1fr;
  }

  .prodLib-detail-grid {
    grid-template-columns: 1fr;
  }
}
