/* ============================================================
   WIZARD LAYOUT - kreator/edytor ładunku
   ============================================================ */
.wizard-layout {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 18px;
    align-items: flex-start;
    padding-bottom: 90px;  /* miejsce na sticky save bar */
}

.wizard-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* ────────── Sticky nav po LEWEJ ────────── */
.wizard-nav {
    position: sticky;
    top: 16px;
    align-self: flex-start;
    min-width: 0;
}
.wizard-nav-inner {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.wizard-nav-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--text-muted);
    padding: 4px 8px 8px;
}
.wizard-nav-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: var(--r-sm);
    text-decoration: none;
    color: var(--text);
    transition: all var(--t-fast);
    border-left: 3px solid transparent;
    cursor: pointer;
}
.wizard-nav-item:hover {
    background: var(--card-hover);
    text-decoration: none;
}
.wizard-nav-item.is-active {
    background: color-mix(in srgb, var(--c) 8%, transparent);
    border-left-color: var(--c);
}
.wizard-nav-icon {
    color: var(--c);
    flex-shrink: 0;
}
.wizard-nav-label {
    flex: 1;
    min-width: 0;
    line-height: 1.25;
}
.wizard-nav-label strong { font-size: 12.5px; display: block; }
.wizard-nav-label small { color: var(--text-muted); font-size: 10.5px; }
.wizard-nav-status {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--border);
}
.wizard-nav-item.is-complete .wizard-nav-status {
    background: var(--st-success);
}

/* ────────── Sekcja formularza ────────── */
.wizard-section {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    overflow: hidden;
    scroll-margin-top: 16px;
}
.wizard-section-head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--c) 8%, var(--card)), var(--card));
    border-bottom: 1px solid var(--border);
    border-left: 4px solid var(--c);
}
.wizard-section-head > div:not(.wizard-section-icon):not(.wizard-section-counter) {
    flex: 1;
}
.wizard-section-head h2 {
    margin: 0;
    font-size: 16px;
    color: var(--text);
    font-weight: 700;
}
.wizard-section-head p {
    margin: 2px 0 0;
    font-size: 12.5px;
}
.wizard-section-icon {
    width: 34px;
    height: 34px;
    border-radius: var(--r-sm);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.wizard-section-counter {
    font-size: 12px;
    color: var(--text-muted);
    background: var(--card-hover);
    padding: 4px 10px;
    border-radius: var(--r-sm);
    border: 1px solid var(--border);
}
.wizard-section-counter .counter-num {
    color: var(--c);
    font-weight: 700;
    font-family: var(--font-mono);
    font-size: 13px;
}
.wizard-section-body {
    padding: 16px 18px;
}

/* ── Pola premium w OBU kreatorach — spójne z formularzem punktu i modalem szybkiej edycji ── */
.wizard-section-body .form-input,
.wizard-section-body .form-select,
.wizard-section-body .form-textarea {
    border: 1.5px solid var(--border-strong);
    background: var(--bg);
}
.wizard-section-body .form-input:focus,
.wizard-section-body .form-select:focus,
.wizard-section-body .form-textarea:focus {
    background: var(--card);
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, .15);
}
.wizard-section-body .form-label {
    font-weight: 600;
    color: var(--text-soft);
    font-size: 12px;
}

/* ────────── Form grid ────────── */
.form-grid {
    display: grid;
    gap: 12px;
}
.form-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.form-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.form-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.form-group-full { grid-column: 1 / -1; }
.form-section-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin: 0 0 10px;
    padding-bottom: 5px;
    border-bottom: 1px dashed var(--border);
}
.form-label-xs {
    font-size: 10.5px;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .03em;
    display: block;
    margin-bottom: 3px;
}
.form-input-sm {
    padding: 5px 8px !important;
    font-size: 12px !important;
}

/* ────────── Radio pills ────────── */
.form-radio-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.form-radio-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--card);
    border: 2px solid var(--border);
    border-radius: 18px;
    cursor: pointer;
    font-size: 12.5px;
    font-weight: 600;
    transition: all var(--t-fast);
}
.form-radio-pill:hover {
    border-color: var(--c);
}
.form-radio-pill input { display: none; }
.form-radio-pill.is-checked {
    background: var(--c);
    color: #fff;
    border-color: var(--c);
}
.form-radio-pill-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--c);
    flex-shrink: 0;
    box-shadow: inset 0 0 0 2px var(--card);
}
.form-radio-pill.is-checked .form-radio-pill-dot {
    background: #fff;
    box-shadow: inset 0 0 0 2px var(--c);
}

/* ────────── Input group (kwota + waluta) ────────── */
.input-group {
    display: flex;
    gap: 4px;
}
.input-group > input { flex: 1; }
.input-group > select { flex-shrink: 0; width: 80px; }

/* ────────── Autocomplete ────────── */
.autocomplete-wrap {
    position: relative;
}
.autocomplete-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--card);
    border: 1px solid var(--border-strong);
    border-radius: var(--r-sm);
    box-shadow: var(--shadow);
    max-height: 280px;
    overflow-y: auto;
    z-index: 100;
    margin-top: 2px;
}
.autocomplete-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    cursor: pointer;
    border-bottom: 1px solid var(--border);
}
.autocomplete-item:last-child { border-bottom: none; }
.autocomplete-item:hover {
    background: var(--card-hover);
}
.autocomplete-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}
.autocomplete-item strong { display: block; font-size: 13px; color: var(--text); }
.autocomplete-item small { display: block; font-size: 11px; color: var(--text-muted); margin-top: 1px; }
.autocomplete-empty {
    padding: 12px;
    color: var(--text-muted);
    font-size: 12px;
    text-align: center;
}

