:root {
    --bg: #f6f7fb;
    --panel: #ffffff;
    --panel-2: #ffffff;
    --text: #0f172a;
    --muted: #475569;
    --border: #e2e8f0;
    --primary: #2563eb;
    --primary-700: #1d4ed8;
    --accent: #06b6d4;
    --success: #16a34a;
    --warning: #d97706;
    --danger: #dc2626;
}

html, body {
    height: 100%;
}

body {
    background: var(--bg);
    color: var(--text);
    font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
    line-height: 1.4;
}

.orders-wrap {
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--panel);
    padding: 16px;
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.06);
    display: flex;
    flex-direction: column;
    height: calc(100vh - 32px);
    max-height: calc(100vh - 32px);
}

.orders-scroll {
    overflow-y: auto;
    overflow-x: auto; /* allow horizontal scroll as a fallback to prevent off-screen overflow */
    flex: 1;
    min-height: 0;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--panel-2);
}

.table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    table-layout: fixed; /* prevent columns from expanding beyond allocated width */
}

/* Adjust column widths to give more space to 'Nazwa produktu' (now 4th column)
   Use max-widths for most to prevent overflow causing horizontal scroll */
.table thead th:nth-child(1),
.table tbody td:nth-child(1) { max-width: 42px; text-align: center; }
.table thead th:nth-child(2),
.table tbody td:nth-child(2) { max-width: 100px; }
.table thead th:nth-child(3),
.table tbody td:nth-child(3) { max-width: 160px; }
.table thead th:nth-child(4),
.table tbody td:nth-child(4) { max-width: 110px; }
.table thead th:nth-child(5),
.table tbody td:nth-child(5) { width: 30%; min-width: 220px; }
.table thead th:nth-child(6),
.table tbody td:nth-child(6) { max-width: 130px; }
.table thead th:nth-child(7),
.table tbody td:nth-child(7) { max-width: 80px; text-align: center; }
.table thead th:nth-child(8),
.table tbody td:nth-child(8) { max-width: 150px; }
.table thead th:nth-child(9),
.table tbody td:nth-child(9) { max-width: 110px; }
.table thead th:nth-child(10),
.table tbody td:nth-child(10) { max-width: 140px; }
.table thead th:nth-child(11),
.table tbody td:nth-child(11) { max-width: 180px; }
.table thead th:nth-child(12),
.table tbody td:nth-child(12) { max-width: 140px; }

/* Allow wrapping for payment status column (11th) so content doesn't overflow */
.table thead th:nth-child(11),
.table tbody td:nth-child(11) {
    white-space: normal;          /* enable multi-line */
    overflow-wrap: break-word;    /* prefer breaking at word boundaries; break long tokens only if needed */
    word-break: normal;           /* do not break between letters by default */
    hyphens: auto;                /* allow hyphenation where supported */
}

