/* ===========================================
   Editor Page Styles
   =========================================== */

/* Highlight zone in preview */
.highlight-zone {
  transition: all 0.2s ease;
  padding: 1px 3px;
  border-radius: 3px;
  position: relative;
}
.highlight-active {
  background-color: rgba(59, 130, 246, 0.15);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.4);
  display: inline-block;
}
.empty-field {
  color: #475569;
  border-bottom: 1px dashed #94a3b8;
  padding-bottom: 1px;
}

/* Document title */
.doc-title {
  font-size: 16pt; font-weight: bold; text-transform: uppercase;
  text-align: center; margin-top: 1.5cm; margin-bottom: 1cm; letter-spacing: 0.05em;
}

/* Logo upload area */
.logo-upload-area {
  display: flex; flex-direction: column; gap: var(--space-3);
  padding: var(--space-4); background: var(--bg-surface-sunken);
  border-radius: var(--radius-md); border: 1px dashed var(--border-strong);
}
.logo-file-input { width: 100%; font-size: var(--text-sm); color: var(--text-secondary); }
.logo-file-input::file-selector-button {
  margin-right: var(--space-4); padding: 5px var(--space-4);
  border-radius: var(--radius-md); border: 1px solid var(--border-strong);
  font-size: var(--text-xs); font-weight: var(--weight-semibold);
  background: var(--bg-surface-raised); color: var(--text-primary);
  cursor: pointer; transition: all var(--transition-fast);
}
.logo-file-input::file-selector-button:hover {
  background: var(--bg-surface-hover); color: var(--color-primary-400);
}
.logo-range {
  width: 100%; height: 4px; border-radius: var(--radius-full); appearance: none;
  background: var(--border-strong); cursor: pointer;
}
.logo-range::-webkit-slider-thumb {
  appearance: none; width: 16px; height: 16px; border-radius: 50%;
  background: var(--color-primary-500); cursor: pointer;
  box-shadow: 0 2px 6px rgba(59,130,246,0.4);
}

/* Payment table in preview */
.pay-table { width: 100%; border-collapse: collapse; margin: 12px 0; font-size: 10.5pt; }
.pay-table th {
  background-color: #f1f5f9; color: #0f172a; padding: 8px 12px;
  text-align: left; font-weight: 600; border-bottom: 2px solid #cbd5e1;
}
.pay-table th:last-child { text-align: right; }
.pay-table td { padding: 8px 12px; border-bottom: 1px solid #e2e8f0; }
.pay-table td:last-child { text-align: right; font-variant-numeric: tabular-nums; }
.pay-table tr:hover td { background-color: #f8fafc; }
.pay-table .total-row td { background-color: #f1f5f9 !important; font-weight: bold; border-top: 2px solid #cbd5e1; }

/* Payment rows in sidebar */
.payment-row {
  display: flex; gap: var(--space-2); align-items: center;
  background: var(--bg-surface-sunken); padding: var(--space-2);
  border-radius: var(--radius-md); border: 1px solid var(--border-default);
}
.payment-row .select, .payment-row .input {
  padding: 5px var(--space-2); font-size: var(--text-xs);
  border-color: transparent; background: var(--bg-surface-raised);
}
.payment-row .select:focus, .payment-row .input:focus { border-color: var(--color-primary-500); }
.payment-remove {
  color: var(--color-danger-400); background: transparent; border: none;
  cursor: pointer; font-size: 0.9rem; padding: var(--space-1);
  border-radius: var(--radius-sm); transition: all var(--transition-fast);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.payment-remove:hover { background: rgba(239,68,68,0.1); }

/* Auto-fill section */
.autofill-section {
  display: flex; flex-direction: column; gap: var(--space-3);
  padding-bottom: var(--space-4); border-bottom: 1px solid var(--border-default);
}

/* Header in doc preview */
#header-left-content { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.2; }
.preview-logo { max-height: 100px; object-fit: contain; transition: width 0.3s; margin-bottom: 8px; }