/* ────────── Contact pills (osoby kontaktowe) ────────── */
.contacts-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 6px 0;
}
.contact-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 18px;
    cursor: pointer;
    transition: all var(--t-fast);
    font-size: 12px;
}
.contact-pill:hover {
    border-color: var(--brand-blue);
}
.contact-pill input { display: none; }
.contact-pill.is-checked {
    background: color-mix(in srgb, var(--brand-blue) 12%, var(--card));
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 1px var(--brand-blue);
}
.contact-pill-body {
    display: flex;
    align-items: center;
    gap: 8px;
}
.contact-pill-body strong { font-weight: 600; color: var(--text); }
.contact-pill-role {
    color: var(--text-muted);
    font-size: 10.5px;
    padding: 1px 6px;
    background: var(--card-hover);
    border-radius: 8px;
}
.contact-pill-phone {
    color: var(--text-muted);
    font-size: 11px;
    font-family: var(--font-mono);
}

/* ────────── Broker section ────────── */
.form-broker-section {
    background: color-mix(in srgb, #7c3aed 6%, transparent);
    border: 1px solid color-mix(in srgb, #7c3aed 25%, transparent);
    border-radius: var(--r-sm);
    padding: 12px 14px;
    margin-top: 12px;
}
.form-broker-section-head {
    font-size: 12px;
    font-weight: 700;
    color: #7c3aed;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
    text-transform: uppercase;
    letter-spacing: .03em;
}

/* ────────── Point cards (załadunki/rozładunki) ────────── */
.points-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 10px;
}
.point-card {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    overflow: hidden;
}
.point-card-head {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--card-hover);
    border-bottom: 1px solid var(--border);
}
.point-card-num {
    font-family: var(--font-mono);
    font-weight: 700;
    color: var(--text-muted);
    min-width: 22px;
}
.point-card-head .point-remove {
    margin-left: auto;
}
.point-fix-toggle {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    padding: 4px 8px;
    border: 1px solid var(--border);
    border-radius: var(--r-xs);
    font-size: 11px;
    font-weight: 700;
    color: var(--text-muted);
    user-select: none;
}
.point-fix-toggle:has(input:checked) {
    background: #dc2626;
    color: #fff;
    border-color: #dc2626;
}
.point-fix-toggle input { display: none; }
.btn-icon {
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: var(--r-xs);
    color: var(--text-muted);
    cursor: pointer;
    transition: all var(--t-fast);
}
.btn-icon:hover {
    background: var(--card-hover);
    color: var(--text);
}
.btn-icon-danger:hover {
    background: var(--st-danger);
    color: #fff;
    border-color: var(--st-danger);
}
.point-card-body {
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Modes pills toggle (multi-select) */
.modes-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}
.mode-pill-toggle {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: 12px;
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .02em;
    cursor: pointer;
    border: 1.5px solid;
    transition: all var(--t-fast);
    user-select: none;
}
.mode-pill-toggle:hover {
    transform: translateY(-1px);
}