/* Allow wrapping for EAN column (12th) */
.table thead th:nth-child(12),
.table tbody td:nth-child(12) {
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

/* Allow wrapping only in the header cell of the 9th column (Status u producenta) */
.table thead th:nth-child(9) {
    white-space: normal; /* enable wrap */
    overflow-wrap: anywhere; /* break long words if needed */
}

/* Allow wrapping for the body cells of the 9th column so producer status labels don't overflow */
.table tbody td:nth-child(9) {
    white-space: normal;          /* enable multi-line */
    overflow-wrap: break-word;    /* prefer breaking at word boundaries; break long tokens only if needed */
    word-break: normal;           /* avoid breaking each letter */
    hyphens: auto;                /* nicer hyphenation */
}

/* Ułóż badge i przycisk Pomiń w kolumnie w 9. komórce */
.producer-status-cell {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
}

/* Nie łam tekstu w badge statusu (np. "Do zamówienia") */
.producer-status-cell .badge {
    white-space: normal;        /* allow wrapping on multiple lines */
    overflow-wrap: break-word;  /* break long words if needed */
    word-break: normal;
    hyphens: auto;
    max-width: 100%;
}

/* Wiersze nie są już globalnie klikalne */
.table tbody tr { cursor: default; }

/* Komórka z checkboxem wiersza jest klikalna jak przycisk */
.row-check-cell { text-align: center; cursor: pointer; }
.row-check-cell .row-check { cursor: pointer; }

.table th, .table td {
    padding: 10px 12px;
    border-bottom: 1px solid #eef2f7;
    vertical-align: top;
    text-align: left;
    font-size: 14px;
    overflow-wrap: break-word; /* allow wrapping at word boundaries */
    word-break: normal;        /* do not break every letter */
    hyphens: auto;             /* nicer hyphenation for long words */
}

.table thead th {
    position: sticky;
    top: 0;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    z-index: 1;
    border-bottom: 1px solid #e2e8f0;
    text-align: center;
}

.table tbody tr:hover {
    background: #f8fafc;
}

/* Row backgrounds based on producer status */
.table tbody tr.producer-status-zamowione {
    background: #f0fdf4;
    border-left: 4px solid #16a34a;
}

.table tbody tr.producer-status-zamowione:hover {
    background: #dcfce7;
}

/* Keep default white background for "do zamówienia" and "pomiń" */
.table tbody tr.producer-status-do_zamowienia {
    background: #ffffff;
}

.table tbody tr.producer-status-pomin {
    background: #ffffff;
}

/* Hover styles for all producer statuses */
.table tbody tr.producer-status-do_zamowienia:hover {
    background: #f8fafc;
}

.table tbody tr.producer-status-pomin:hover {
    background: #f8fafc;
}

/* Selection styles - higher specificity to override producer status backgrounds */
.table tbody tr.row-selected.producer-status-zamowione {
    background: #dcfce7 !important;
    border-left: 4px solid #16a34a;
}

.table tbody tr.row-selected.producer-status-do_zamowienia {
    background: #e6f2ff !important;
}

.table tbody tr.row-selected.producer-status-pomin {
    background: #e6f2ff !important;
}

/* Fallback for row-selected without producer status class */
.table tbody tr.row-selected {
    background: #e6f2ff;
}

/* Hover styles for selected rows */
.table tbody tr.row-selected.producer-status-zamowione:hover {
    background: #bbf7d0 !important;
}

.table tbody tr.row-selected.producer-status-do_zamowienia:hover {
    background: #dbeafe !important;
}

.table tbody tr.row-selected.producer-status-pomin:hover {
    background: #dbeafe !important;
}

.table tbody tr.row-selected:hover {
    background: #dbeafe;
}

/* Larger, easier-to-click checkboxes in the table (header + rows) */
.table input[type="checkbox"] {
    width: 20px;
    height: 20px;
    cursor: pointer;
    accent-color: var(--primary);
}

/* Dodatkowy margines dla przycisku Pomiń pod badge */
.btn-skip {
  margin-top: 6px;
  padding: 2px 6px;
  font-size: 11px;
  line-height: 1.2;
  border-radius: 6px;
}

/* Wymuś kompaktowy rozmiar dla przycisku Pomiń w kolumnie statusu */
.producer-status-cell .btn.btn-secondary.btn-skip {
    padding: 2px 6px;
    font-size: 11px;
    line-height: 1.2;
    border-radius: 6px;
    box-shadow: none;
}

/* Center the 'Pomiń' button horizontally within the producer status column */
.producer-status-cell .btn-skip {
    align-self: center;
}

.filters, .orders-toolbar {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

/* Responsive toolbar for mobile */
@media (max-width: 768px) {
    .orders-wrap > div:first-child {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
    }
    
    .orders-wrap > div:first-child > div:first-child {
        justify-content: center !important;
        flex-wrap: wrap !important;
    }
    
    .orders-wrap > div:first-child > div:last-child {
        justify-content: center !important;
        flex-wrap: wrap !important;
    }
}

.orders-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    background: #eef2ff;
    font-size: 12px;
    color: #1e293b;
    border: 1px solid #dbeafe;
}

.orders-toast {
    position: fixed;
    right: 16px;
    top: 16px;
    background: #111827;
    color: #ffffff;
    border-radius: 10px;
    padding: 10px 12px;
    box-shadow: 0 10px 20px rgba(15,23,42,0.25);
    opacity: 0;
    transform: translateY(-8px);
    transition: opacity .2s ease, transform .2s ease;
    z-index: 1000;
}

.orders-toast.show {
    opacity: .98;
    transform: translateY(0);
}

 .orders-toast.orders-toast-warning {
     background: #fef3c7;
     color: #7c2d12;
     border: 1px solid #f59e0b;
 }

/* Lightweight modal used for confirmations in orders */
.orders-modal {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1100;
    padding: 16px;
}

.orders-modal-content {
    background: #ffffff;
    color: var(--text);
    border-radius: 12px;
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.25);
    border: 1px solid var(--border);
    width: 100%;
    max-width: 560px;
    padding: 16px;
}

.orders-modal-text {
    margin: 0;
    padding: 12px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    white-space: pre-wrap; /* wrap long lists nicely */
    max-height: 50vh;
    overflow: auto;
    font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Helvetica Neue", Arial;
    font-size: 14px;
}

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

.orders-modal-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.orders-modal-icon {
    font-size: 20px;
}

.orders-modal-title {
    font-weight: 700;
    font-size: 16px;
}

.orders-scanbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: #ffffff;
    margin-bottom: 10px;
}

.orders-scanbar-left {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.orders-scanbar-label {
    font-size: 12px;
    color: var(--muted);
}

.orders-scanbar-input {
    width: 260px;
    max-width: 60vw;
}

.orders-scan-panel {
    border: 1px solid var(--border);
    border-radius: 10px;
    background: #ffffff;
    margin-bottom: 12px;
    overflow: visible;
}

.orders-scan-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 8px 12px;
    border-bottom: 1px solid var(--border);
    background: #f8fafc;
}

.orders-scan-panel-title {
    font-weight: 700;
    font-size: 13px;
}

.orders-scan-panel-hint {
    font-size: 12px;
    color: var(--muted);
}

.orders-scan-panel-list {
    max-height: 300px;
    overflow: auto;
    display: flex;
    flex-direction: column;
}

.orders-scan-entry {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 8px 12px;
    border-bottom: 1px solid #eef2f7;
}

.orders-scan-entry:last-child {
    border-bottom: none;
}

.orders-scan-entry-code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 12px;
    color: var(--text);
}

.orders-scan-entry-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    margin-left: 8px;
    border-radius: 9999px;
    background: var(--success);
    border: 1px solid rgba(0, 0, 0, 0.06);
    cursor: pointer;
    padding: 0;
    vertical-align: middle;
    position: relative;
}

.orders-scan-entry-dot:hover {
    filter: brightness(0.95);
}

.orders-tooltip {
    position: fixed;
    left: 0;
    top: 0;
    background: rgba(15, 23, 42, 0.92);
    color: #fff;
    font-size: 12px;
    line-height: 1.2;
    padding: 6px 8px;
    border-radius: 8px;
    z-index: 2000;
    pointer-events: none;
    white-space: nowrap;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
}

.orders-scan-entry-meta {
    font-size: 12px;
    color: var(--muted);
}

.orders-scan-entry-warning {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    margin-left: 6px;
    border-radius: 9999px;
    background: #fef3c7;
    color: #b45309;
    font-weight: 700;
    font-size: 11px;
    border: 1px solid rgba(180, 83, 9, 0.35);
}

.orders-scan-entry-actions {
    display: flex;
    gap: 6px;
    align-items: center;
}