/* ────────── Cargo items ────────── */
.cargo-items-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 10px;
}
.cargo-item-row {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: 8px;
}
.cargo-item-grid {
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr)) 30px;
    gap: 6px;
    align-items: center;
}
/* Drugi rząd towaru: objętość / ADR / UN / uwagi — parytet z modalem edycji */
.cargo-item-extra {
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px dashed var(--border);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* ────────── Sticky save bar ────────── */
.wizard-save-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 50;
    background: var(--card);
    border-top: 1px solid var(--border-strong);
    box-shadow: 0 -4px 12px rgba(0, 0, 0, .08);
    padding: 10px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.wizard-save-info {
    font-size: 12.5px;
}
.wizard-save-actions {
    display: flex;
    gap: 8px;
}
.wizard-save-actions .btn-primary {
    padding: 8px 20px;
    font-weight: 700;
}

/* Responsive */
@media (max-width: 1000px) {
    .wizard-layout { grid-template-columns: 1fr; }
    .wizard-nav { position: static; }
    .form-grid-3, .form-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .cargo-item-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
    .form-grid-2, .form-grid-3, .form-grid-4 { grid-template-columns: 1fr; }
    .cargo-item-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ============================================================
   FINANSE - sekcja pricing rozbudowana
   ============================================================ */
.finance-row {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-bottom: 12px;
}
.finance-row-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 6px;
}
.finance-row-label small {
    color: var(--text-muted);
    font-weight: 400;
    font-size: 11px;
    margin-left: 4px;
}
.finance-row-primary {
    background: color-mix(in srgb, #F59E0B 6%, transparent);
    border: 1px solid color-mix(in srgb, #F59E0B 30%, transparent);
    border-radius: var(--r-sm);
    padding: 12px 14px;
}
.finance-row-primary .finance-row-label {
    font-size: 13px;
    color: #92400e;
    text-transform: uppercase;
    letter-spacing: .03em;
}

/* Broker section */
.finance-broker-wrap {
    background: color-mix(in srgb, #7c3aed 5%, transparent);
    border: 1px solid color-mix(in srgb, #7c3aed 25%, transparent);
    border-radius: var(--r-sm);
    padding: 12px 14px;
    margin-top: 12px;
}
.finance-broker-head {
    font-size: 11px;
    font-weight: 800;
    color: #7c3aed;
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.finance-broker-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    align-items: end;
}
.finance-margin-readout {
    background: var(--bg);
    border: 1.5px dashed color-mix(in srgb, #7c3aed 40%, var(--border));
    border-radius: var(--r-sm);
    padding: 8px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.finance-margin-label {
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--text-muted);
}
.finance-margin-value {
    font-size: 15px;
    font-family: var(--font-mono);
    font-weight: 600;
    color: var(--text-muted);
}
.finance-margin-value.is-positive { color: #16a34a; }
.finance-margin-value.is-negative { color: #dc2626; }
.finance-margin-value.is-warning  { color: #f59e0b; }
.finance-margin-value small {
    font-weight: 400;
    font-size: 12px;
    margin-left: 4px;
    opacity: .85;
}

/* Price items list */
.price-items-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 10px;
}
.price-item-row {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-left: 3px solid #16a34a;
    border-radius: var(--r-sm);
    padding: 8px;
    transition: border-color var(--t-fast);
}
.price-item-row[data-side="cost"] {
    border-left-color: #dc2626;
}
.price-item-grid {
    display: grid;
    grid-template-columns: auto repeat(4, minmax(0, 1fr)) 80px auto 30px;
    gap: 6px;
    align-items: center;
}

.price-item-side-toggle {
    display: inline-flex;
    border: 1px solid var(--border);
    border-radius: var(--r-xs);
    overflow: hidden;
}
.price-side-btn {
    background: transparent;
    border: none;
    color: var(--text-muted);
    width: 24px;
    height: 28px;
    cursor: pointer;
    font-weight: 800;
    font-size: 14px;
    line-height: 1;
    transition: all var(--t-fast);
}
.price-side-btn:hover { background: var(--card-hover); }
.price-side-btn.is-active {
    color: #fff;
}
.price-side-btn.is-active[data-side="income"] { background: #16a34a; }
.price-side-btn.is-active[data-side="cost"]   { background: #dc2626; }

.price-separate-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 8px;
    border: 1px solid var(--border);
    border-radius: var(--r-xs);
    font-size: 10px;
    font-weight: 700;
    cursor: pointer;
    color: var(--text-muted);
    height: 28px;
    user-select: none;
}
.price-separate-toggle:has(input:checked) {
    background: #0ea5e9;
    color: #fff;
    border-color: #0ea5e9;
}
.price-separate-toggle input { display: none; }

@media (max-width: 1000px) {
    .finance-broker-grid { grid-template-columns: 1fr; }
    .price-item-grid { grid-template-columns: auto 1fr 1fr 80px auto 30px; }
    .price-item-grid > .price-desc { grid-column: span 1; }
}

/* ============================================================
   DOKUMENTY w wizardzie
   ============================================================ */
.docs-required-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}
.doc-required-item {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--card);
    border: 1px solid var(--border);
    border-left: 3px solid #0ea5e9;
    border-radius: var(--r-sm);
    padding: 8px 10px;
}
.doc-required-info {
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.doc-required-info strong {
    font-size: 12px;
    color: var(--text);
}
.doc-required-info small {
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-top: 2px;
}

.docs-extra-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 6px;
}
.doc-extra-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 8px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    cursor: pointer;
    transition: all var(--t-fast);
    font-size: 12px;
}
.doc-extra-pill:hover {
    border-color: var(--brand-blue);
    background: var(--card-hover);
}
.doc-extra-pill.is-checked {
    background: color-mix(in srgb, var(--brand-blue) 10%, var(--card));
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 1px var(--brand-blue);
}
.doc-extra-pill input { display: none; }

/* Autocomplete add new */
.autocomplete-item.autocomplete-add-new {
    background: color-mix(in srgb, #16a34a 5%, var(--card));
    border-top: 1px solid color-mix(in srgb, #16a34a 25%, var(--border));
}
.autocomplete-item.autocomplete-add-new:hover {
    background: color-mix(in srgb, #16a34a 15%, var(--card));
}
.autocomplete-item.autocomplete-add-new strong { color: #15803d; }

/* ============================================================
   FINANSE - pozycje w 2-kol grid (Adrian: nie musi być na całą szerokość)
   ============================================================ */
.price-items-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}
.price-item-row {
    margin: 0;
}
.price-item-grid {
    display: grid;
    grid-template-columns: auto 1fr 90px 70px auto 28px;
    gap: 6px;
    align-items: center;
}
.price-item-grid > .price-desc {
    grid-column: 2 / 3;
}
@media (max-width: 700px) {
    .price-items-list { grid-template-columns: 1fr; }
}

/* ============================================================
   DOKUMENTY - 3-stanowe pigułki
   ============================================================ */
.docs-pills-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 8px;
}
.docs-state-pill {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 8px 12px;
    border: 2px solid;
    border-radius: var(--r-sm);
    cursor: pointer;
    transition: all var(--t-fast);
    user-select: none;
    line-height: 1.3;
}
.docs-state-pill:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}
.docs-state-pill strong {
    font-size: 13px;
    font-family: var(--font-mono);
    letter-spacing: .03em;
}
.docs-state-pill-label {
    font-size: 11.5px;
    font-weight: 500;
}
.docs-state-pill-state {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-top: 2px;
    opacity: .9;
}

/* ============================================================
   FINANSE - layout 2-kol + panel podsumowania
   ============================================================ */
.finance-layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 16px;
    align-items: flex-start;
}
.finance-inputs {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.finance-card {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-left: 3px solid color-mix(in srgb, #f59e0b 65%, var(--border));
    border-radius: var(--r-sm);
    padding: 12px 14px;
}
.finance-card-broker {
    border-left: 3px solid #7c3aed;
}
.finance-card-label {
    font-size: 11.5px;
    font-weight: 700;
    color: var(--text);
    text-transform: uppercase;
    letter-spacing: .03em;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.finance-card-label small {
    font-weight: 400;
    color: var(--text-muted);
    text-transform: none;
    letter-spacing: 0;
}

/* Kwota + waluta jako jeden spójny kontroler (premium) — tylko w kartach finansowych */
.finance-card .input-group {
    gap: 0;
    align-items: stretch;
    border: 1.5px solid var(--border-strong);
    border-radius: var(--r-sm);
    background: var(--bg);
    overflow: hidden;
    transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.finance-card .input-group:focus-within {
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, .15);
}
.finance-card .input-group > input,
.finance-card .input-group > select {
    border: none !important;
    border-radius: 0;
    background: transparent;
    box-shadow: none !important;
}
.finance-card .input-group > input {
    flex: 1;
    font-size: 17px;
    font-weight: 700;
    padding: 9px 12px;
}
.finance-card .input-group > select {
    flex-shrink: 0;
    width: auto;
    min-width: 72px;
    border-left: 1px solid var(--border) !important;
    font-weight: 600;
    color: var(--text-soft);
    padding: 0 8px;
}

/* Panel podsumowania - sticky w obrębie sekcji */
.finance-summary {
    background: color-mix(in srgb, #F59E0B 8%, var(--card));
    border: 1px solid color-mix(in srgb, #F59E0B 30%, var(--border));
    border-radius: var(--r-sm);
    padding: 14px;
    position: sticky;
    top: 80px;
    align-self: flex-start;
}
.finance-summary-head {
    font-size: 13px;
    font-weight: 700;
    color: #92400e;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 10px;
    padding-bottom: 8px;
    border-bottom: 1px solid color-mix(in srgb, #F59E0B 25%, var(--border));
    display: flex;
    align-items: center;
    gap: 6px;
}
.finance-summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 5px 0;
    font-size: 12.5px;
}
.finance-summary-label {
    color: var(--text-muted);
}
.finance-summary-value {
    font-family: var(--font-mono);
    font-weight: 700;
    color: var(--text);
    text-align: right;
}
.finance-summary-value.is-positive { color: #16a34a; }
.finance-summary-value.is-negative { color: #dc2626; }
.finance-summary-value.is-warning  { color: #f59e0b; }
.finance-summary-row.balance .finance-summary-value { font-size: 15px; }
.finance-summary-divider {
    height: 1px;
    background: color-mix(in srgb, #F59E0B 20%, var(--border));
    margin: 6px 0;
}

@media (max-width: 900px) {
    .finance-layout { grid-template-columns: 1fr; }
    .finance-summary { position: static; }
}

/* ============================================================
   QUICK-ADD KONTRAHENTA - multi-kontakty
   ============================================================ */
.qac-contacts-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 6px;
}
.qac-contact-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 110px 1.2fr 30px;
    gap: 4px;
    align-items: center;
}
@media (max-width: 700px) {
    .qac-contact-row {
        grid-template-columns: 1fr 1fr 30px;
        gap: 4px;
    }
    .qac-contact-row > .qac-c-role,
    .qac-contact-row > .qac-c-phone,
    .qac-contact-row > .qac-c-email {
        grid-column: span 2;
    }
}

/* ============================================================
   AUTOCOMPLETE adresu - ikony flag typu
   ============================================================ */
.addr-flags {
    display: flex;
    gap: 2px;
    flex-shrink: 0;
}
.addr-flag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    font-size: 9px;
    color: #fff;
}

/* ============================================================
   PUNKTY - multi-kontakty per punkt
   ============================================================ */
.point-contacts {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    min-height: 30px;
    padding: 4px;
    background: var(--bg);
    border: 1px dashed var(--border);
    border-radius: var(--r-xs);
}
.point-contacts:has(label) {
    border-style: solid;
    background: var(--bg-elevated);
}

/* ============================================================
   HOTFIX 026B - Sales Wizard
   ============================================================ */

/* Kafelki typów sprzedaży */
.sale-types-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 12px;
}
.sale-type-tile {
    display: flex;
    gap: 12px;
    padding: 14px;
    border: 2px solid var(--border);
    border-radius: var(--r-md);
    background: var(--card);
    cursor: pointer;
    transition: all var(--t-fast);
}
.sale-type-tile:hover {
    border-color: var(--c);
    background: color-mix(in srgb, var(--c) 5%, var(--card));
}
.sale-type-tile.is-selected {
    border-color: var(--c);
    background: color-mix(in srgb, var(--c) 12%, var(--card));
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--c) 30%, transparent);
}
.sale-type-icon {
    width: 46px;
    height: 46px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    flex-shrink: 0;
}
.sale-type-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.sale-type-text strong { font-size: 14px; color: var(--text); }
.sale-type-text small { font-size: 11.5px; color: var(--text-muted); line-height: 1.4; }

/* Kafelki baz */
.bases-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 10px;
    margin-top: 8px;
}
.base-tile {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border: 2px solid var(--border);
    border-radius: var(--r-sm);
    cursor: pointer;
    transition: all var(--t-fast);
    background: var(--card);
}
.base-tile:hover { border-color: var(--c); }
.base-tile.is-selected {
    border-color: var(--c);
    background: color-mix(in srgb, var(--c) 10%, var(--card));
}
.base-tile-code {
    padding: 4px 8px;
    border-radius: 4px;
    color: #fff;
    font-weight: 700;
    font-size: 12px;
}
.base-tile-text strong { font-size: 13px; display: block; }
.base-tile-text small { font-size: 11px; color: var(--text-muted); }

/* Checkbox punktów */
.points-group { margin-top: 12px; }
.points-group-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin: 8px 0 6px;
}
.point-check-row {
    display: grid;
    grid-template-columns: 24px 90px 1fr auto;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-radius: var(--r-sm);
    cursor: pointer;
    transition: background var(--t-fast);
    border: 1px solid transparent;
}
.point-check-row:hover { background: var(--card-hover); }
.point-check-row input[type=checkbox]:checked + .point-check-date,
.point-check-row:has(input:checked) {
    background: color-mix(in srgb, var(--brand-blue) 8%, var(--card));
    border-color: color-mix(in srgb, var(--brand-blue) 30%, transparent);
}
.point-check-date {
    font-weight: 600;
    color: var(--text);
    font-size: 12.5px;
}
.point-check-place { font-size: 12.5px; color: var(--text); }
.point-check-ref { font-size: 11px; color: var(--text-muted); }

/* Banner dziedziczenia */
.inheritance-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    background: linear-gradient(135deg, color-mix(in srgb, #f97316 10%, var(--card)), color-mix(in srgb, #f97316 4%, var(--card)));
    border: 1px solid color-mix(in srgb, #f97316 35%, var(--border));
    border-left: 4px solid #f97316;
    border-radius: var(--r-sm);
    margin-bottom: 12px;
}
.inheritance-banner strong { display: block; font-size: 13.5px; color: var(--text); }
.inheritance-banner small { font-size: 11.5px; color: var(--text-muted); }

/* Review grid */
.review-summary {
    background: color-mix(in srgb, var(--brand-blue) 4%, var(--card));
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 16px;
    margin-bottom: 16px;
}
.review-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}
.review-cell {
    background: var(--card);
    border-radius: var(--r-sm);
    padding: 10px 12px;
    border: 1px solid var(--border);
}
.review-label {
    font-size: 10px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    display: block;
    margin-bottom: 3px;
}
.review-cell strong { font-size: 13.5px; color: var(--text); }
.review-terms {
    background: color-mix(in srgb, #f97316 6%, var(--bg));
    padding: 8px 10px;
    border-radius: 4px;
    font-size: 12px;
    color: var(--text);
    white-space: pre-wrap;
    margin-top: 4px;
    border-left: 3px solid #f97316;
}
.review-actions {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px dashed var(--border);
}
.btn-lg {
    padding: 12px 24px;
    font-size: 14px;
    font-weight: 600;
}

/* ============================================================
   HOTFIX 035 - Brakujące klasy wizarda sprzedaży
   ============================================================ */
.wizard-form {
    min-width: 0;
}
.wizard-nav-head {
    padding: 0 0 14px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 12px;
}
.wizard-nav-head h2 {
    font-size: 17px;
    font-weight: 800;
    margin: 0 0 6px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--text);
}
.wizard-nav-sub {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}
.wizard-nav-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.wizard-nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: var(--r-sm);
    border-left: 3px solid transparent;
    text-decoration: none;
    color: var(--text);
    transition: all var(--t-fast);
    cursor: pointer;
}
.wizard-nav-item:hover {
    background: var(--card-hover);
}
.wizard-nav-item.is-active {
    background: color-mix(in srgb, var(--c, var(--brand-blue)) 10%, var(--card));
    border-left-color: var(--c, var(--brand-blue));
}
.wizard-nav-item div strong {
    display: block;
    font-size: 13px;
    font-weight: 600;
}
.wizard-nav-item div small {
    font-size: 11px;
    color: var(--text-muted);
}
.wizard-nav-num {
    width: 26px;
    height: 26px;
    flex-shrink: 0;
    border-radius: 50%;
    background: var(--c, var(--brand-blue));
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 12px;
}
.wizard-nav-footer {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* map point card */
.map-point-card {
    transition: all var(--t-fast);
}
.map-point-card:hover {
    border-color: var(--brand-blue) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
}

/* ============================================================
   PREMIUM POLISH — spójność z podglądem ładunku (addytywne)
   ============================================================ */
.wizard-section { box-shadow: 0 1px 3px rgba(15,23,42,.05), 0 1px 2px rgba(15,23,42,.04); transition: box-shadow .15s ease; }
.wizard-section:hover { box-shadow: 0 6px 20px rgba(15,23,42,.07); }
.sale-type-tile { box-shadow: 0 1px 2px rgba(15,23,42,.04); }
.sale-type-tile:hover { transform: translateY(-1px); box-shadow: 0 8px 22px rgba(15,23,42,.09); }
.sale-type-tile.is-selected { transform: none; }
.wizard-nav-item.is-active { box-shadow: 0 2px 10px rgba(37,99,235,.14); }
.wizard-section-icon { box-shadow: 0 2px 6px color-mix(in srgb, var(--c) 35%, transparent); }
.form-input:focus, .form-input-sm:focus, .form-select:focus {
    border-color: var(--accent, #2563eb);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent, #2563eb) 14%, transparent);
    outline: none;
}

/* ── Karta punktu — premium + kolor wg rodzaju (dziedziczy --c sekcji) ── */
.point-card { box-shadow: 0 1px 2px rgba(15,23,42,.04); transition: box-shadow .15s ease, border-color .15s ease; }
.point-card:hover { box-shadow: 0 5px 16px rgba(15,23,42,.07); border-color: color-mix(in srgb, var(--c) 30%, var(--border)); }
.point-card-head { border-left: 3px solid var(--c, var(--border));
    background: linear-gradient(135deg, color-mix(in srgb, var(--c) 8%, var(--card-hover)), var(--card-hover)); }
.point-card-num { color: var(--c, var(--text-muted)); }

/* =================================================================================
   PREMIUM 2026 — REFINEMENT (kreator/edytor ładunku)
   Dopisane na końcu: czysto wizualne nadpisania (późniejsze reguły wygrywają).
   Cel: bardziej kompaktowo + premium wg podglądu ładunku; przebudowa Finansów.
   Klasy/ID/markup/JS bez zmian. Tylko tokeny — bez surowych hexów.
   ================================================================================= */

/* ——— Gęstość ogólna ——— */
.wizard-layout { gap: 16px; }
.wizard-main   { gap: 12px; }

/* ——— Premium panele sekcji (elewacja + miękki hover) ——— */
.wizard-section {
    border-radius: var(--r-md);
    box-shadow: var(--shadow);
    transition: box-shadow var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.wizard-section:hover { box-shadow: var(--shadow-md); }
.wizard-section:focus-within {
    box-shadow: var(--shadow-md);
    border-color: color-mix(in srgb, var(--c) 45%, var(--border));
}
.wizard-section-head {
    padding: 12px 16px;
    gap: 11px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--c) 10%, var(--card)), var(--card) 62%);
    border-bottom: 1px solid color-mix(in srgb, var(--c) 16%, var(--border));
}
.wizard-section-head h2 { font-size: 15px; letter-spacing: -.01em; }
.wizard-section-head p  { font-size: 12px; color: var(--text-muted); }
.wizard-section-icon {
    width: 30px; height: 30px;
    border-radius: var(--r);
    box-shadow: var(--shadow-sm);
    background: linear-gradient(140deg, var(--c), color-mix(in srgb, var(--c) 78%, #000 12%));
}
.wizard-section-counter {
    border-radius: 999px;
    padding: 3px 11px;
    background: color-mix(in srgb, var(--c) 10%, var(--card));
    border-color: color-mix(in srgb, var(--c) 26%, var(--border));
}
.wizard-section-body { padding: 14px 16px; }

/* ——— Premium sticky rail po lewej ——— */
.wizard-nav { top: 16px; }
.wizard-nav-inner {
    border-radius: var(--r-md);
    box-shadow: var(--shadow);
    padding: 8px;
    gap: 2px;
}
.wizard-nav-title { padding: 4px 8px 6px; }
.wizard-nav-item {
    padding: 7px 9px;
    border-radius: var(--r-sm);
    border-left-width: 3px;
}
.wizard-nav-item.is-active {
    background: color-mix(in srgb, var(--c) 12%, transparent);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--c) 22%, transparent);
}
.wizard-nav-item.is-active .wizard-nav-label strong { color: var(--c); }
.wizard-nav-status { box-shadow: 0 0 0 3px color-mix(in srgb, var(--border) 40%, transparent); }
.wizard-nav-item.is-complete .wizard-nav-status {
    box-shadow: 0 0 0 3px var(--st-success-bg);
}

/* ——— Gęstsze pola w sekcjach ——— */
.wizard-section-body .form-input,
.wizard-section-body .form-select,
.wizard-section-body .form-textarea { padding: 7px 11px; font-size: 13px; }
.wizard-section-body .form-label { font-size: 11.5px; margin-bottom: 4px; }
.wizard-section-body .ld-form-section-label { margin: 12px 0 7px; }
.wizard-section-body .ld-form-section-label:first-child { margin-top: 0; }
.form-grid { gap: 10px; }

/* ——— Kompaktowe listy powtarzalne ——— */
.points-list { gap: 10px; }
.cargo-items-list { gap: 8px; }
.point-card { border-radius: var(--r); box-shadow: var(--shadow-sm); }
.point-card:hover { box-shadow: var(--shadow); }
.point-card-head { padding: 8px 12px; }
.point-card-body { padding: 12px; }

/* =========================== FINANSE — przebudowa =========================== */
/* Układ: pola po lewej, podsumowanie po prawej (czytelniejsza, premium prawa kolumna) */
.finance-layout { grid-template-columns: minmax(0, 1fr) 300px; gap: 16px; }
.finance-inputs { gap: 10px; }

/* Karta „KWOTA GŁÓWNA OD KLIENTA" — to wpływ (zielony akcent, money-in) */
.finance-card {
    border-radius: var(--r-md);
    box-shadow: var(--shadow-sm);
    border-left: 3px solid color-mix(in srgb, var(--st-success) 70%, var(--border));
    background: var(--card);
}
.finance-card:focus-within { box-shadow: var(--shadow); }
.finance-card-broker { border-left-color: var(--st-customs); }   /* broker = celne/fiolet */
.finance-card .input-group { border-radius: var(--r); }
.finance-card .input-group > input { font-size: 18px; }

/* Podsumowanie — premium kafel (spójny z panelami finansów w podglądzie) */
.finance-summary {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    box-shadow: var(--shadow-md);
    padding: 14px 16px;
    top: 78px;
}
.finance-summary-head {
    color: var(--text);
    border-bottom: 1px solid var(--border);
    margin-bottom: 8px; padding-bottom: 8px;
}
.finance-summary-row {
    position: relative;
    padding: 6px 0 6px 13px;
    border-bottom: 1px dashed var(--line);
}
.finance-summary-row:last-child { border-bottom: 0; }
.finance-summary-row::before {
    content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
    width: 4px; height: 15px; border-radius: 2px; background: var(--st-neutral);
}
.finance-summary-row.income::before  { background: var(--st-success); }
.finance-summary-row.cost::before    { background: var(--st-danger); }
.finance-summary-row.balance::before { background: var(--brand-blue); }
.finance-summary-row.margin::before  { background: var(--st-info); }
.finance-summary-row.of::before      { background: var(--st-neutral); }
.finance-summary-label { font-size: 12px; color: var(--text-muted); }

/* Saldo — wyróżnione */
.finance-summary-row.balance {
    background: color-mix(in srgb, var(--brand-blue) 7%, transparent);
    border-radius: var(--r-sm);
    padding: 8px 10px 8px 13px;
    margin: 2px 0;
}
.finance-summary-row.balance .finance-summary-label { color: var(--text-soft); font-weight: 600; }
.finance-summary-row.balance .finance-summary-value { font-size: 16px; }

/* Wartości — kolory z tokenów (zamiast surowych hexów) */
.finance-summary-value.is-positive { color: var(--st-success); }
.finance-summary-value.is-negative { color: var(--st-danger); }
.finance-summary-value.is-warning  { color: var(--st-warning); }
.finance-summary-divider { background: var(--border); margin: 7px 0; }

/* Marża brokera (czytnik) — tokeny zamiast hexów */
.finance-margin-value.is-positive { color: var(--st-success); }
.finance-margin-value.is-negative { color: var(--st-danger); }
.finance-margin-value.is-warning  { color: var(--st-warning); }

/* Segment przychód/koszt w wierszach pozycji — tokeny */
.price-side-btn.is-active[data-side="income"] { background: var(--st-success); }
.price-side-btn.is-active[data-side="cost"]   { background: var(--st-danger); }
.price-item-row { border-radius: var(--r-sm); }

/* ——— Premium pasek zapisu ——— */
.wizard-save-bar {
    box-shadow: var(--shadow-lg);
    border-top-color: var(--border);
    padding: 11px 24px;
}
.wizard-save-actions .btn-primary {
    background: linear-gradient(135deg, var(--brand-blue), var(--brand-blue-dark));
    box-shadow: var(--shadow-sm);
}

/* ——— Responsywność: prawa kolumna finansów schodzi pod pola ——— */
@media (max-width: 980px) {
    .finance-layout { grid-template-columns: 1fr; }
    .finance-summary { position: static; top: auto; }
}

/* =================================================================================
   FINANSE v2 — ledger + podsumowanie jak w podglądzie ładunku (last-wins)
   Naprawia zawijanie pozycji (była siatka kart minmax(380px)); wiersz = czyste kolumny.
   Hooki JS bez zmian. Tylko tokeny.
   ================================================================================= */
.finance-layout { grid-template-columns: minmax(0, 1fr) 312px; gap: 16px; align-items: flex-start; }
.finance-inputs { display: flex; flex-direction: column; gap: 12px; min-width: 0; }

/* Kwota główna (wpływ = zielony akcent), broker = fiolet celny */
.finance-card {
    background: var(--card); border: 1px solid var(--border);
    border-left: 3px solid color-mix(in srgb, var(--st-success) 70%, var(--border));
    border-radius: var(--r-md); box-shadow: var(--shadow-sm); padding: 12px 14px;
}
.finance-card:focus-within { box-shadow: var(--shadow); }
.finance-card-broker { border-left-color: var(--st-customs); }
.finance-card .input-group { border-radius: var(--r); overflow: hidden; }
.finance-card .input-group > input { font-size: 18px; font-weight: 700; }

/* —— Ledger pozycji dodatkowych —— */
.fin-ledger {
    border: 1px solid var(--border); border-radius: var(--r-md);
    background: var(--card); box-shadow: var(--shadow-sm); overflow: hidden;
}
.fin-ledger-head {
    display: flex; align-items: center; justify-content: space-between; gap: 8px;
    padding: 9px 12px; border-bottom: 1px solid var(--border); background: var(--bg);
    font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: var(--text-soft);
}
.fin-ledger-head small { font-weight: 500; text-transform: none; letter-spacing: 0; color: var(--text-muted); }
.fin-ledger .price-items-list { padding: 8px 12px; }
.fin-ledger .price-items-list:empty { display: none; }
.fin-ledger-add {
    width: 100%; justify-content: center; border: 0; border-top: 1px dashed var(--border);
    border-radius: 0; color: var(--brand-blue); font-weight: 600;
}
.fin-ledger-add:hover { background: color-mix(in srgb, var(--brand-blue) 7%, transparent); }

/* Lista = jedna kolumna (KONIEC zawijania) */
.price-items-list { display: flex; flex-direction: column; gap: 6px; }
.price-item-row { background: transparent; border: 0; padding: 0; }
.price-item-grid {
    display: grid; gap: 8px; align-items: center;
    grid-template-columns: 60px minmax(0, 1fr) 96px 76px 46px 30px;
}
.price-item-grid > .price-desc { grid-column: auto; }
.price-item-row .price-amount { text-align: right; font-weight: 600; }
.price-item-row[data-side="income"] .price-amount { color: var(--st-success); }
.price-item-row[data-side="cost"]   .price-amount { color: var(--st-danger); }

/* Segment +/- */
.price-item-side-toggle {
    display: inline-flex; border: 1px solid var(--border-strong);
    border-radius: var(--r-sm); overflow: hidden; height: 32px;
}
.price-side-btn {
    width: 29px; border: 0; background: var(--card); color: var(--text-muted);
    font-weight: 800; font-size: 15px; cursor: pointer; transition: all var(--t-fast);
}
.price-side-btn + .price-side-btn { border-left: 1px solid var(--border); }
.price-side-btn:hover { background: var(--card-hover); }
.price-side-btn.is-active[data-side="income"] { background: var(--st-success); color: #fff; }
.price-side-btn.is-active[data-side="cost"]   { background: var(--st-danger);  color: #fff; }

/* OF — kompaktowy chip */
.price-separate-toggle {
    display: inline-flex; align-items: center; justify-content: center; height: 32px;
    border: 1px solid var(--border-strong); border-radius: var(--r-sm);
    font-size: 11px; font-weight: 700; color: var(--text-muted); cursor: pointer; user-select: none;
    transition: all var(--t-fast);
}
.price-separate-toggle:has(input:checked) {
    background: var(--st-info-bg); border-color: var(--st-info); color: var(--st-info);
}
.price-separate-toggle input { display: none; }

/* —— Podsumowanie — premium kafel (jak w podglądzie) —— */
.finance-summary {
    background: var(--card); border: 1px solid var(--border);
    border-radius: var(--r-md); box-shadow: var(--shadow-md);
    padding: 14px 16px; position: sticky; top: 78px; align-self: flex-start;
}
.finance-summary-head {
    font-size: 13px; font-weight: 700; color: var(--text);
    text-transform: uppercase; letter-spacing: .04em;
    margin-bottom: 8px; padding-bottom: 8px; border-bottom: 1px solid var(--border);
    display: flex; align-items: center; gap: 6px;
}
.finance-summary-row {
    position: relative; display: flex; justify-content: space-between; align-items: center;
    padding: 6px 0 6px 13px; font-size: 12.5px; border-bottom: 1px dashed var(--line);
}
.finance-summary-row:last-of-type { border-bottom: 0; }
.finance-summary-row::before {
    content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
    width: 4px; height: 15px; border-radius: 2px; background: var(--st-neutral);
}
.finance-summary-row.income::before  { background: var(--st-success); }
.finance-summary-row.cost::before    { background: var(--st-danger); }
.finance-summary-row.margin::before  { background: var(--st-info); }
.finance-summary-row.balance::before { background: var(--brand-blue); }
.finance-summary-row.of::before      { background: var(--st-neutral); }
.finance-summary-label { color: var(--text-muted); }
.finance-summary-value { font-family: var(--font-mono); font-weight: 700; color: var(--text); text-align: right; }
.finance-summary-value.is-positive { color: var(--st-success); }
.finance-summary-value.is-negative { color: var(--st-danger); }
.finance-summary-value.is-warning  { color: var(--st-warning); }

/* Saldo — wyróżnione */
.finance-summary-row.balance {
    background: color-mix(in srgb, var(--brand-blue) 7%, transparent);
    border-radius: var(--r-sm); padding: 8px 10px 8px 13px; margin: 2px 0; border-bottom: 0;
}
.finance-summary-row.balance .finance-summary-label { color: var(--text-soft); font-weight: 600; }
.finance-summary-row.balance .finance-summary-value { font-size: 16px; }

/* Pasek przychód→koszt (jak w podglądzie) */
.fin-bar {
    height: 5px; border-radius: 999px; margin: 9px 0 4px;
    background: linear-gradient(90deg, var(--st-success), var(--st-success) 58%, var(--st-danger));
}

@media (max-width: 980px) {
    .finance-layout { grid-template-columns: 1fr; }
    .finance-summary { position: static; top: auto; }
}
@media (max-width: 560px) {
    .price-item-grid { grid-template-columns: 60px 1fr 30px; }
    .price-item-grid > .price-desc { grid-column: 2 / -1; }
}

/* =================================================================================
   TOWAR v2 — kompaktowo · żółta spójność (sekcja amber) · waga↔LDM · ADR-czerwony
   Nowy układ: [opis · LDM · waga · palety · opakowanie · ×] / uwagi / [UN · ADR · grupa · m³]
   Hooki JS bez zmian. Tokeny (odcienie dat = te z podglądu, w JS).
   ================================================================================= */
.cargo-items-list { display: flex; flex-direction: column; gap: 8px; }
.cargo-item-row {
    position: relative; background: var(--card); border: 1px solid var(--border);
    border-left: 3px solid color-mix(in srgb, var(--st-warning) 60%, var(--border));
    border-radius: var(--r-md); box-shadow: var(--shadow-sm); padding: 10px 12px;
    transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.cargo-item-row:focus-within { box-shadow: var(--shadow); }

/* Wiersz 1 — najważniejsze, jedna linia */
.cargo-item-grid {
    display: grid; gap: 8px; align-items: center;
    grid-template-columns: minmax(0, 1fr) 84px 84px 84px 152px 30px;
}
.cargo-item-grid > .cargo-desc { grid-column: auto; }
.cargo-item-row .cargo-ldm,
.cargo-item-row .cargo-weight,
.cargo-item-row .cargo-pallets { text-align: right; }

/* Wiersz 2 — uwagi (pełna szerokość) */
.cargo-row-notes { width: 100%; margin-top: 8px; }

/* Wiersz 3 — ADR / towar niebezpieczny */
.cargo-adr-grid {
    display: grid; gap: 8px; margin-top: 8px; padding-top: 8px;
    border-top: 1px dashed var(--line); grid-template-columns: repeat(4, minmax(0, 1fr));
}
.cargo-adr-grid .form-group { margin: 0; }
.cargo-adr-grid .form-label-xs { margin-bottom: 2px; }

/* Waga vs LDM — kolor jak w podglądzie (klasy nadaje JS wg progów z ustawień) */
.cargo-weight.wl-green  { color: var(--st-success); }
.cargo-weight.wl-yellow { color: var(--st-warning); font-weight: 700; }
.cargo-weight.wl-red    { color: var(--st-danger); font-weight: 700; box-shadow: inset 0 0 0 1px var(--st-danger-border); }

/* ADR wypełnione (UN / klasa / grupa) → cały wiersz na czerwono */
.cargo-item-row.cargo-adr-on { border-left-color: var(--st-danger); }
.cargo-item-row.cargo-adr-on .cargo-adr-grid { border-top-color: var(--st-danger-border); }
.cargo-item-row.cargo-adr-on .cargo-un,
.cargo-item-row.cargo-adr-on .cargo-adr,
.cargo-item-row.cargo-adr-on .cargo-packing-group {
    border-color: var(--st-danger); color: var(--st-danger); background: var(--st-danger-bg); font-weight: 600;
}
.cargo-item-row.cargo-adr-on .cargo-adr-grid .form-group:nth-child(-n+3) .form-label-xs { color: var(--st-danger); }

/* —— Zwartość pionowa całego kreatora —— */
.wizard-section { margin-bottom: 14px; }
.wizard-section-head { padding: 12px 16px; }
.wizard-section-head h2 { font-size: 15px; margin: 0; }
.wizard-section-head p { font-size: 11.5px; margin: 1px 0 0; }
.wizard-section-body { padding: 14px 16px; }

/* Responsywność towaru */
@media (max-width: 680px) {
    .cargo-item-grid { grid-template-columns: 1fr 1fr; }
    .cargo-item-grid > .cargo-desc { grid-column: 1 / -1; }
    .cargo-item-grid > .cargo-packaging { grid-column: 1 / -1; }
    .cargo-adr-grid { grid-template-columns: 1fr 1fr; }
}

/* =================================================================================
   FORMULARZE — krótkie pola NIE na całą szerokość (kreator: punkty + odprawa)
   Problem: .ld-form-grid rozciągał każde dziecko (m.in. checkboxy FIX/ENS/zdalna
   robiły się pełnym boxem). Zwężamy kolumnę formularza i zwijamy krótkie pola.
   ================================================================================= */
.wizard-section .ld-form-grid { max-width: 880px; }
/* Pojedyncze checkboxy (FIX / ENS / Odprawa zdalna) → zwarte, do lewej, nie pełny box */
.wizard-section .ld-form-grid > .ld-check { width: auto; justify-self: start; }
.wizard-section .customs-flags { display: flex; flex-wrap: wrap; gap: 10px 14px; align-items: center; }
.wizard-section .customs-flags .ld-check { width: auto; margin: 2px 0; }
/* Wąskie pola (data / godzina / kod pocztowy) — sensowna szerokość w swojej kolumnie */
.wizard-section .ld-form-grid input[type="date"],
.wizard-section .ld-form-grid input[type="time"] { max-width: 210px; }
.wizard-section .ld-form-grid .customs-postal,
.wizard-section .ld-form-grid .point-postal { max-width: 150px; }

/* === Atomy w kreatorze + wyrównanie ikon (po migracji ✕/emoji → Ui::icon) === */
/* checkboxy używają teraz atomu .check — te same reguły zwartości co dla .ld-check */
.wizard-section .ld-form-grid > .check { width: auto; justify-self: start; }
.wizard-section .customs-flags .check { width: auto; margin: 2px 0; }
/* ikona przy etykiecie podsumowania + numerze karty odprawy */
.finance-summary-label { display: inline-flex; align-items: center; gap: 6px; }
.finance-summary-label svg { flex: 0 0 auto; opacity: .85; }
.point-card-num { display: inline-flex; align-items: center; justify-content: center; }

/* === Waga ↔ LDM: wyraźny „badge" gdy pojawia się kolor (tło+obwódka+bold) === */
.cargo-item-row .cargo-weight.wl-green,
.cargo-item-row .cargo-weight.wl-yellow,
.cargo-item-row .cargo-weight.wl-red {
    font-weight: 700; border-width: 1.5px; box-shadow: none;
}
.cargo-item-row .cargo-weight.wl-green {
    color: var(--st-success); background: var(--st-success-bg); border-color: var(--st-success-border);
}
.cargo-item-row .cargo-weight.wl-yellow {
    color: var(--st-warning); background: var(--st-warning-bg); border-color: var(--st-warning-border);
}
.cargo-item-row .cargo-weight.wl-red {
    color: var(--st-danger); background: var(--st-danger-bg); border-color: var(--st-danger-border);
}