.orders-scan-entry-loading { opacity: .75; }
.orders-scan-entry-unassigned { background: #fff7ed; }
.orders-scan-entry-matched { background: #f0fdf4; }
.orders-scan-entry-conflict { background: #fef2f2; }
.orders-scan-entry-error { background: #fef2f2; }

.row-scan-highlight {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
    box-shadow: 0 0 0 4px rgba(6, 182, 212, 0.15);
}

.loading {
    /* Zamiast ukrywać element całkiem, rezerwujemy miejsce, by uniknąć przeskoku układu */
    visibility: hidden;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--muted);
    font-size: 14px;
    min-width: 160px; /* rezerwacja miejsca dla tekstu + spinnera */
}

.loading.show {
    visibility: visible;
}

.loading .spinner {
    width: 14px;
    height: 14px;
    border: 2px solid #cbd5e1;
    border-top-color: var(--primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.btn {
    background: linear-gradient(180deg, var(--primary), var(--primary-700));
    color: white;
    border: none;
    padding: 8px 12px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px; /* stabilny rozmiar czcionki, by uniknąć przeskoków */
    cursor: pointer;
    transition: transform .05s ease, box-shadow .2s ease;
    box-shadow: 0 4px 14px rgba(37,99,235,.25);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    white-space: nowrap; /* nie zawijaj tekstu w przyciskach */
}
.btn:active { transform: translateY(1px); }
.btn-secondary {
    background: #ffffff;
    color: var(--text);
    border: 1px solid var(--border);
    box-shadow: none;
}

 .btn-admin-panel {
     position: relative;
     z-index: 5;
 }

/* Clipboard button should look like the default .btn */
.btn-clipboard {
    background: linear-gradient(180deg, var(--primary), var(--primary-700));
    color: #ffffff;
    border: none;
    box-shadow: 0 4px 14px rgba(37,99,235,.25);
    white-space: nowrap; /* bezpieczeństwo dla przycisku schowka */
}

.input, .select {
    background: #ffffff;
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 8px 10px;
}

.badge { border-radius: 999px; padding: 2px 8px; font-size: 12px; font-weight: 600; display: inline-block; text-align: center; }
.badge-success { background: #ecfdf5; color: #065f46; border: 1px solid #bbf7d0; }
.badge-warning { background: #fffbeb; color: #92400e; border: 1px solid #fde68a; }
.badge-danger { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }
.badge-info { background: #eff6ff; color: #1e40af; border: 1px solid #bfdbfe; }
.badge-muted { background: #f3f4f6; color: #374151; border: 1px solid #e5e7eb; }

/* Payment status badges - more prominent styling */
.badge-payment-paid { 
  background: linear-gradient(135deg, #16a34a, #15803d); 
  color: #ffffff; 
  border: 1px solid #166534; 
  box-shadow: 0 2px 4px rgba(22, 163, 74, 0.3);
  font-weight: 700;
}
.badge-payment-unpaid { 
  background: linear-gradient(135deg, #dc2626, #b91c1c); 
  color: #ffffff; 
  border: 1px solid #991b1b; 
  box-shadow: 0 2px 4px rgba(220, 38, 38, 0.3);
  font-weight: 700;
}
.badge-payment-unknown { 
  background: linear-gradient(135deg, #6b7280, #4b5563); 
  color: #ffffff; 
  border: 1px solid #374151; 
  box-shadow: 0 2px 4px rgba(107, 114, 128, 0.3);
  font-weight: 700;
}

/* Payment badges: allow wrapping within the cell to avoid horizontal overflow */
.badge-payment-paid,
.badge-payment-unpaid,
.badge-payment-unknown {
    display: inline-block;
    max-width: 100%;
    white-space: normal;          /* allow wrapping */
    overflow-wrap: break-word;    /* break long tokens only when necessary */
    word-break: normal;           /* avoid breaking each letter */
    hyphens: auto;                /* nicer long-word breaks */
    vertical-align: middle;
}

/* --- Admin panel styles --- */
.admin-wrap {
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--panel);
    padding: 16px;
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.06);
}

.admin-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.card {
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--panel-2);
    overflow: hidden;
}
.card-header {
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.card-body { padding: 16px; }

.role-badge { font-size: 12px; border-radius: 999px; padding: 2px 8px; border: 1px solid #e5e7eb; background: #f8fafc; color: #334155; }
.role-admin { background: #eff6ff; border-color: #bfdbfe; color: #1e40af; }

.form-grid { display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 640px) { .form-grid { grid-template-columns: 1fr 1fr; } }

.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

.form-actions { display: flex; gap: 8px; margin-top: 12px; }

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

/* Nicer checkboxes and labels in admin forms */
.form-check-input {
    width: 18px;
    height: 18px;
    margin-right: 8px;
    accent-color: var(--primary);
    vertical-align: middle;
}

/* Style labels that wrap checkbox inputs (Symfony renders <label><input> Tekst</label>) */
label:has(> .form-check-input) {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: #fff;
    cursor: pointer;
    margin-right: 8px;
}

/* Field labels general spacing */
.form-label {
    display: block;
    margin-bottom: 6px;
    font-weight: 600;
}

/* --- Auth (login) helpers --- */
.auth-wrap {
    min-height: calc(100vh - 80px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 12px;
}

.auth-logo {
    font-weight: 800;
    font-size: 22px;
    color: var(--text);
}

.auth-card {
    width: 100%;
    max-width: 420px;
}

/* Alerts (e.g., login error) */
.alert {
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: #fff;
}
.alert-danger {
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
}
.alert-success {
    background: #ecfdf5;
    border-color: #bbf7d0;
    color: #065f46;
}
